Android大量新增連絡人到通訊錄

來源:互聯網
上載者:User

由於工作上的需要,把資料庫中備份的連絡人添加到通訊錄,一般都有幾百條記錄,插入一條資料系統預設commit一次,這樣效率就降低了,如果把所有的資料都添加進去後再commit效率就不一樣,這就需要事務

沒有添加事務的方法,每次添加一條記錄

/** * 單條添加資料 *  * @param contacts * @return */public boolean add(Tb_contacts contacts) {SQLiteDatabase db = helper.getWritableDatabase();ContentValues values = new ContentValues();values.put("name", contacts.getName());values.put("number", contacts.getNumber());long result = db.insert("tb_contacts", null, values);GlobalConstants.PrintLog_D("[ContactsDAO->add] result = " + result);db.close();if (result != -1)return true;elsereturn false;}
Tb_contacts是實體類

public class Tb_contacts {private String name;private String number;public Tb_contacts() {super();}public Tb_contacts(String name, String number) {super();this.name = name;this.number = number;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getNumber() {return number;}public void setNumber(String number) {this.number = number;}@Overridepublic String toString() {return "Tb_contacts [name=" + name + ", number=" + number + "]";}}
添加二百多條記錄要兩分多鐘

看下面這種方法

/** * 大量新增資料 *  * @param cursor * @return */public boolean add(Cursor cursor) {SQLiteDatabase db = helper.getWritableDatabase();long result = 0;db.beginTransaction();while (cursor.moveToNext()) {ContentValues values = new ContentValues();String contactname = cursor.getString(cursor.getColumnIndex(Phone.DISPLAY_NAME));String contactnumber = cursor.getString(cursor.getColumnIndex(Phone.NUMBER));values.put("name", contactname);values.put("number", contactnumber);result = db.insert("tb_contacts", null, values);GlobalConstants.PrintLog_D("[ContactsDAO->add] cursor result = "+ result + " number = " + contactnumber);}db.setTransactionSuccessful(); // 設定交易處理成功,不設定會自動復原不提交db.endTransaction();cursor.close();db.close();if (result != -1)return true;elsereturn false;}
傳入的參數是查詢得到的資料

Cursor contactsCursor = getActivity().getContentResolver().query(Phone.CONTENT_URI, null, null, null, null); // 讀取連絡人contacts.add(contactsCursor);
同樣的資料只要十幾秒就可以了,關鍵就這幾句話

1.db.beginTransaction(); 迴圈之前開啟事務
2.db.setTransactionSuccessful(); 迴圈結束後調用
3.db.endTransaction();最後釋放事務
以上是對一般資料庫的操作,對通訊錄有專門的ContentProvider大量操作

先看一條一條記錄操作

/** * 往資料庫中新增連絡人 *  * @param name * @param number */public static void AddContact(String name, String number) {ContentValues values = new ContentValues();// 首先向RawContacts.CONTENT_URI執行一個空值插入,目的是擷取系統返回的rawContactIdUri rawContactUri = mContext.getContentResolver().insert(RawContacts.CONTENT_URI, values);long rawContactId = ContentUris.parseId(rawContactUri);// 往data表插入姓名資料values.clear();values.put(Data.RAW_CONTACT_ID, rawContactId);values.put(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE);// 內容類型values.put(StructuredName.GIVEN_NAME, name);mContext.getContentResolver().insert(ContactsContract.Data.CONTENT_URI,values);// 往data表插入電話資料values.clear();values.put(Data.RAW_CONTACT_ID, rawContactId);values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);values.put(Phone.NUMBER, number);values.put(Phone.TYPE, Phone.TYPE_MOBILE);mContext.getContentResolver().insert(ContactsContract.Data.CONTENT_URI,values);}
二百多條記錄差不多要七分鐘

使用下面大量新增方法,不到兩分鐘

/** * 大量新增通訊錄 *  * @throws OperationApplicationException * @throws RemoteException */public static void BatchAddContact(List list)throws RemoteException, OperationApplicationException {GlobalConstants.PrintLog_D("[GlobalVariables->]BatchAddContact begin");ArrayList ops = new ArrayList();int rawContactInsertIndex = 0;for (Tb_contacts contact : list) {rawContactInsertIndex = ops.size(); // 有了它才能給真正的實現大量新增ops.add(ContentProviderOperation.newInsert(RawContacts.CONTENT_URI).withValue(RawContacts.ACCOUNT_TYPE, null).withValue(RawContacts.ACCOUNT_NAME, null).withYieldAllowed(true).build());// 添加姓名ops.add(ContentProviderOperation.newInsert(android.provider.ContactsContract.Data.CONTENT_URI).withValueBackReference(Data.RAW_CONTACT_ID,rawContactInsertIndex).withValue(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE).withValue(StructuredName.DISPLAY_NAME, contact.getName()).withYieldAllowed(true).build());// 添加號碼ops.add(ContentProviderOperation.newInsert(android.provider.ContactsContract.Data.CONTENT_URI).withValueBackReference(Data.RAW_CONTACT_ID,rawContactInsertIndex).withValue(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE).withValue(Phone.NUMBER, contact.getNumber()).withValue(Phone.TYPE, Phone.TYPE_MOBILE).withValue(Phone.LABEL, "").withYieldAllowed(true).build());}if (ops != null) {// 真正添加ContentProviderResult[] results = mContext.getContentResolver().applyBatch(ContactsContract.AUTHORITY, ops);// for (ContentProviderResult result : results) {// GlobalConstants// .PrintLog_D("[GlobalVariables->]BatchAddContact "// + result.uri.toString());// }}}
通過以上的對比,對於資料庫效率就不一樣了!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.