Android中SQLite的增删改查

  1. 首先我们创建一个数据库帮助类PersonSQLLiteOpenHelper,单词拼写有点小错误。。

    让这个类继承SQLiteOpenHelper

  2. package com.example.android03db.db;
    
    import android.content.Context;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteDatabase.CursorFactory;
    import android.database.sqlite.SQLiteOpenHelper;
    
    /**
     * 数据库帮助类,用于创建和管理数据库
     * @author Administrator
     *
     */
    public class PersonSQLLiteOpenHelper extends SQLiteOpenHelper {
    
    	/**
    	 * 数据库的构造函数
    	 * @param context
    	 * @param name数据库名称
    	 * @param factory游标工程
    	 * @param version数据库版本
    	 */
    	public PersonSQLLiteOpenHelper(Context context, String name,
    			CursorFactory factory, int version) {
    		super(context, "hzg01.db", null, 1);//依次是上下文,数据库的名称,版本,不能低于1
    	}
    	public PersonSQLLiteOpenHelper(Context context) {
    		super(context, "hzg01.db", null, 1);//依次是上下文,数据库的名称,版本,不能低于1
    	}
    
    	/**
    	 * 数据库第一次创建时调用此方法
    	 * 初始化一些表
    	 */
    	@Override
    	public void onCreate(SQLiteDatabase db) {
    		//操作数据库
    		String sql="create table person(id integer primary key,name varchar(20),age integer)";
    		db.execSQL(sql);//创建person表
    	}
    	/**
    	 * 数据库的版本号更新时回调此方法
    	 */
    	@Override
    	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    
    	}
    
    }

接下来我们写一个DAO

package com.example.android03db.dao;

import java.util.ArrayList;
import java.util.List;

import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;

import com.example.android03db.db.PersonSQLLiteOpenHelper;
import com.example.android03db.entities.Person;

public class PersonDao {
	private PersonSQLLiteOpenHelper personsql;//数据库的帮助类
	public PersonDao(Context context){
		 personsql=new PersonSQLLiteOpenHelper(context);

	}
	/**
	 * 添加到person表中一条数据
	 * @param p
	 */
	public void insert(Person p){
		SQLiteDatabase db=personsql.getWritableDatabase();
		if(db.isOpen()){//如果数据库打开执行添加的操作
			//执行添加到数据库的操作
			String sql="insert into person (name,age) values(?,?)";
			db.execSQL(sql,new Object[]{p.getName(),p.getAge()});
			db.close();//数据库关闭
		}
	}
	public void delete(int id){
		SQLiteDatabase db=personsql.getWritableDatabase();//获得可写的数据库对象
		if(db.isOpen()){//如果数据库打开执行添加的操作
			//执行添加到数据库的操作
			db.execSQL("delete from person where id=?", new Integer[]{id});
			db.close();//数据库关闭
		}
	}
	public void update(int id,String name){
		SQLiteDatabase db=personsql.getWritableDatabase();
		if(db.isOpen()){//如果数据库打开执行添加的操作
			//执行添加到数据库的操作
			db.execSQL("update person set name=? where id=?", new Object[]{name,id});
			db.close();//数据库关闭
		}
	}

	public List<Person> queryAll(){
			SQLiteDatabase db=personsql.getReadableDatabase();//获得一个只读的数据库对象
			if(db.isOpen()){
				//db.execSQL("select *from person");
				Cursor cursor=db.rawQuery("select id,name,age from person", null);
				if(cursor!=null&&cursor.getCount()>0){
					List<Person> persons=new ArrayList<Person>();
					while(cursor.moveToNext()){

						int id=cursor.getInt(0);//取第0列id
						String name=cursor.getString(1);
						int age=cursor.getInt(2);
						persons.add(new Person(id,name,age));
					}
					db.close();
					return persons;
				}
				db.close();
			}
			return null;
	}

	public Person queryIntem(int id){
		SQLiteDatabase db=personsql.getReadableDatabase();//获得一个只读的数据库对象
		if(db.isOpen()){
			Cursor cursor=db.rawQuery("select id,name,age from person where id=?", new String[]{id+""});
			if(cursor!=null&&cursor.moveToFirst()){
				int pid=cursor.getInt(0);//取第0列id
				String name=cursor.getString(1);
				int age=cursor.getInt(2);
				return new Person(pid,name,age);
			}
		}
		return null;
	}

}

定义一个entity类Person

package com.example.android03db.entities;

public class Person {
	private int id;
	private String name;
	private int age;
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
	public Person(int id, String name, int age) {
		super();
		this.id = id;
		this.name = name;
		this.age = age;
	}
	public Person() {
		super();
	}
	public Person(String name, int age) {
		super();
		this.name = name;
		this.age = age;
	}
	@Override
	public String toString() {
		return "Person [id=" + id + ", name=" + name + ", age=" + age + "]";
	}

}

测试阶段

package com.example.android03db.test;

import java.util.List;

import android.test.AndroidTestCase;
import android.util.Log;

import com.example.android03db.dao.PersonDao;
import com.example.android03db.db.PersonSQLLiteOpenHelper;
import com.example.android03db.entities.Person;

public class Test extends AndroidTestCase{

	private static final String TAG = "Test";
	public static void main(String[] args) {
		// TODO Auto-generated method stub

	}
	public void t(){
		PersonSQLLiteOpenHelper pl=new PersonSQLLiteOpenHelper(getContext());
		//第一次连接数据库时,创建数据库文件oncreate会被调用
		pl.getReadableDatabase();
	}
	public void testinsert(){
		PersonDao dao=new PersonDao(getContext());
		dao.insert(new Person("张三",25));
	}
	public void testDelete(){
		PersonDao dao=new PersonDao(getContext());
		dao.delete(1);
	}

	public void testUpdate(){
		PersonDao dao=new PersonDao(getContext());
		dao.update(2, "李四");
	}
	public void testQueryAll(){
		PersonDao dao=new PersonDao(getContext());
		List<Person> persons=dao.queryAll();
		for(Person ps:persons){
		Log.i(TAG, ps.toString());}
	}
	public void testQueryItem(){
		PersonDao dao=new PersonDao(getContext());
		Person p=dao.queryIntem(2);
		Log.i(TAG, p.toString());
	}
}
时间: 2024-10-08 02:21:29

Android中SQLite的增删改查的相关文章

【Android】Sqlite数据库增删改查

Android系统内置一个Sqlite数据库,如果app需要使用Sqlite数据库数据库存储数据,Android会为此app生成一个.db文件.这个数据库在data/data/<package_name>/databases里面,其中<package_name>为该安卓app的工程包名,这个目录必须root后才能看到.在Windows,单机的应用程序,存储数据,基本放到一个文件里面,正如游戏的存档,基本就是把当前的游戏状态存到一个用户很难找到的文件里面.每次存档读档就是一个从这个存

(转)SQLite数据库增删改查操作

原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字).TEXT(字符串文本)和BLOB(二进制对象)数据类型,虽然它支持的类型只有五种,但实际上sqlite3也接受varchar(n).char(n).d

IOS sqlite数据库增删改查

1.简单介绍 简单封装sqlite数据库操作类 BaseDB 用于完毕对sqlite的增删改查.使用前先导入libsqlite3.0.dylib库 2.BaseDB.h // // BaseDB.h // SqliteDemo // // Created by 赵超 on 14-8-26. // Copyright (c) 2014年 赵超. All rights reserved. // #import <Foundation/Foundation.h> #import "sqli

yii中数据的"增删改查"相关工作!(此文比较乱,需细看)

使用findByPk()根据数据表主键查询的是对象,不需要使用foreach()循环出来 但是使用findall()和find()查询的是对象类型的数组需要使用foreach()循环出来 ======================================= public function getMinLimit () { $sql = "..."; $result = yii::app()->db->createCommand($sql); $query = $r

一、数据库表中字段的增删改查,二、路由基础.三、有名无名分组.四、多app共存的路由分配.五、多app共存时模板冲突问题.六、创建app流程.七、路由分发.八、路由别名,九、名称空间.十、反向解析.十一、2.x新特性.十二、自定义转换器

一.数据库表中字段的增删改查 ''' 直接在modules中对字段进行增删改查 然后在tools下点击Run manage.py Task执行makemigrations和migrate 注意在执行字段的删除过程中需不需要对数据进行备份 ''' 二.路由基础 ''' # url中含有四个参数 # url(regex, view, kwargs=None, name=None) # 正则路径 视图函数地址 默认关键字参数(了解) 路由别名 # r'index' 只要请求中含有index都可以匹配成

Android下数据库操作——增删改查

Android下数据库第一种方式增删改查 1.创建一个帮助类的对象,调用getReadableDatabase方法,返回一个SqliteDatebase对象 2.使用SqliteDatebase对象调用execSql()做增删改,调用rawQuery方法做查询. 特点:增删改没有返回值,不能判断sql语句是否执行成功.sql语句手动写,容易写错 private MySqliteOpenHelper mySqliteOpenHelper;     public InfoDao(Context co

使用C#书写SQLite数据库增删改查语句(以及插入byte[]时遇到的问题总结)

在没有使用SQLite这种轻量级的数据库之前,只使用过Sqlserver2008进行数据的增删改查,公司使用的是大型的ORACLE数据库,还没有真正的会使用它.那时候觉得数据库很庞大,然而遇到SQLite以后,发现有这么个迷你的小数据库,就像女生的包包随身携带的小镜子一样,放在哪里都能使用. 废话少说,SQLite提供了如何连接.关闭等数据库操作,但真正的增.删.改.查等语句同Sqlserver.ORACLE是一样的. 首先,是创建SQLite数据库文件(写了一个方法): Public stat

TP框架中 数据库的增删改查

框架会用到数据库的内容,这一篇就是关于数据库的增删改查. 数据库的操作,无疑就是连接数据库,然后对数据库中的表进行各种查询,然后就是对数据的增删改的操作, 想要操作数据库,第一步必然是要:链接数据库 一.链接数据库 (1)找到模块文件夹中的Conf文件夹,然后进行编写config.php文件 我这里是这样的文件路径 (2)打开这个config.php文件,然后找到父类配置文件convention.php文件,将关于"数据库"的部分复制粘贴到config.php配置文件中(父类的conv

数据库中简单的增删改查(CRUD)

一切都是基于数据,而对数据的管理都离不开数据库.最近学到数据库的简单操作,所以写下这篇文章,总结一下学习到的知识.浅陋之处,多多见谅. 补充一下:一直弄不清SQL Server,Mysql ,以及Oracle的关系.SQL Server是微软的,因为微软系统的市场占有额,所以这款软件在市场上也占用很大份额,而Mysql是一款开源免费的数据库,我们知道关系型数据库最开始是IBM的一个实验室提出的理论,但是当时并没有被IBM公司重视,被Oracle的创始人劳伦斯·埃里森重视,发展壮大起来.但是Ora