package com.examp.use_SQLite.dao;

import java.util.ArrayList;
import java.util.List; import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase; import com.examp.use_SQLite.PersonSQLiteOpenHelper;
import com.examp.use_SQLite.domain.Person; public class PersonDaoForAndroid {
// 获取要操作的数据库对象
private PersonSQLiteOpenHelper helper; /**
* 在构造方法中完毕helper的初始化
*
* @param context
*/
public PersonDaoForAndroid(Context context) {
helper = new PersonSQLiteOpenHelper(context);
} /**
* 加入数据
*
* @param name姓名
* @param number电话
* @return 返回新插入一行的行ID,或者-1说明发生一个错误
*/
public long add(String name, String number) {
// 获取数据库的连接对象
SQLiteDatabase db = helper.getWritableDatabase();
// 以下是API推荐的写法
ContentValues values = new ContentValues();
values.put("name", name);
values.put("number", number);
// 目标数据表
// 返回新插入一行的行ID,或者-1说明发生一个错误
long id = db.insert("person", null, values);
// 及时的关闭数据库连接
db.close();
return id;
} /**
* 依据用户姓名查询数据
*
* @param name
* 查询条件
* @return 查询结果
*/
public Person findByName(String name) {
// 获取数据库连接
SQLiteDatabase db = helper.getReadableDatabase();
// 目标数据表名|指定返回的数据字段,假设设置null表示返回全部的数据字段|条件语句,不包含wherekeyword|条件的參数列表|分组的语句|having查询的语句|排序的语句,假设不设置表示使用默认
Cursor cursor = db.query("person", null, "name=?",
new String[] { name }, null, null, null); // 声明结果对象
Person person = null;
// 推断是否有结果返回
if (cursor.moveToNext()) {
// 取出数据集中的单行数据的个字段的数据
// cursor.getColumnIndex("id");获取指定的字段的下标
// cursor.getInt(index);或getString(index);是获取指定的下标的数据index为int类型;
int id = cursor.getInt(cursor.getColumnIndex("id"));
String named = cursor.getString(cursor.getColumnIndex("name"));
String number = cursor.getString(cursor.getColumnIndex("number"));
// 实例化查询结果数据对象
person = new Person(id, named, number);
}
// 关闭数据库连接,释放资源
db.close();
// 返回数据结果对象
return person;
} /**
* 依据name更新一条数据
*
* @param name
* 跟新条件
* @param newnumber
* 新的数据
* @return rows受影响的行数
*/
public int update(String name, String newnumber) {
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("number", newnumber);
// 目标数据表|要更新的数据|更新条件语句|更新条件參数列表
int rows = db.update("person", values, "name=?", new String[] { name });
db.close();
return rows;
} /**
* 依据指定的名字删除数据
*
* @param name
* 删除条件
* @return rows受影响的行数
*/
public int delete(String name) {
SQLiteDatabase db = helper.getWritableDatabase();
// 目标数据库表名称|条件语句|条件參数
int rows = db.delete("person", "name=?", new String[] { name });
db.close();
return rows;
} /**
* 查询全部的操作
*
* @return 查询的结果集
*/
public List<Person> findAll() {
SQLiteDatabase db = helper.getReadableDatabase();
Cursor cursor = db.query("person", null, null, null, null, null, null);
// 声明结果集
// 初始化结果集
List<Person> persons = new ArrayList<Person>();
// 推断是否有结果返回
while (cursor.moveToNext()) { // 声明结果对象
Person person = null;
// 取出数据集中的单行数据的个字段的数据
// cursor.getColumnIndex("id");获取指定的字段的下标
// cursor.getInt(index);或getString(index);是获取指定的下标的数据index为int类型;
int id = cursor.getInt(cursor.getColumnIndex("id"));
String named = cursor.getString(cursor.getColumnIndex("name"));
String number = cursor.getString(cursor.getColumnIndex("number"));
// 实例化查询结果数据对象
person = new Person(id, named, number);
// 向结果集中加入数据
persons.add(person);
}
// 关闭连接,释放资源
db.close();
// 放回结果集
return persons;
}
}

其他的代码參见还有一篇博客Android实现SQLite数据库的增、删、改、查的操作

Android中API建议的方式实现SQLite数据库的增、删、改、查的操作的更多相关文章

  1. iOS FMDB的使用(增,删,改,查,sqlite存取图片)

    iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...

  2. Android中数据存储(三)——SQLite数据库存储数据

    当一个应用程序在Android中安装后,我们在使用应用的过程中会产生很多的数据,应用都有自己的数据,那么我们应该如何存储数据呢? 数据存储方式 Android 的数据存储有5种方式: 1. Share ...

  3. 【转】Android 增,删,改,查 通讯录中的联系人

    一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission. ...

  4. Android 增,删,改,查 通讯录中的联系人

    一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission. ...

  5. python基础中的四大天王-增-删-改-查

    列表-list-[] 输入内存储存容器 发生改变通常直接变化,让我们看看下面列子 增---默认在最后添加 #append()--括号中可以是数字,可以是字符串,可以是元祖,可以是集合,可以是字典 #l ...

  6. Android SQLite(1)简单示例-增,删,改,查

    1.主要核心类,Sqlite编程要继承SQLiteOpenHelper import android.content.Context; import android.database.sqlite.S ...

  7. 怎样从C#中打开数据库并进行 增 删 改 查 操作

    首先 在C#中引用数据库的操作! (因为我们用的是SQLserver数据库,所以是SqlClient) using System.Data.SqlClient; 1:要实现对数据库的操作,我们必须先登 ...

  8. JDBC中执行sql语句的 增 , 删 , 改 , 查 的方法

    executeQuery()  : 执行 SELECT 语句,它几乎是使用最多的 SQL 语句 executeUpdate() :   执行 INSERT.UPDATE 或 DELETE 语句以及 S ...

  9. Android笔记——Android中数据的存储方式(二)

    我们在实际开发中,有的时候需要储存或者备份比较复杂的数据.这些数据的特点是,内容多.结构大,比如短信备份等.我们知道SharedPreferences和Files(文本文件)储存这种数据会非常的没有效 ...

随机推荐

  1. NDEF-NFC数据交换格式

    为实现NFC标签.NFC设备以及NFC设备之间的交互通信,NFC论坛(NFC FROUM)定义了称为NFC数据交换格式(NDEF)的通用数据格式.NDEF是轻量级的紧凑的二进制格式,可带有URL,vC ...

  2. 时间TDateTime相当于是Double,即双精度数64位,终于查到它用11位表示e,53位表示精度(整数小数一起),最前面一位表示正负

    http://docwiki.embarcadero.com/RADStudio/Seattle/en/Internal_Data_Formats 关于Double的RTL函数,好像就一个:TrySt ...

  3. http协言和web本质

    http协议和web本质 作为一个开发者,尤其是web开发人员,我想你有必要去了解这一系列的处理流程,在这期间,浏览器和服务器到底是如何打交道的?服务器又是如何处理的?浏览器又是如何将网页显示给用户的 ...

  4. 推荐使用Tiny Framework web开发UI组件

    TINY FRAMEWORK 基于组件化的J2EE开发框架,from:http://www.tinygroup.org/   名字 Tiny名称的来历 取名Tiny是取其微不足道,微小之意. Tiny ...

  5. poj 1852 Ants_贪心

    题目大意:很多的蚂蚁都在长度为L(cm)的膀子上爬行,它们的速度都是1cm/s,到了棒子终端的时候,蚂蚁就会掉下去.如果在爬行途中遇到其他蚂蚁,两只蚂蚁的方向都会逆转.已知蚂蚁在棒子的最初位置坐标,但 ...

  6. Android学习总结——Activity状态保存和恢复

    Android中启动一个Activity如果点击Home键该Activity是不会被销毁的,但是当进行某些操作时某些数据就会丢失,如下: Java class: package com.king.ac ...

  7. ThreadLocal 在web环境下使用的边界问题

    ThreadLocal 相关分析,请查看http://wangxinchun.iteye.com/blog/1884228 另外一个必须要提的点是: ThreadLocal在线程池环境下的使用. 比如 ...

  8. HTML 基础 1

    1. 文件结构: HTML文件的固定结构: <html> <head>...</head> <body>...</body> </ht ...

  9. xcode中控件共有属性

    Text,title 控件上的文字 backgroung 背景图片或颜色 alignment 布局(居中,..) mode显示模式(缩放,拉伸..) drawing 隐藏控件的可见性 alpha 透明 ...

  10. InitCommonControlsEx()

    参见:http://blog.sina.com.cn/s/blog_4fcd1ea30100qlzp.html MFC通用控件初始化 ********************************* ...