java - 如何将数据转移到 SQLite?

标签 java android xml sqlite

代码

public class SettingsContacts extends AppCompatActivity {
private RecyclerView contactsList;
private List<ContactsHelper> contacts = new ArrayList<>();
private LinearLayoutManager linearLayoutManager;
private ContactsAdapter mAdapter;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_settings_contacts);

    contactsList = (RecyclerView) findViewById(R.id.usersList);
    //Add the data first
    addDataToList();
    linearLayoutManager = new LinearLayoutManager(getApplicationContext());
    //and then create a object and pass the lis
    mAdapter = new ContactsAdapter(contacts);

    contactsList.setHasFixedSize(true);
    contactsList.setLayoutManager(linearLayoutManager);
    contactsList.setAdapter(mAdapter);
    mAdapter.notifyDataSetChanged();


}

public void addDataToList() {
    ContentResolver contentResolver = getContentResolver();
    Cursor cursor = contentResolver.query(ContactsContract.Contacts.CONTENT_URI, null, null, null, ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME + " ASC");
    if (cursor != null) {
        if (cursor.getCount() > 0) {
            while (cursor.moveToNext()) {
                int hasPhoneNumber = Integer.parseInt(cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.HAS_PHONE_NUMBER)));
                if (hasPhoneNumber > 0) {
                    String id = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));
                    String name = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
                    Cursor phoneCursor = contentResolver.query(
                            ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
                            null,
                            ContactsContract.CommonDataKinds.Phone.CONTACT_ID + " = ?", new String[]{id},
                            null);
                    if (phoneCursor != null) {
                        if (phoneCursor.moveToNext()) {
                            String phoneNumber = phoneCursor.getString(phoneCursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));

                            contacts.add(new ContactsHelper(name, phoneNumber));
                            phoneCursor.close();
                        }
                    }
                }
            }
        }
        cursor.close();
    }
}
}

这会显示 Activity 中用户手机中的所有联系人...如何将数据移动到 SQLite 中的表中?

到目前为止的进展:

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";

// 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);";

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);
 }

helper

public class ContactsHelper {
private String Name;
private String PhoneNumber;

public ContactsHelper() {
}

public ContactsHelper(String Name, String PhoneNumber) {
    this.Name = Name;
    this.PhoneNumber = PhoneNumber;
}
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;
}

}

我已经到了这一点,但我不知道如何继续,因为到目前为止我只通过单击按钮或类似的按钮来添加/修改数据。

如何将完整数据移动到 SQLite,并且当添加新联系人时,显然它不会自动添加到表中,因此当我添加滑动刷新等功能时,我希望新联系人也添加到数据中?

最佳答案

解决方案:

在您的 DatabaseHelper 类中添加此方法:

public void insertData(String contactName, String phoneNumber) {

    SQLiteDatabase db = this.getWritableDatabase();

    ContentValues values = new ContentValues();

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

    db.insert(DatabaseHelper.TABLE_NAME, null, values);

    // close db connection
    db.close();

}

然后,首先,在您的 SettingsContacts 类中创建 DatabaseHelper 全局对象:

public DatabaseHelper database;

将其添加到您的onCreate()

database = new DatabaseHelper(SettingsContacts.this);

然后在此之后,在 addDataToList() 方法中添加以下行,如下所示:

添加这一行:

database.insertData(name, phoneNumber)

如下面的代码所示(写在这里):

if (phoneCursor != null) {
    if (phoneCursor.moveToNext()) {
         String phoneNumber = phoneCursor.getString(phoneCursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));

          contacts.add(new ContactsHelper(name, phoneNumber));
          phoneCursor.close();

          ....... (Write Here)

     }
}

就是这样。

希望它能起作用。

要查看数据是否已插入,您可以检查表的计数:

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

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

    // return count
    return count;
}

在数据库处理程序类中编写上述方法。

然后,在调用 insertData(..) 之后的 Activity 中,您可以这样写:

int count = database.getCount();
Log.e("Count From DB: ", String.valueOf(count));

关于java - 如何将数据转移到 SQLite?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52454839/

相关文章:

java - 隐写术尝试,为什么我的照片没有任何反应?

java - 加载广告时抛出这个异常是什么原因

强调 ListView 行的 Android ICS 指南

ruby-on-rails - 如何配置与非 ActiveRecord 模型的 has_many 关联

python-3.x - 跳过大型 XML 文件中的元素(python 3)

java - Java中如何获取返回类型为List接口(interface)的对象?

java - Teradata 和 JDBC 驱动程序 - classnotfoundexception ...但它在那里?

Android - 从特定 Thread_ID 查询所有彩信和短信

android - 膨胀类 com.facebook.widget.LoginButton 时出错

python - 如何使用python查找xml文件中的元素并替换同名元素的值?