实现对sqlite数据库增删改查
package com.example.db.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.example.db.PersonSQLiteOpenHelper;
import com.example.db.domain.Person;
public class PersonDao {
//获取dbhelper实例
private PersonSQLiteOpenHelper helper;
// 在构造方法里面完成 helper的初始化
public PersonDao(Context context)
{
helper = new PersonSQLiteOpenHelper(context);
}
/**
* 添加一条记录 ,拿到数据库的第一时间需要把数据库关闭掉
* @param name 姓名
* @param number 电话
*/
public void add(String name,String number){
SQLiteDatabase db = helper.getWritableDatabase();
String sql ="这里是添加的sql语句 values(?,?) ";
//bindArgs 则是一个数组 放添加的值
Object[] bindArgs ={name,number};
db.execSQL(sql, bindArgs);
db.close();
}
/**
* 通过调用系统api 添加一条记录 ,拿到数据库的第一时间需要把数据库关闭掉
* @param name 姓名
* @param number 电话
*/
public long adds(String name,String number){
SQLiteDatabase db = helper.getWritableDatabase();
/**
* table 表名
* nullColumnHack 是否允许数据为空
* values ConteatValues map 集合
*/
ContentValues values = new ContentValues();
values.put("name", name);
values.put("number", number);
long id = db.insert("sys_user", null, values);
db.close();
return id;
}
/**
* 根据用户名查找信息。查询用getReadableDatabase() 通过 rawQuery()去查询 返回 Cursor 游标
* @param name 姓名
* @return true 存在 false 不存在
*/
public boolean find(String name){
SQLiteDatabase db = helper.getReadableDatabase();
String sql ="这里是查询的sql语句 name=? ";
//bindArgs 则是一个数组 放添加的值
String[] selectionArgs ={name};
Cursor cursor = db.rawQuery(sql, selectionArgs);
// cursor.moveToNext() 让结果集移动下一行如果移动成功 说明return true,不成功就return false
boolean result = cursor.moveToNext();
//游标也需要释放
cursor.close();
db.close();
return result;
}
/**
* 修改一条记录
* @param name 用户名
* @param newnumber 用户手机号码
*/
public void update (String name,String newnumber)
{
SQLiteDatabase db = helper.getWritableDatabase();
String sql ="这里是修改的sql语句 set number=? where name=? ";
//bindArgs 则是一个数组 放添加的值
Object[] bindArgs ={name,newnumber};
db.execSQL(sql, bindArgs);
db.close();
}
/**
* 通过系统api修改一条记录
* @param name 用户名
* @param newnumber 用户手机号码
*/
public int updates (String name,String newnumber)
{
SQLiteDatabase db = helper.getWritableDatabase();
/**
* table 表名
* values ContentValues map 集合
* whereClause 选择条件
* whereArgs 站位符
*/
ContentValues values = new ContentValues();
values.put("newnumber", newnumber);
//返回的值大于零 语句执行成功
int num = db.update("sys_user", values, "name =?", new String[] {name}) ;
db.close();
return num;
}
/**
* 删除一条语句
* @param name 用户名
*/
public void delete (String name){
SQLiteDatabase db = helper.getWritableDatabase();
String sql ="这里是删除的sql语句 name=? ";
//bindArgs 则是一个数组 放添加的值
Object[] bindArgs ={name};
db.execSQL(sql, bindArgs);
db.close();
}
/**
* 通过系统api删除一条语句
* @param name 用户名
*/
public int delets (String name){
SQLiteDatabase db = helper.getWritableDatabase();
/**
* table 表名
* whereClause 条件
* whereArgs 占位符
*/
//返回的值大于零 语句执行成功
int num = db.delete("sys_user", "name = ?", new String[]{name});
db.close();
return num;
}
/**
* 返回全部数据信息
* @return
*/
public List<Person> findAll()
{
SQLiteDatabase db = helper.getReadableDatabase();
List<Person> persons = new ArrayList<Person>();
String sql ="查询全部 select * from sys_user";
//如果没有参数可以写null
String[] selectionArgs ={null};
Cursor cursor = db.rawQuery(sql, selectionArgs);
while(cursor.moveToNext()){
int id = cursor.getInt(cursor.getColumnIndex("id"));
String name = cursor.getString(cursor.getColumnIndex("name"));
String number =cursor.getString(cursor.getColumnIndex("number"));
Person p = new Person(id,name,number);
persons.add(p);
}
cursor.close();
db.close();
return persons;
}
/**
* 通过系统api返回全部数据信息
* @return
*/
public List<Person> findAlls(){
SQLiteDatabase db = helper.getReadableDatabase();
List<Person> persons = new ArrayList<Person>();
/**
* table 表名
* columns 返回具体列名
* selection 选择条件
* selectionArgs 选择参数
* groupBy, having, orderBy 有就写 没有写null
*
*/
Cursor cursor = db.query("sys_user", new String[]{"id","name","number"}, null, null, null, null, null);
while(cursor.moveToNext()){
int id = cursor.getInt(cursor.getColumnIndex("id"));
String name = cursor.getString(cursor.getColumnIndex("name"));
String number =cursor.getString(cursor.getColumnIndex("number"));
Person p = new Person(id,name,number);
persons.add(p);
}
cursor.close();
db.close();
return persons;
}
}
实现对sqlite数据库增删改查的更多相关文章
- (转)SQLite数据库增删改查操作
原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...
- Android SQLite 数据库 增删改查操作
Android SQLite 数据库 增删改查操作 转载▼ 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NU ...
- IOS sqlite数据库增删改查
1.简单介绍 简单封装sqlite数据库操作类 BaseDB 用于完毕对sqlite的增删改查.使用前先导入libsqlite3.0.dylib库 2.BaseDB.h // // BaseDB.h ...
- Android 利用xUtils框架实现对sqllite的增删改查
首先下载xUtils,下载地址:https://github.com/wyouflf/xUtils 把下载好的文件压缩,把里面的jar包拷进项目中如图所示: 这里新建一个User类进行测试增删改查 ...
- 使用C#书写SQLite数据库增删改查语句(以及插入byte[]时遇到的问题总结)
在没有使用SQLite这种轻量级的数据库之前,只使用过Sqlserver2008进行数据的增删改查,公司使用的是大型的ORACLE数据库,还没有真正的会使用它.那时候觉得数据库很庞大,然而遇到SQLi ...
- web项目总结——通过jsp+servlet实现对oracle的增删改查功能
1.DAO模式 分包:依次建立 entity:实体包,放的是跟oracle数据库中表结构相对应的对象的属性,也就是这个对象有什么 dao:增删改查接口,实现增删改查的具体方法 service:同dao ...
- Android SQLite数据库增删改查操作
一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库——SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字). TEXT(字符 ...
- SQLite数据库增删改查
一:SQLite数据库简介: SQLite是一种轻量级的关系型数据库,官网:http://www.sqlite.org/. SQLite数据库文件存在于移动设备的一下目录中:data->data ...
- SQLite数据库增删改查操作
一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库——SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字).TEXT(字符串 ...
随机推荐
- D3.js学习笔记(四)—— 使用SVG坐标空间
目标 在这一章,你将要使用D3.js基于一些数据把SVG元素添加到你想要的坐标位置上. 我们的目标就是使用下面的数据集: var spaceCircles = [30,70,110]; 并使用D3.j ...
- 5.8 页面对象(Page Object)模式
页面对象(Page Object)模式是目前自动化测试领域普遍使用的设计模式之一,此模式可以大大提高测试代码的复用率,提高测试脚本的编写效率和维护效率,是中级自动化测试工程师的必备技能之一. 1.页面 ...
- Educational Codeforces Round 22E
给你n和k,n个数,每个数范围1e5,m次查询,每次查询区间(l,r),在区间中的每个数,如果超过k次只算k次,否则算原来的次数,求总次数,强制在线 解法:线段树维护区间中每个数经过k次到达的点pos ...
- 解决Oracle数据库IP地址改变创建数据库的问题
方案一 查了相关的资料后才知道,只要修改安装Oracle的目录下面的listener.ora和tnsnames.ora里面的内容即可.看图看图 修改什么内容呢?看图看图. 就是HOST地址改一下就可 ...
- 四十四 Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的基本查询
1.elasticsearch(搜索引擎)的查询 elasticsearch是功能非常强大的搜索引擎,使用它的目的就是为了快速的查询到需要的数据 查询分类: 基本查询:使用elasticsearch内 ...
- socket http read
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.i ...
- openvswitch的原理和常用命令
一.Openvswitch工作原理 openvSwitch是一个高质量的.多层虚拟交换机,使用开源Apache2.0许可协议,由 Nicira Networks开发,主要实现代码为可移植的C代码.它的 ...
- Django中ORM模板常用属性讲解
学习了ORM模板中常用的字段以及使用方法,具体如下: from django.db import models # Create your models here. # 如果要将一个普通的类映射到数据 ...
- python面向对象总结
一 面向对象的程序设计的由来 见概述:http://www.cnblogs.com/linhaifeng/articles/6428835.html 二 什么是面向对象的程序设计及为什么要有它 面向过 ...
- 《转》浅谈EJB
ejb一直是一个让我很纠结的技术,虽然ejb作为sun推荐的最佳实践,在sun的J2EE教程中,推荐jsp和servlet作为view层,ejb作为业务逻辑层. 上述就是J2EE教程讲J2EE体系中J ...