Android下数据库的使用

来源:互联网 发布:用java编写一个计算器 编辑:程序博客网 时间:2024/05/19 14:02

SQLiteOpenHelper 

根据开发应用程序的需要,内部封装了创建和更新数据库使用的逻辑

使用SQLiteOpenHelper首先要创建一个类,该类继承自android.database.sqlite.SQLiteOpenHelper

而SQLiteDatabase.java中,构造函数是私有的,需要指定构造方法,接收参数为:

通过构造函数选择父类 SQLiteOpenHelper 的构造函数:

public myOpenHelper(Context context,String name,CursorFactory factory,int version) {
//context 上下文
//name 数据库的名称,"person.db"(文件数据库),如果是空则创建内存数据库
//factory 数据库查询结果的游标工厂,一般为null
//version 数据库的版本 >=1
super(context, "person.db", null, 4);

由于这个是抽象类, 因此你需要实现该类的两个方法

一个是

onCreate(SQLiteDatabase db),(数据库第一次创建的时候调用的方法,适合做数据库表结构的初始化)

db.execSQL("create table person (id integer primary key autoincrement , name varchar(20), phone varchar(20))");//用传进来的db例创建一个数据库

一个是

onUpgrage();

创建数据库

在测试类中使用上下文,getContext()  获取的是一个模拟的方便测试的上下文,用于提供数据库的路径等信息

1,在activity中创建myOpenHelper实例: myOpenHelper helper = new myOpenHelper(this);

在调用helper.getWriteableDatabase();时如果数据库中没有表,则会创建一个数据库表结构。

getWriteableDatabase();该方法会调用SQLiteOpenHelper类中的

<span style="font-size:14px;">getWritableDatabase()<span style="font-family: 'Microsoft YaHei', 'Segoe UI', Tahoma, Arial, Helvetica, sans-serif;">方法</span></span>

<span style="font-size:14px;"> public SQLiteDatabase getWritableDatabase() {        synchronized (this) {            return getDatabaseLocked(true);        }    }</span>
getDatabaseLocked(true);方法中会判断数据库是否已经创建过,执行创建或是返回等操作

关于数据库中存放的类型

SQLite,SQLite3支持 NULL、INTEGER、REAL(浮点数字)、TEXT(字符串文本)和BLOB(二进制对象)数据类型,虽然它支持的类型只有五种,但实际上sqlite3也接受varchar(n)、char(n)、decimal(p,s) 等数据类型,只不过在运算或保存时会转成对应的五种数据类型。 SQLite最大的特点是你可以把各种类型的数据保存到任何字段中,而不用关心字段声明的数据类型是什么。

数据库的操作

语句:

查询语句:   select * from person where name = 'zhangsan'

插入语句:insertinto 表名(字段列表)values(值列表)。如:insert into person(name, age) values(‘lisi’,3)

更新语句:update表名set字段名=值where条件子句。如:update person set name='zhangsan' where id=10

删除语句:deletefrom 表名where条件子句。如:delete from person  where id=10

代码包装数据库语句

创建一个类 persondao.java

数据库增删改查方法1:

<span style="font-size:14px;">public class PersonDao {private PersonDBOpenHelper helper;public PersonDao(Context context) { 创建对象,传递上下文,得到PersonDBOpenHelper对象</span>helper = new PersonDBOpenHelper(context);在构造函数中创建对象} * 添加一条记录public void add(String name,String phone){SQLiteDatabase  db = helper.getWritableDatabase();db.execSQL("insert into person (name,phone) values (?,?)", new Object[]{name,phone});db.close();//最好记得关闭数据库, 避免如果有过的打开的连接 导致数据库以后无法访问.} * 查询一条记录public boolean find(String name){SQLiteDatabase db = helper.getReadableDatabase(); Cursor cursor = db.rawQuery("select * from  person where name=?", new String[]{name});boolean result = cursor.moveToFirst();//如果可以移动则返回turecursor.close();db.close();return result;} * @param 姓名根据姓名修改 * @param newphone  新的电话号码public void update(String name,String newphone){SQLiteDatabase  db = helper.getWritableDatabase();db.execSQL("update person set phone=? where name=?", new Object[]{newphone , name});db.close();} * 删除记录public void delete(String name){SQLiteDatabase  db = helper.getWritableDatabase();db.execSQL("delete from person where name=?", new Object[]{ name});db.close();}}</span>


方法处理完毕,则可以在activity中创建对象,调用方法

personDao dao = new personDao(this);dao.add("zhangsan","123456");dao.update("zhangsan","110");


数据库增删改查2(API):注释的为第一种方法

此方法能显示增删改查的结果

<span style="font-size:14px;">public class PersonDao2 {private PersonDBOpenHelper helper;public PersonDao2(Context context) {helper = new PersonDBOpenHelper(context);}public boolean add(String name, String phone) {SQLiteDatabase db = helper.getWritableDatabase();// db.execSQL("insert into person (name,phone) values (?,?)", new// Object[]{name,phone});ContentValues values = new ContentValues();//内部是一个map集合values.put("name", name);values.put("phone", phone);long id = db.insert("person", null, values);//返回一个被影响的行的id,如果失败则返回-1db.close();return id != -1;}public boolean find(String name) {SQLiteDatabase db = helper.getReadableDatabase();/* * Cursor cursor = db.rawQuery("select * from peron where name =?", new * String[]{name}); */Cursor cursor = db.query("person", null(返回哪几列), "name=?",new String[] { name }, null, null, null);boolean result = cursor.moveToFirst();cursor.close();db.close();return result;}/** * 获取全部的person信息 * @return */public List<Person> findAll(){//返回list集合,集合中装person对象,需要创建SQLiteDatabase db = helper.getReadableDatabase();Cursor cursor = db.query("person", null(返回全部), null, null, null, null, null);List<Person> persons = new ArrayList<Person>();while(cursor.moveToNext()){//遍历结果集int id = cursor.getInt(cursor.getColumnIndex("id")<span style="font-family: 'Microsoft YaHei', 'Segoe UI', Tahoma, Arial, Helvetica, sans-serif;">(根据id得到例)</span>);String name = cursor.getString(cursor.getColumnIndex("name")(根据name得例));String phone = cursor.getString(cursor.getColumnIndex("phone"));long account = cursor.getLong(cursor.getColumnIndex("account"));Person person = new Person(name, phone, id);person.setAccount(account);persons.add(person);}cursor.close();db.close();return persons;}public boolean update(String name, String newphone) {SQLiteDatabase db = helper.getReadableDatabase();// db.execSQL("update person set phone=? where name=?", new// Object[]{newphone,name});ContentValues values = new ContentValues();values.put("phone", newphone);int result = db.update("person", values, "name=?",//返回的int为影响了多少行new String[] { name });db.close();return result>0;}public boolean delete(String name) {SQLiteDatabase  db = helper.getWritableDatabase();//db.execSQL("delete from person where name=?", new Object[]{ name});int result = db.delete("person", "name=?", new String[]{name});//int值为影响了多少行db.close();return result>0;}}</span>
推荐使用第二种方法,稳定性高

往数据库中添加一列:名为account的列,将版本更新就能调用onupgrade方法

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {//程序的2.0的版本也要发布了. 2.0的版本 增加一个新的表  db.execSQL("alter table person add account varchar(20)");}


数据库的事物:如转账,需要金额减少的一方和金额增加的一方都执行,增加数据库的事物

db.beginTransaction();// 开始数据库的事务try {db.execSQL("update person set account = account-100 where name='zhangsan'");// s.equals("haha");db.execSQL("update person set account = account+100 where name='zhangsan0'");db.setTransactionSuccessful(); // 如果没有标记数据库事务成功 //数据会回滚} finally {db.endTransaction(); // 检查是否设置了事务成功的flag}db.close();










0 0
原创粉丝点击