android дублирование значений в студии и sqlite count - PullRequest
0 голосов
/ 02 марта 2020

Я не знаю, как посчитать повторную стоимость партии. Пожалуйста, помогите мне кому-нибудь, это очень полезно для моего проекта колледжа. я сохранил свои данные в базе данных sqlite, здесь я прикрепил скриншот таблицы. Мне нужно показать, сколько DMK, ADMK и BJP. например, DMK = 5, ADMK = 3, BJP = 3. для показа на тосте. Table

, если кто-нибудь скажет мне, как изменить мою кодировку, и дайте мне соответствующую кодировку.

Страница голосования. java


protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_votingpage);
        myDb = new DatabaseHelper(this);

        emailview = findViewById(R.id.emailview);
        edtaadhar1 = findViewById(R.id.edtaadhar1);
        btnlogout = findViewById(R.id.btnlogout);
        btnadd = findViewById(R.id.btnadd);
        btncheck = findViewById(R.id.btncheck);
        radioGroup = findViewById(R.id.radioGroup);

        dmk = findViewById(R.id.dmk);


        AddData();


        FirebaseAuth firebaseAuth = FirebaseAuth.getInstance();
        FirebaseUser firebaseUser = firebaseAuth.getCurrentUser();
        emailview.setText(firebaseUser.getEmail());

        btncheck.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

            }
        });

        btnlogout.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent(Votingpage.this,MainActivity.class);
                startActivity(intent);
            }
        });
    }

        private void AddData() {
            btnadd.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                if (edtaadhar1.getText().toString().trim().length() <= 0) {
                    Toast.makeText(Votingpage.this, "Please enter aadhar no", Toast.LENGTH_SHORT).show();
                }else {


                    int radioid = radioGroup.getCheckedRadioButtonId();

                    radioButton = findViewById(radioid);

                    boolean isInserted = myDb.insertData(radioButton.getText().toString(),edtaadhar1.getText().toString());
                    if (isInserted = true)
                        Toast.makeText(Votingpage.this, "Thanks for giving your vote", Toast.LENGTH_SHORT).show();

                    else
                        Toast.makeText(Votingpage.this, "data not inserted", Toast.LENGTH_SHORT).show();


                }

            }
        });
    }

    public void check_button(View v){
        int radioid = radioGroup.getCheckedRadioButtonId();

        radioButton = findViewById(radioid);
    }
}

DatabaseHelper. java

public class DatabaseHelper extends SQLiteOpenHelper {
    public static final String DATABASE_NAME = "Vote.db";
    public static final String TABLE_NAME = "voter_table";
    public static final String COL_1 = "ID";
    public static final String COL_2 = "PARTY";
    public static final String COL_3 = "AADHAR";



    public DatabaseHelper(Context context) {
        super(context, DATABASE_NAME, null, 1);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("create table " + TABLE_NAME + " (ID INTEGER PRIMARY KEY AUTOINCREMENT,PARTY TEXT,AADHAR INTEGER)");
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
        onCreate(db);
    }


    public boolean insertData(String party,String aadhar) {
        if (!isValueExist(aadhar)) {


            SQLiteDatabase db = this.getWritableDatabase();
            ContentValues contentValues = new ContentValues();
            contentValues.put(COL_2, party);
            contentValues.put(COL_3, aadhar);


            long result = db.insert(TABLE_NAME, null, contentValues);
            return result != -1;
        }else {
                return false;

        }

    }

    private boolean isValueExist(String aadhar) {
        String query = "SELECT * FROM " + TABLE_NAME + " WHERE " + COL_3 + " = ?";
        String[] whereArgs = {aadhar};

        SQLiteDatabase db = this.getReadableDatabase();
        Cursor cursor = db.rawQuery(query, whereArgs);

        int count = cursor.getCount();

        cursor.close();

        return count >= 1;
    }


    public Cursor getAllData() {
        SQLiteDatabase db = this.getWritableDatabase();
        Cursor res = db.rawQuery("select * from "+TABLE_NAME,null);
        return res;
    }




}

1 Ответ

1 голос
/ 02 марта 2020

Вам нужен метод для этого запроса:

select PARTY, count(PARTY) from voter_table group by PARTY;

Он вернет 2 столбца, т. Е. Имя и счет PARTY.

РЕДАКТИРОВАТЬ:

Используйте этот метод для получения данных:

public List<Data> getPartyCountData() {
    SQLiteDatabase db = this.getWritableDatabase();
    Cursor cursor = db.rawQuery("select PARTY, count(PARTY) from voter_table group by PARTY", null);
    List<Data> dataList = new ArrayList<>();
    while (cursor.moveToNext()) {
        String partyName = cursor.getString(0);
        Integer partyCount = cursor.getInt(1);
        Data data = new Data(partyName, partyCount);
        dataList.add(data);
    }
    return dataList;
}

и создания данных POJO. java

public class Data {
    String partyName;
    Integer partyCount;

    public Data(String partyName, Integer partyCount) {
        this.partyName = partyName;
        this.partyCount = partyCount;
    }

    public String getPartyName() {
        return partyName;
    }

    public void setPartyName(String partyName) {
        this.partyName = partyName;
    }

    public Integer getPartyCount() {
        return partyCount;
    }

    public void setPartyCount(Integer partyCount) {
        this.partyCount = partyCount;
    }
}

В списке данных вы получите имя и количество всех участников.

...