热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Android实现批量添加联系人到通讯录

nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd

由于工作上的需要,把数据库中备份的联系人添加到Android通讯录,一般都有几百条记录,插入一条数据系统默认commit一次,这样效率就降低了,如果把所有的数据都添加进去后再commit效率就不一样,这就需要事务。

Ubuntu 14.04 x64配置Android 4.4 kitkat编译环境的方法 2014-05/101148.htm

Ubuntu 12.04搭建Android开发环境 2012-09/69961.htm

Ubuntu 14.04 配置 Android SDK 开发环境 2014-05/101039.htm

64位Ubuntu 11.10下Android开发环境的搭建(JDK+Eclipse+ADT+Android SDK详细) 2013-06/85303.htm

Ubuntu 12.10 x64 安装 Android SDK 2013-03/82005.htm

没有添加事务的方法,每次添加一条记录

 /**
  * 单条添加数据
  *
  * @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;
  else
   return 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;
 }

 @Override
 public 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;
  else
   return 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执行一个空值插入,目的是获取系统返回的rawContactId
  Uri 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);
 }

更多详情见请继续阅读下一页的精彩内容: 2014-05/1018p2.htm


推荐阅读
  • 本文讨论了在进行 MySQL 数据迁移过程中遇到的所有 .frm 文件报错的问题,并提供了详细的解决方案和建议。 ... [详细]
  • 您的数据库配置是否安全?DBSAT工具助您一臂之力!
    本文探讨了Oracle提供的免费工具DBSAT,该工具能够有效协助用户检测和优化数据库配置的安全性。通过全面的分析和报告,DBSAT帮助用户识别潜在的安全漏洞,并提供针对性的改进建议,确保数据库系统的稳定性和安全性。 ... [详细]
  • 一个建表一个执行crud操作建表代码importandroid.content.Context;importandroid.database.sqlite.SQLiteDat ... [详细]
  • DAO(Data Access Object)模式是一种用于抽象和封装所有对数据库或其他持久化机制访问的方法,它通过提供一个统一的接口来隐藏底层数据访问的复杂性。 ... [详细]
  • 本文介绍如何使用 Python 的 DOM 和 SAX 方法解析 XML 文件,并通过示例展示了如何动态创建数据库表和处理大量数据的实时插入。 ... [详细]
  • 如何在Java中使用DButils类
    这期内容当中小编将会给大家带来有关如何在Java中使用DButils类,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。D ... [详细]
  • RocketMQ在秒杀时的应用
    目录一、RocketMQ是什么二、broker和nameserver2.1Broker2.2NameServer三、MQ在秒杀场景下的应用3.1利用MQ进行异步操作3. ... [详细]
  • 操作系统如何通过进程控制块管理进程
    本文详细介绍了操作系统如何通过进程控制块(PCB)来管理和控制进程。PCB是操作系统感知进程存在的重要数据结构,包含了进程的标识符、状态、资源清单等关键信息。 ... [详细]
  • oracle c3p0 dword 60,web_day10 dbcp c3p0 dbutils
    createdatabasemydbcharactersetutf8;alertdatabasemydbcharactersetutf8;1.自定义连接池为了不去经常创建连接和释放 ... [详细]
  • 本文介绍了在 Spring Boot 中使用 JPA 进行数据删除操作时遇到的 SQL 错误及其解决方法。错误表现为:删除操作失败,原因是无法打开 JPA EntityManager 以进行事务处理。 ... [详细]
  • 本文详细介绍了如何在 Django 项目中使用 Admin 管理后台,包括创建超级用户、启动项目、管理数据模型和修改用户密码等步骤。 ... [详细]
  • 开机自启动的几种方式
    0x01快速自启动目录快速启动目录自启动方式源于Windows中的一个目录,这个目录一般叫启动或者Startup。位于该目录下的PE文件会在开机后进行自启动 ... [详细]
  • 本文详细介绍了 InfluxDB、collectd 和 Grafana 的安装与配置流程。首先,按照启动顺序依次安装并配置 InfluxDB、collectd 和 Grafana。InfluxDB 作为时序数据库,用于存储时间序列数据;collectd 负责数据的采集与传输;Grafana 则用于数据的可视化展示。文中提供了 collectd 的官方文档链接,便于用户参考和进一步了解其配置选项。通过本指南,读者可以轻松搭建一个高效的数据监控系统。 ... [详细]
  • C# 中 SQLite 报错:在 "\\s\\" 附近出现语法错误,如何解决? ... [详细]
  • 为了确保数据库的高效运行,本文介绍了一种方法,通过编写定时任务脚本来自动清理 `order` 表中状态为 0 或为空的无效订单记录。该脚本使用 PHP 编写,并设置时区为中国标准时间,每 10 分钟执行一次,以保持数据库的整洁和性能优化。此外,还详细介绍了如何配置定时任务以及脚本的具体实现步骤。 ... [详细]
author-avatar
sferra石_455
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有