作者:石明瑾于 2017年07月06日 发布在分类 / 开发技术 / Android 下,并于 2017年07月06日 编辑
    Android 操作SQLite基本用法

       615

       0


    一.SQLite的介绍
    1.SQLite简介
    SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持 Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,还有ODBC接口,处理速度快。
    2.SQLite的特点:
    • 轻量级
    • 不需要"安装"
    • 单一文件  
    • 跨平台/可移植性
    • 弱类型的字段
    • 开源
    3.SQLite数据类型
    一般数据采用的固定的静态数据类型,而SQLite采用的是动态数据类型,会根据存入值自动判断。SQLite具有以下五种常用的数据类型:
    NULL: 这个值为空值
    VARCHAR(n):长度不固定且其最大长度为 n 的字串,n不能超过 4000。
    CHAR(n):长度固定为n的字串,n不能超过 254。
    INTEGER: 值被标识为整数,依据值的大小可以依次被存储为1,2,3,4,5,6,7,8.
    REAL: 所有值都是浮动的数值,被存储为8字节的IEEE浮动标记序号.
    TEXT: 值为文本字符串,使用数据库编码存储(TUTF-8, UTF-16BE or UTF-16-LE).
    BLOB: 值是BLOB数据块,以输入的数据格式进行存储。如何输入就如何存储,不改  变格式。
    DATA :包含了 年份、月份、日期。
    TIME: 包含了 小时、分钟、秒。
    二.SQLiteDatabase的介绍
    SQLiteDatabase的常用方法 
    方法名称
    方法表示含义
    openOrCreateDatabase(String path,SQLiteDatabase.CursorFactory  factory)
    打开或创建数据库
    insert(String table,String nullColumnHack,ContentValues  values)
    插入一条记录
    delete(String table,String whereClause,String[]  whereArgs)
    删除一条记录
    query(String table,String[] columns,String selection,String[]  selectionArgs,String groupBy,String having,String  orderBy)
    查询一条记录
    update(String table,ContentValues values,String whereClause,String[]  whereArgs)
    修改记录
    execSQL(String sql)
    执行一条SQL语句
    close()
    关闭数据库
    1、打开或者创建数据库
    在Android 中使用SQLiteDatabase的静态方法openOrCreateDatabase(String  path,SQLiteDatabae.CursorFactory  factory)打开或者创建一个数据库。它会自动去检测是否存在这个数据库,如果存在则打开,不存在则创建一个数据库;创建成功则返回一个SQLiteDatabase对象,否则抛出异常FileNotFoundException。
    下面是创建名为“stu.db”数据库的代码:
    openOrCreateDatabase(String  path,SQLiteDatabae.CursorFactory  factory)
    参数1  数据库创建的路径
    参数2  一般设置为null就可以了
    db=SQLiteDatabase.openOrCreateDatabase("/data/data/com.lingdududu.db/databases/stu.db",null); 
    2、创建表
    创建一张表的步骤很简单:
    • 编写创建表的SQL语句
    • 调用SQLiteDatabase的execSQL()方法来执行SQL语句
    下面的代码创建了一张用户表,属性列为:id(主键并且自动增加)、sname(学生姓名)、snumber(学号)
    //创建表SQL语句  
    String stu_table="create table usertable(_id integer primary key autoincrement,sname text,snumber text)";  
    //执行SQL语句  
    db.execSQL(stu_table);   
    3、插入数据
    插入数据有两种方法:
    ①SQLiteDatabase的insert(String table,String nullColumnHack,ContentValues  values)方法,
      参数1  表名称,
      参数2  空列的默认值
      参数3  ContentValues类型的一个封装了列名称和列值的Map;
    ②编写插入数据的SQL语句,直接调用SQLiteDatabase的execSQL()方法来执行
    第一种方法的代码:
    //实例化常量值  
    ContentValues cValue = new ContentValues();  
    //添加用户名  
    cValue.put("sname","xiaoming");  
    //添加密码  
    cValue.put("snumber","01005");  
    //调用insert()方法插入数据  
    db.insert("stu_table",null,cValue);   
    第二种方法的代码:
    //插入数据SQL语句  
    String stu_sql="insert into stu_table(sname,snumber) values('xiaoming','01005')";  
    //执行SQL语句  
    db.execSQL(sql);   
    4、删除数据
    删除数据也有两种方法:
    ①调用SQLiteDatabase的delete(String table,String whereClause,String[]  whereArgs)方法
    参数1  表名称 
    参数2  删除条件
    参数3  删除条件值数组
    ②编写删除SQL语句,调用SQLiteDatabase的execSQL()方法来执行删除。
    第一种方法的代码:
    //删除条件  
    String whereClause = "id=?";  
    //删除条件参数  
    String[] whereArgs = {String.valueOf(2)};  
    //执行删除  
    db.delete("stu_table",whereClause,whereArgs);   
    第二种方法的代码:
    //删除SQL语句  
    String sql = "delete from stu_table where _id = 6";  
    //执行SQL语句  
    db.execSQL(sql);
    5、修改数据
    修改数据有两种方法:
    ①调用SQLiteDatabase的update(String table,ContentValues values,String  whereClause, String[]  whereArgs)方法
    参数1  表名称
    参数2  跟行列ContentValues类型的键值对Key-Value
    参数3  更新条件(where字句)
    参数4  更新条件数组
    ②编写更新的SQL语句,调用SQLiteDatabase的execSQL执行更新。
    第一种方法的代码: 
    //实例化内容值 ContentValues values = new ContentValues();  
    //在values中添加内容  
    values.put("snumber","101003");  
    //修改条件  
    String whereClause = "id=?";  
    //修改添加参数  
    String[] whereArgs={String.valuesOf(1)};  
    //修改  
    db.update("usertable",values,whereClause,whereArgs);   
    第二种方法的代码:
    //修改SQL语句  
    String sql = "update stu_table set snumber = 654321 where id = 1";  
    //执行SQL  
    db.execSQL(sql);   
    6、查询数据
    在Android中查询数据是通过Cursor类来实现的,当我们使用SQLiteDatabase.query()方法时,会得到一个Cursor对象,Cursor指向的就是每一条数据。它提供了很多有关查询的方法,具体方法如下:
    public  Cursor query(String table,String[] columns,String selection,String[]  selectionArgs,String groupBy,String having,String orderBy,String limit);
    各个参数的意义说明:
    参数table:表名称
    参数columns:列名称数组
    参数selection:条件字句,相当于where
    参数selectionArgs:条件字句,参数数组
    参数groupBy:分组列
    参数having:分组条件
    参数orderBy:排序列
    参数limit:分页查询限制
    参数Cursor:返回值,相当于结果集ResultSet
    Cursor是一个游标接口,提供了遍历查询结果的方法,如移动指针方法move(),获得列值方法getString()等.
    Cursor游标常用方法

    方法名称
    方法描述
    getCount()
    获得总的数据项数
    isFirst()
    判断是否第一条记录
    isLast()
    判断是否最后一条记录
    moveToFirst()
    移动到第一条记录
    moveToLast()
    移动到最后一条记录
    move(int offset)
    移动到指定记录
    moveToNext()
    移动到下一条记录
    moveToPrevious()
    移动到上一条记录
    getColumnIndexOrThrow(String  columnName)
    根据列名称获得列索引
    getInt(int columnIndex)
    获得指定列索引的int类型值
    getString(int columnIndex)
    获得指定列缩影的String类型值
    //查询获得游标  
    Cursor cursor = db.query ("usertable",null,null,null,null,null,null);    
    //判断游标是否为空  
    if(cursor.moveToFirst() {  
    //遍历游标  
    for(int i=0;i<cursor.getCount();i++){  
    cursor.move(i);  
    //获得ID  
    int id = cursor.getInt(0);  
    //获得用户名  
    String username=cursor.getString(1);  
    //获得密码  
    String password=cursor.getString(2);  
    //输出用户信息 System.out.println(id+":"+sname+":"+snumber);  
    }  
    }   
    7、删除指定表
    //删除表的SQL语句  
    String sql ="DROP TABLE stu_table";  
    //执行SQL  
    db.execSQL(sql);   
    三. SQLiteOpenHelper
    该类是SQLiteDatabase一个辅助类。这个类主要生成一  个数据库,并对数据库的版本进行管理。当在程序当中调用这个类的方法getWritableDatabase()或者 getReadableDatabase()方法的时候,如果当时没有数据,那么Android系统就会自动生成一个数据库。 SQLiteOpenHelper 是一个抽象类,我们通常需要继承它,并且实现里面的3个函数:
    1.onCreate(SQLiteDatabase)
    在数据库第一次生成的时候会调用这个方法,也就是说,只有在创建数据库的时候才会调用,当然也有一些其它的情况,一般我们在这个方法里边生成数据库表。
    2.  onUpgrade(SQLiteDatabase,int,int) 
    当数据库需要升级的时候,Android系统会主动的调用这个方法。一般我们在这个方法里边删除数据表,并建立新的数据表,当然是否还需要做其他的操作,完全取决于应用的需求。
    3.  onOpen(SQLiteDatabase):
    这是当打开数据库时的回调函数,一般在程序中不是很常使用。


    使用adb命令查看数据库

    1.在命令行窗口输入adb  shell回车,就进入了Linux命令行,现在就可以使用linux的命令了。

    2.ls回车,显示所有的东西,其中有个data。

    3.cd data回车,再ls回车,cd  data回车,ls回车后就会看到很多的com................,那就是系统上的应用程序包名,找到你数据库程序的包名,然后进入。

    4.进去后在查看所有,会看到有databases,进入databases,显示所有就会发现你的数据库名字,这里使用的是"stu_db"。

    5.sqlite3 stu_db回车就进入了你的数据库了,然后“.schema”就会看到该应用程序的所有表及建表语句。

    6.之后就可以使用标准的SQL语句查看刚才生成的数据库及对数据执行增删改查了。
    访问权限

    创建人 石明瑾
    文档编辑权限 创建者私有
    文档阅读权限 来自分类
    分类阅读权限 所有人
    分类编辑权限 所有人
    分类审核权限
    标签

    sqlite
    历史版本

    修改日期 修改人 备注
    2017-07-06 10:55:13[当前版本] 石明瑾 CREAT
    同类知识
    相关知识

    睿恒知识库-V3.2.0