Как показать таблицу SQLite в Logcat - PullRequest
0 голосов
/ 23 сентября 2018

Помощник по базам данных

public class DatabaseHelper extends SQLiteOpenHelper {

// Table Name
public static final String TABLE_NAME = "Contacts";

// Table columns
public static final String ID = "ID";
public static final String Contact_Name = "Contact_Name";
public static final String Phone_Number = "Phone_Number";
public static final String Favourites = "Favourites";

// Database Information
static final String DB_NAME = "MessagePlus_Contacts";

// database version
static final int DB_VERSION = 1;

// Creating table query
private static final String CREATE_TABLE = "Create Table " + TABLE_NAME + "(" + ID
        + " INTEGER PRIMARY KEY AUTOINCREMENT, " + Contact_Name + " TEXT NOT NULL, " + Phone_Number + " INT NOT NULL, " + Favourites + " Boolean NOT NULL);";

private static final String Show_Table = "Select * From " + TABLE_NAME;

public DatabaseHelper(Context context) {
    super(context, DB_NAME, null, DB_VERSION);
}

@Override
public void onCreate(SQLiteDatabase db) {
    db.execSQL(CREATE_TABLE);
}

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

public void showData(SQLiteDatabase db){db.execSQL(Show_Table);}

public void insertData(String contactName, String phoneNumber,String favourites) {

    SQLiteDatabase db = this.getWritableDatabase();

    ContentValues values = new ContentValues();

    values.put(DatabaseHelper.Contact_Name, contactName);
    values.put(DatabaseHelper.Phone_Number, phoneNumber);
    values.put(DatabaseHelper.Favourites, favourites);

    db.insert(DatabaseHelper.TABLE_NAME, null, values);
    // close db connection
    db.close();
}

public int addToFavourites(String favourites) {
    SQLiteDatabase db = this.getWritableDatabase();

    ContentValues values = new ContentValues();
    values.put(DatabaseHelper.Favourites, favourites);

    // updating row
    return db.update(DatabaseHelper.TABLE_NAME, values, DatabaseHelper.Phone_Number + " = ?", new String[]{favourites});
}



public int getCount() {
    String countQuery = "SELECT * FROM " + DatabaseHelper.TABLE_NAME;
    SQLiteDatabase db = this.getReadableDatabase();
    Cursor cursor = db.rawQuery(countQuery, null);

    int count = cursor.getCount();
    cursor.close();

    // return count
    return count;
}

Модальные

public class FavouritesHelper {
public String Name;
public String PhoneNumber;
public boolean Favourites;

public FavouritesHelper() {
}

public FavouritesHelper(String Name, String PhoneNumber, Boolean Favourites) {
    this.Name = Name;
    this.PhoneNumber = PhoneNumber;
    this.Favourites = Favourites;
}
public String getName() {
    return Name;
}

public void setName(String Name) {
    this.Name = Name;
}

public String getPhoneNumber() {
    return PhoneNumber;
}

public void setPhoneNumber(String PhoneNumber) {
    this.PhoneNumber = PhoneNumber;
}

public boolean getFavourites() {
    return Favourites;
}

public void setFavourites(boolean Favourites) {
    this.Favourites = Favourites;
}

}

Это мой помощник по базе данных, и я пытаюсь получить таблицу в logcat, но я нене знаю, как это сделать.Я знаю, что код Select * from <tablename>, но как мне это реализовать.Я хочу видеть все данные в моей таблице.

Ответы [ 2 ]

0 голосов
/ 23 сентября 2018

Как @ pskink предположил, что вы можете использовать dumpCursor следующим образом

создать этот метод внутри класса DatabaseHelper

 public  void dumpCursorInLogCat() {

    //here first getting the readable database

            SQLiteDatabase db = this.getReadableDatabase();

            Cursor cursor = db.rawQuery(Show_Table, null);
      //here is how you can Dump cursor
            DatabaseUtils.dumpCursor(cursor);

            cursor.close();


        }

и вызывать этот метод в своей деятельности всякий раз, когда выхотите показывать данные в logcat

вызывайте их внутри своей деятельности как

new DatabaseHelper(your_activity_name.this).dumpCursorInLogCat();
0 голосов
/ 23 сентября 2018

Решение:

Пожалуйста, выполните следующие шаги:

Первый шаг:

Выполните описанный ниже метод в DatabaseHelper класс:

public List<FavouritesHelper> getAllData() {
    List<FavouritesHelper> data = new ArrayList<>();

    // Select All Query
    String selectQuery = "SELECT * FROM " + FavouritesHelper.TABLE_NAME;

    SQLiteDatabase db = this.getWritableDatabase();
    Cursor cursor = db.rawQuery(selectQuery, null);

    // looping through all rows and adding to list
    if (cursor.moveToFirst()) {
        do {
            FavouritesHelper alldata = new FavouritesHelper();

            alldata.setName(cursor.getString(cursor.getColumnIndex(FavouritesHelper.Name)));
            alldata.setPhoneNumber(cursor.getString(cursor.getColumnIndex(FavouritesHelper.PhoneNumber)));
            alldata.setFavourites(cursor.getBoolean(cursor.getColumnIndex(FavouritesHelper.Favourites)));

            data.add(alldata);
        } while (cursor.moveToNext());
    }

    // close db connection
    db.close();

    // return notes list
    return data;
}

Второй шаг:

В вашей деятельности:

объявите глобальный объект: List<FavouritesHelper> AllData внутри вашего класса.

Третий шаг:

Затем добавьте это AllData = new List<FavouritesHelper>(); в ваш onCreate()

Четвертый шаг:

напишите это в своей деятельности после вставки данных: AllData = database.getAllData();

Пятый шаг:

Распечатайте это в журнале, используя следующую инструкцию:

for(FavouritesHelper helper : AllData) {
     Log.e("values : ", helper.getName() + ", " + helper.getPhoneNumber() + ", " + helper.getFavourites());
}

Вот и все.

Попробуйте.Надеюсь, это поможет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...