• (转)Android学习笔记---SQLite介绍,以及使用Sqlite,进行数据库的创建,完成数据添删改查的理解


    原文:http://blog.csdn.net/lidew521/article/details/8655229

    1.SQLite介绍:最大特点是,无数据类型;
    除了可以使用文件或SharedPreferences存储数据,还可以选择使用SQLite数据库存储数据。
    在Android平台上,集成了一个嵌入式关系型数据库—SQLite,SQLite3支持
    NULL、INTEGER


    、REAL(浮点数字)、TEXT(字符串文本)和BLOB(二进制对象)数据类型,虽然它支持的类型


    只有五种,但实际上sqlite3也接受varchar(n)、char(n)、decimal(p,s)
    等数据类型,只不


    过在运算或保存时会转成对应的五种数据类型。
    SQLite最大的特点是你可以把各种类型的数


    据保存到任何字段中,而不用关心字段声明的数据类型是什么。例如:可以在Integer类型的


    字段中存放字符串,或者在布尔型字段中存放浮点数,或者在字符型字段中存放日期型值。 


    但有一种情况例外:定义为INTEGER
    PRIMARY KEY的字段只能存储64位整数, 当向这种字段


    保存除整数以外的数据时,将会产生错误。 另外, SQLite
    在解析CREATE TABLE 语句时,


    会忽略 CREATE TABLE 语句中跟在字段名后面的数据类型信息,如下面语句会忽略
    name字段


    的类型信息:
    CREATE TABLE person (personid integer primary key
    autoincrement, name
    varchar


    (20))
    SQLite可以解析大部分标准SQL语句,如:
    查询语句:select * from 表名
    where 条件子句 group by 分组字句 having ... order by 


    排序子句
    如:select * from
    person
            select * from person order by id desc
            select name
    from person group by name having
    count(*)>1
    ---------------------------------------------------------------------------
    2.a.分页SQL与mysql类似,下面SQL语句获取5条记录,跳过前面3条记录
     
      select * from Account limit 5 offset 3 或者 select * from Account limit 3,5
     
    b.select * from Account limit 3,5,指的是跳过前面的3条记录,然后获取5条记录
      c.select * from
    Account limit 3,5是select * from Account limit 5 offset 3语句
       
    的简写版
    ------------------------------------------------------------------------------- 
    3.常用操作:
    a.插入语句:insert
    into 表名(字段列表) values(值列表)。如: insert into person   


    (name, age)
    values(‘传智’,3)
    b.更新语句:update 表名 set 字段名=值 where 条件子句。如:update person set
    name= 


     'credream‘ where id=10
    c.删除语句:delete from 表名 where
    条件子句。如:delete from person  where
    id=10
    -------------------------------------------------------------------------------
    2.虽然无数据类型,但是建议加上,这样可以增加可读性,支持标准sql,oracle中的不行
    ---------------------------------------------------
    3.获取添加记录后的自增长的ID值:select
    last_insert_rowid();
    -----------------------------------------------------------
    4.在android中开发数据库应用:
     
    a.创建数据库:以前在javaee时候,需要手工数据,但是android应用,需要运行在用户的
       
    手机上,所以,android应用,要有自动创建数据库功能,当第一次使用软件的时候
       
    就创建数据库
    ----------------------------------------
    5.关于数据库自动创建的详细介绍:
    我们在编写数据库应用软件时,需要考虑这样的问题:因为我们开发的软件可能会安装在很


    多用户的手机上,如果应用使用到了SQLite数据库,我们必须在用户初次使用软件时创建出


    应用使用到的数据库表结构及添加一些初始化记录,另外在软件升级的时候,也需要对数据


    表结构进行更新。那么,我们如何才能实现在用户初次使用或升级软件时自动在用户的手机


    上创建出应用需要的数据库表呢?总不能让我们在每个需要安装此软件的手机上通过手工方


    式创建数据库表吧?因为这种需求是每个数据库应用都要面临的,所以在Android系统,为我


    们提供了一个名为SQLiteOpenHelper的抽象类,必须继承它才能使用,它是通过对数据库版


    本进行管理来实现前面提出的需求。 
    -----------------------------------------
    6.SQLite数据库添加,删除,改查操作
     
    A.创建数据库:SQLiteOpenHelper .getWritableDatabase()或getReadableDatabase()
       
    可以创建数据库
    7.创建完成以后可以使用SQLITE Expert软件打开生成的数据库
     
    可以看到除了生成的自己的需要的表之外,还生成了一张:android_metadata表:
     
    如果在sqlite中使用数据库一定会有一张android_metadata表,用来登记用户的
     
    使用语言:zh_cn
    -----------------------------------------------------
     
    b.数据库自动创建的过程及方法详细介绍:
     
     我们在编写数据库应用软件时,需要考虑这样的问题:因为我们开发的软件可能会安装在


    很多用户的手机上,如果应用使用到了SQLite数据库,我们必须在用户初次使用软件时创建


    出应用使用到的数据库表结构及添加一些初始化记录,另外在软件升级的时候,也需要对数


    据表结构进行更新。那么,我们如何才能实现在用户初次使用或升级软件时自动在用户的手


    机上创建出应用需要的数据库表呢?总不能让我们在每个需要安装此软件的手机上通过手工


    方式创建数据库表吧?因为这种需求是每个数据库应用都要面临的,所以在Android系统,为


    我们提供了一个名为SQLiteOpenHelper的抽象类,必须继承它才能使用,它是通过对数据库


    版本进行管理来实现前面提出的需求。 
    -------------------------------------------
    8.详细介绍:
    为了实现对数据库版本进行管理,SQLiteOpenHelper类提供了两个重要的方法,分别是


    onCreate(SQLiteDatabase
    db)和onUpgrade(SQLiteDatabase db, int oldVersion,
    int 


    newVersion),前者用于初次使用软件时生成数据库表,后者用于升级软件时更新数据库表结


    构。当调用SQLiteOpenHelper的getWritableDatabase()或者getReadableDatabase()方法获


    取用于操作数据库的SQLiteDatabase实例的时候,如果数据库不存在,Android系统会自动生


    成一个数据库,接着调用onCreate()方法,onCreate()方法在初次生成数据库时才会被调用


    ,在onCreate()方法里可以生成数据库表结构及添加一些应用使用到的初始化数据。


    onUpgrade()方法在数据库的版本发生变化时会被调用,一般在软件升级时才需改变版本号,


    而数据库的版本是由程序员控制的,假设数据库现在的版本是1,由于业务的变更,修改了数


    据库表结构,这时候就需要升级软件,升级软件时希望更新用户手机里的数据库表结构,为


    了实现这一目的,可以把原来的数据库版本设置为2(有同学问设置为3行不行?当然可以,如


    果你愿意,设置为100也行),并且在onUpgrade()方法里面实现表结构的更新。当软件的版本


    升级次数比较多,这时在onUpgrade()方法里面可以根据原版号和目标版本号进行判断,然后


    作出相应的表结构及数据更新。
    getWritableDatabase()和getReadableDatabase()方法都可以获取一个用于操作数据库的


    SQLiteDatabase实例。但getWritableDatabase()
    方法以读写方式打开数据库,一旦数据库


    的磁盘空间满了,数据库就只能读而不能写,倘若使用的是getWritableDatabase()
    方法就


    会出错。getReadableDatabase()方法先以读写方式打开数据库,如果数据库的磁盘空间满了


    ,就会打开失败,当打开失败后会继续尝试以只读方式打开数据库。
    ------------------------------------------------------------------------
    9.创建数据库的代码:
     
    a.创建项目:DBSQLIte
      b./DBSQLIte/src/com/credream/service/DBOpenHelter.java
     
      package com.credream.service;


    import
    android.content.Context;
    import
    android.database.sqlite.SQLiteDatabase;
    import
    android.database.sqlite.SQLiteOpenHelper;
    import
    android.database.sqlite.SQLiteDatabase.CursorFactory;


    public class
    DBOpenHelter extends SQLiteOpenHelper
    {
    //父类没有默认构造器,需要显示调用
    public
    DBOpenHelter(Context context)
    {
    super(context,
    "credream.db", null,
    1);
    //数据库创建完成后,默认会保存在<包>/database/文件夹下
    //当修改版本号时候,会触发:onUpgrade方法
    //第二个:指定数据库名称,
    //第三个:游标工厂,用来迭代,查询后的结果集,null代表使用系统默认的


    游标工厂
    //版本号,大于0
     
    }
    /**
     *
    这个方法是在数据库第一次被创建的时候调用的
     */
    @Override
    public
    void onCreate(SQLiteDatabase db)
    {
    //SQLiteDatabase这个类,封装了增删改查操作,也叫做数据库操作实例
    db.execSQL("CREATE
    TABLE person (personid integer primary key 


    autoincrement, name
    varchar(20))");
    //这里也可以不写name的数据类型,因为sqlite是数据类型无关的,就是写


    了varchar(20),也可以写入超过20的内容

     
    }
    /**
     *
    当数据库的版本号变更的时候被调用
     */
    @Override
    public
    void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
    {
    db.execSQL("alter
    table person add phone varchar(12) null");


    }


    }
    --------------------------------------------------------
    2.在清单文件中写入测试环境
     
        <uses-library android:name="android.test.runner" />
               
    </application>
     <instrumentation
    android:name="android.test.InstrumentationTestRunner"
     
    android:targetPackage="com.credream.db" android:label="Tests for My App"
    />
    ----------------------------------------------------
    3./DBSQLIte/src/com/credream/test/PersonServiceTest.java
    package
    com.credream.test;


    import
    com.credream.service.DBOpenHelter;


    import
    android.test.AndroidTestCase;


    public class PersonServiceTest extends
    AndroidTestCase
    {
    //创建数据库,在<包>/database/
    public
    void testCreateDB(){
    DBOpenHelter
    dbOpenHelter=new DBOpenHelter(getContext());
    dbOpenHelter.getWritableDatabase();
    }


    }
    -------------------------------------------------------
    4.选择方法开始测试,然后,在data/data/<包>/database/下
     
    查看并用sqlite打开生成的数据库检查是否正确
    ---------------------------------------------
    然后将版本号,改成2,然后再次执行,看到,表已经被更新,增加了一列phone
    -----------------------------------------------
    5.了解sqlite工作的原理:
     
    DBOpenHelter dbOpenHelter=new DBOpenHelter(getContext());
    dbOpenHelter.getWritableDatabase();
     
    打开getWritableDatabase();代码:

  • 相关阅读:
    作业3——turtle
    作业2——Python基础
    作业——理解管理信息系统
    测试用例挑选策略
    UVALive 5903 Piece it together(二分图匹配)
    UVALive 4953 Wormly--【提醒自己看题要仔细】
    HDU 3111 Sudoku(精确覆盖)
    FZU 2165 v11(最小重复覆盖)+ codeforces 417D Cunning Gena
    UVALive 6577 Binary Tree 二叉树的LRU串
    codeforces 425C Sereja and Two Sequences(DP)
  • 原文地址:https://www.cnblogs.com/allearner/p/3677288.html
Copyright © 2020-2023  润新知