Android在API推荐的方式来实现SQLite数据库的增长、删除、变化、检查操作
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数据库的增长、删除、变化、检查操作的更多相关文章
- Android中API建议的方式实现SQLite数据库的增、删、改、查的操作
package com.examp.use_SQLite.dao; import java.util.ArrayList; import java.util.List; import android. ...
- Android开发8:数据存储(二)——SQLite数据库和ContentProvider的使用
前言 啦啦啦各位小伙伴们许久不见了~学期末和过年期间自己忙着做其他事没能及时更新Android开发系列课程的博客,实在是罪过罪过~ 好啦~废话不多说,进入我们今天的主题.今天我们将和大家学习其他的数据 ...
- android开发之路09(浅谈SQLite数据库01)
1.SQLite数据库: SQLite 是一个开源的嵌入式关系数据库,实现自包容.零配置.支持事务的SQL数据库引擎. 其特点是高度便携.使 用方便.结构紧凑.高效.可靠. 与其他数据库管理系统不同, ...
- [Android] SQLite数据库之增删改查基础操作
在编程中常常会遇到数据库的操作,而Android系统内置了SQLite,它是一款轻型数据库,遵守事务ACID的关系型数据库管理系统,它占用的资源非常低,可以支持Windows/Linux/Un ...
- Android中操作数据的集中方式---文件,SQLite,ContentProvider
http://blog.csdn.net/he90227/article/details/33734239 转
- Android(java)学习笔记192:SQLite数据库(表)的创建 以及 SQLite数据库的升级
一.数据库的创建 1.文件的创建 //引用,如果文件不存在是不会创建的 File file = new File("haha.txt"): //输出流写数据 ...
- Android(java)学习笔记135:SQLite数据库(表)的创建 以及 SQLite数据库的升级
一.数据库的创建 1.文件的创建 //引用,如果文件不存在是不会创建的 File file = new File("haha.txt"): //输出流写数据 ...
- Android中SQLite数据库小计
2016-03-16 Android数据库支持 本文节选并翻译<Enterprise Android - Programing Android Database Applications for ...
- 【Android】13.0 第13章 创建和访问SQLite数据库—本章示例主界面
分类:C#.Android.VS2015: 创建日期:2016-02-26 一.简介 Android 内置了三种数据存取方式:SQLite数据库.文件.SharedPreferences. 这一章我们 ...
随机推荐
- [SVN]两个分支合并
Date:2014-1-1 Summary: 记录一下自己使用SVN时候的操作步骤,先吃鱼,再学钓鱼 Contents: 环境:从同事的branch迁出一份代码,作为自己的分支进行开发,同时同事也在自 ...
- java 状态模式 解说演示样例代码
package org.rui.pattern; import junit.framework.*; /** * 为了使同一个方法调用能够产生不同的行为,State 模式在代理(surrogate)的 ...
- nginx 源码安装
安装环境: 操作系统:Ubuntu 12.04 Nginx: V1.4.2 PCRE: V8.33 zlib: V1.2.8 下载上述源包到当前用户主目录(本机:/hom ...
- TRIZ系列-创新原理-29-气动或液压结构原理
气动或液压结构原理的详细表述例如以下:1)用气态或液态部件替代固体部件.能够用空气或者水,也能够用气垫或水垫,使这些部件膨胀.这条原理符合系统的动态性进化法则-柔性化.在改造系统时,我们能够尝试将系统 ...
- 【剑指offer】q34:丑数
题目要求第n个丑数.所以对于中间结果不须要保存. def Humble(index): curHum = 1 M2 = 2; M3 = 3; M5 = 5 while index > 1: cu ...
- 黑马程序猿_ 利用oc的协议实现代理模式
先说下代理模式是什么吧 定义: 为其它对象提供一种代理以控制对这个对象的訪问.在某些情况下,一个对象不适合或者不能直接引用还有一个对象 而代理对象能够在client和目标对象之间起到中介的作用. 在看 ...
- fastdfs storage server的设计与实现
fastdfs是一个针对互联网应用设计的分布式文件系统.具有架构简单.结构清晰.代码量小等特点. 详细的介绍及架构请參考分布式文件系统FastDFS架构剖析(http://www.program ...
- hdu 4925 贪心 自己从小到大做数据找方法规律
http://acm.hdu.edu.cn/showproblem.php?pid=4925 自己逐个做数据找规律.提供下我的找的: 1 2 1 3 2 2 2 3 3 3 然后发现这种矩阵是最优的: ...
- 前后端分离Web项目中,RBAC实现的研究
在前后端分离Web项目中,RBAC实现的研究 最近手头公司的网站项目终于渐渐走出混沌,走上正轨,任务也轻松了一些,终于有时间整理和总结一下之前做的东西. 以往的项目一般使用模板引擎(如ejs)渲染 ...
- SlidingMenu开源项目滑动界面的实现总结
先上图 须要准备的是先得在GitHub上下载ActionBarSherlock-master.zip,和SlidingMenu-master.zip这两个开源文件,然后解压这两个包,SlidingMe ...