android平台下的SQLite数据库是一种轻量级数据库,支持标准的SQL语句。

本文将介绍

  • android数据库的创建
  • 利用sql语句对数据库增删改查
  • 系统api数据库增删改查
  • 数据库的事务
  • 1,数据库的创建

    步骤:

  • 写一个类继承SQLiteOpenHelper
  • 在构造函数中指定 数据库名称,游标工厂, 版本号
  • 初始化数据库,执行getWritableDatabase或getReadableDatabase, 创建或打开一个数据库.
  • onCreate里执行SQL创建语句

  • android平台下数据库的创建需要一个辅助类继承SQLiteOpenHelper,并且需要重写父类的构造方法。

  • /**
    * 数据库创建辅助类 写一个类继承SQLiteOpenHelper
    *
    * @author wgk
    *
    */
    public class PersonSQLiteOpenHelper extends SQLiteOpenHelper { public PersonSQLiteOpenHelper(Context context) {
    super(context, "PERSON.db", null, 1);//此处是super,直接调用父类的构造方法
    } /**
    *
    * 构造方法,用于创建一个辅助类,用于打开/创建/管理一个数据库
    *
    * @param context
    * 上下文
    * @param name
    * 数据库文件的名字
    * @param factory
    * 游标工厂 Cursor 游标(指针), 本身并不存储数据. 保存数据库的引用.
    * @param version
    * 数据库版本
    */
    public PersonSQLiteOpenHelper(Context context, String name,
    CursorFactory factory, int version) {
    super(context, name, factory, version);
    } @Override
    // 数据库第一次被创建时调用,适合初始化操作
    public void onCreate(SQLiteDatabase db) {
    // 创建表
    db.execSQL("create table person ("
    + " _id integer primary key autoincrement, "
    + " name varchar(20), " + " age integer);");
    } @Override
    // 数据库更新时调用这个方法
    // 用于执行表的更新操作
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    // TODO Auto-generated method stub } }

    这个类仅仅是一个辅助类,若想使用数据库,还需要创建一个数据库访问类PersonDAO。

  • 2,对数据库进行增删改查

  • public class PersonDAO{
    
        private final Context context;
    private PersonSQLiteOpenHelper helper; public PersonDAO(Context context) {
    this.context = context;
    helper = new PersonSQLiteOpenHelper(context);
    } /**
    * @param name
    * @param age
    */
    public void add(String name, int age) {
    SQLiteDatabase db = helper.getWritableDatabase();
    // db.execSQL("insert into person (name,age) values ('"+name+"',"+age+")");
    // 防止SQL注入
    db.execSQL("insert into person (name,values) values(?,?)",
    new Object[] { name, age });
    } /**
    * 根据名字删除一条数据
    *
    * @param name
    */
    public void delete(String name) {
    SQLiteDatabase db = helper.getWritableDatabase();
    db.execSQL("delete from person where name=?", new Object[] { name });
    } //根据名字更新年龄
    public void update(int age, String name) {
    SQLiteDatabase db = helper.getWritableDatabase();
    db.execSQL("update person set age=? where name=?", new Object[] { age,name });
    } public void querySingleRecord(String nameStr) {
    SQLiteDatabase db = helper.getReadableDatabase();
    Cursor cursor = db.rawQuery("select * from person where name=?",new String[] { nameStr }); if (cursor != null && cursor.moveToFirst()) {
    String _id = cursor.getString(0);
    String name = cursor.getString(1);
    String age = cursor.getString(2);
    System.out.println("_id: " + _id);
    System.out.println("name: " + name);
    System.out.println("age: " + age);
    cursor.close();
    }
    } /**
    * 查询所有数据
    */
    public void queryAll() {
    SQLiteDatabase db = helper.getReadableDatabase();
    Cursor cursor = db.rawQuery("select * form person", null); if (cursor != null && cursor.getCount() > 0) {
    while (cursor.moveToNext()) {
    int _id = cursor.getInt(cursor.getColumnIndex("_id"));
    String name = cursor.getString(cursor.getColumnIndex("name"));
    int age = cursor.getInt(cursor.getColumnIndex("age"));
    System.out.println("_id: " + _id);
    System.out.println("name: " + name);
    System.out.println("age: " + age);
    System.out.println("-----------------");
    }
    cursor.close();
    }
    } }
  • 注意:在获得数据库辅助类对象时,此时并未创建数据库,只有在辅助类对象调用getxxxxDatabase方法(创建可读或者可写的数据库)时,才创建数据库。

  • //此时并未创建数据可
    PersonSQLiteOpenHelper helper = new PersonSQLiteOpenHelper(getContext());
    // 获取一个可读/可写的数据库, 真正创建了数据库
    helper.getWritableDatabase();
     

    3,使用goole的api操作数据库

  • 除了使用SQL语句来进行增删改查,还可以使用google提供的api。

    //主要语句
    // 增
    db.insert("person", "name", values); // 删
    db.delete("person", "name=?", new String[]{name}); // 改
    db.update("person", values, "name=?", new String[]{name}); //查
    Cursor cursor = db.query("person", // 表名
    null, // 要查询列名 new String[]{name,age}
    "name = ?", // 查询条件
    new String[]{nameStr},// 条件参数
    null, // 分组
    null, // 分组
    null); // 排序

    使用google的api对PersonDAO进行修改,如下

    /**
    * 使用google提供的api来操作数据库
    *
    * 数据库访问对象
    * @author wgk
    *
    */
    public class PersonDAO3 { private final Context context;
    private PersonSQLiteOpenHelper helper;
    public PersonDAO3(Context context){
    this.context=context;
    helper=new PersonSQLiteOpenHelper(context);
    }
    /**
    * 增加一条数据
    * @param name
    * @param age
    */
    public void add(String name,int age){
    SQLiteDatabase db=helper.getWritableDatabase();
    ContentValues values=new ContentValues();
    values.put("name", name);
    values.put("age", age); //若需要插入一条空的数据,需要指定任意一个列的名称,以避免异常
    String nullColumnHack="null";
    long insert=db.insert("person", nullColumnHack, values);
    System.out.println(insert);
    }
    /**
    * 删除一条数据根据名字
    * @param name
    */
    public void delete(String name){
    SQLiteDatabase db=helper.getWritableDatabase();
    int delete=db.delete("person", "name=?", new String[]{name});
    System.out.println(delete);
    }
    /**
    * 更新年龄!根据名字
    * @param age
    * @param name
    */
    public void update(int age,String name){
    SQLiteDatabase db=helper.getWritableDatabase();
    ContentValues values=new ContentValues();
    values.put("age", age);
    int update =db.update("person", values, "name=?", new String[]{name});
    System.out.println(update);
    } /**
    * 查!根据一个人的名字
    * @param name
    */
    public void querySingleRecord(String nameStr){
    SQLiteDatabase db=helper.getReadableDatabase();
    Cursor cursor=db.query("person",
    null,//列名
    "name=?",//查询条件
    new String[]{nameStr},//查询参数
    null, //分组
    null,//分组
    null);//排序
    if(cursor!=null&&cursor.moveToFirst()){
    String _id=cursor.getString(0);
    String name=cursor.getString(1);
    String age=cursor.getString(2);
    System.out.println("_id: " + _id);
    System.out.println("name: " + name);
    System.out.println("age: " + age); //关闭cursor
    //关闭cursor
    //关闭cursor
    cursor.close();
    } }
    /**
    * 查询所有数据
    */
    public void queryAll(){
    SQLiteDatabase db=helper.getReadableDatabase();
    Cursor cursor=db.query("person",
    null,
    null,
    null,
    null,
    null,
    "_id DESC");//排序
    if(cursor!=null&&cursor.getCount()>0){
    while(cursor.moveToNext()){
    int _id=cursor.getInt(cursor.getColumnIndex("_id"));
    String name=cursor.getString(cursor.getColumnIndex("name"));
    int age=cursor.getInt(cursor.getColumnIndex("age")); System.out.println("_id: " + _id);
    System.out.println("name: " + name);
    System.out.println("age: " + age);
                  }
    //关闭cursor
    //关闭cursor
    //关闭cursor
    cursor.close();
    }
    }
    }

    两种方式的比较

    1.利用SQL语句进行增删改查
    优点:灵活, 根据需要进行表的级联查询.

    缺点:容易出错. 没有返回值

    2.利用系统API增删改查

    优点:不容易出错. 有返回值

    缺点:不灵活, 效率稍低, 拼接sql语句耗时

    -------------------------------------------------我是分割线-------------------------------------------------

    数据库的事务(Transaction)

    1. (安全性)银行转账:

      • 转出,laowang 账户10000 -> 转出1000 ->
      • 转入,xiaosan 账户 0 收到1000
    2. (高效性)数据的插入:

      • 提高数据库操作效率, 大约提升6倍速度
      • 打开一次数据,

    以laowang给xiaosan转账1000的例子写一段demo如下

    public class TransactionDemo extends AndroidTestCase{
    
        public void transactionDemo(){
    
            PersonSQLiteOpenHelper helper= new PersonSQLiteOpenHelper(getContext());
    //此时才真正创建数据库
    SQLiteDatabase db=helper.getWritableDatabase();
    try{
    //开始事务
    db.beginTransaction(); //转出1000
    db.execSQL("update person set money=money-1000 where name=?", new Object[]{"laowang"}); //在执行至回滚点之前,并不会对数据库进行真的操作,一切都在内存中进行,只有执行到回滚点之后,才会影响到数据库
    //int i =1/0;
    //转入1000
    db.execSQL("update person set money=money+1000 where name=?", new Object[]{"xiaosan"});
    //设置回滚点
    db.setTransactionSuccessful();
    }catch (Exception e){
    e.printStackTrace();
    }finally{
    db.endTransaction(); }
    }

    总结:

    -------------------------------------------------基础要像磐石!!!

android-数据库SQLite相关的更多相关文章

  1. android数据库SQLite的设计模式

    Dao设计模式可能是使用最多的数据库的设计模式其基本思路是将数据库操作的代码 与设计代码分离以便于维护和升级.具体的实现方法是使用包,然后在设计代码中调 用数据库的操作代码,dao设计模式需要创建5个 ...

  2. Android 数据库SQLite 写入SD卡

    如果手机没有root,数据库文件是无法查看到的,不方便调试. 最好的办法是把数据库写进SD卡. 修改的地方有两处: 1.在你的helper类中把数据库文件名称 DATABASE_NAME 由原来的一个 ...

  3. Android数据库(sqlite)加密方案

    最近因为一些项目的安全性需要将数据库加密,一开始想到的就是先将数据库通过AES加密,然后运行时再解密,另一种是将数据库里的内容加密. 很快这两种方案都是不理想的,第一种加密方式形同虚设,第二种,如果加 ...

  4. android数据库sqlite增加删改查

    http://hi-beijing.iteye.com/blog/1322040 http://www.cnblogs.com/wenjiang/archive/2013/05/28/3100860. ...

  5. Android下的SQLite数据库的相关操作及AndroidTestCase测试

    一:创建数据库 package com.itcode.mysqlite; import android.content.Context; import android.database.sqlite. ...

  6. Android中SQLite数据库小计

    2016-03-16 Android数据库支持 本文节选并翻译<Enterprise Android - Programing Android Database Applications for ...

  7. Android数据库高手秘籍(一)——SQLite命令

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/38461239 要想熟练地操作不论什么一个数据库.最最主要的要求就是要懂SQL语言, ...

  8. Android数据库框架——GreenDao轻量级的对象关系映射框架,永久告别sqlite

    Android数据库框架--GreenDao轻量级的对象关系映射框架,永久告别sqlite 前不久,我在写了ORMLite这个框架的博文 Android数据库框架--ORMLite轻量级的对象关系映射 ...

  9. Android:自定义Sqlite数据库路径

    默认的sqlite数据库是放在/data/data/database目录下的,今天看腾讯云IM的demo发现再该路径下找不到它存放消息的数据库,找了下后发现居然是放在/data/data/files目 ...

  10. Android数据库(1)、SQLite数据库介绍

    一.关系性数据库   关系型数据库主要有以下三个特征,尤为明显,如果没有这个三个特征约束,当多个客户端使用数据的时候就会出现各种各样的错误,所以关系型数据库定义这些约束,让客户端程序只要遵守这个规则便 ...

随机推荐

  1. Codeforces 538 B. Quasi Binary

    B. Quasi Binary   time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...

  2. POJ 3087 Shuffle'm Up【模拟/map/string】

    Shuffle'm Up Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14471 Accepted: 6633 Descrip ...

  3. 洛谷——P1009 阶乘之和

    P1009 阶乘之和 题目描述 用高精度计算出S=1!+2!+3!+…+n!(n≤50) 其中“!”表示阶乘,例如:5!=5*4*3*2*1. 输入输出格式 输入格式: 一个正整数N. 输出格式: 一 ...

  4. 13、Flask实战第13天:SQLAlchemy操作MySQL数据库

    安装MySQL 在MySQL官网下载win版MySQL 双击运行 后面根据提示设置密码然后启动即可,这里我设置的密码是:123456 我们可以通过Navicat客户端工具连接上MySQL addres ...

  5. Gitlab运维

    安装Gitlab 新建 /etc/yum.repos.d/gitlab-ce.repo [gitlab-ce] name=gitlab-ce baseurl=http://mirrors.tuna.t ...

  6. 【哈希表】CODEVS1230 元素查找

    #include<cstdio> #include<vector> using namespace std; typedef vector<int>::iterat ...

  7. 【前缀和】【前缀MAX】洛谷 P1351 NOIP2014提高组 day1 T2 联合权值

    不难发现,树中与某个点距离为2的点只可能是它的父亲的父亲.儿子的儿子 或者 兄弟,分类讨论一下即可. 只有对于兄弟我们不能暴力搞,维护一下每个节点的所有儿子的前缀和.前缀MAX就行了. #includ ...

  8. [美团 CodeM 初赛 Round A]最长树链

    题目大意: 给你一棵带点权的树,找出一个最长的树链满足链上点权的最大公因数不为1. 思路: 暴力DP. 对于每个点,记录一下以这个点为一个端点的所有链的最大公因数及长度. 然后暴力转移一下,时间复杂度 ...

  9. 求满足n^2>12000的n的最大值 Exercise05_13

    /** * @author 冰樱梦 * 时间:2018年下半年 * 题目:求满足n^2>12000的n的最大值 * */ public class Exercise05_13 { public ...

  10. iOS开发中几种常见的存储方式

    1.archive 归档 数据的保存 1: let result = NSKeyedArchiver.archiveRootObject(contacts, toFile: path as Strin ...