记一次对sqlite数据库的学习

来源:互联网 发布:淘宝教育上直通车 编辑:程序博客网 时间:2024/05/23 01:05

1.使用SqliteOpenHelper类

   构造方法

public DBOpenHandler(Context context, String name, SQLiteDatabase.CursorFactory factory,                     int version) {    super(context, name, factory, version);    // TODO Auto-generated constructor stub}
        // SQLiteOpenHelper的构造函数参数:        // context:上下文环境        // name:数据库名字        // factory:游标工厂(可选)        // version:数据库模型版本号

   重写onCreate

   使用到新建数据库表。

重写onUpgrade

方法在数据库的版本发生变化时会被调用,一般在软件升级时才需改变版本号,而数据库的版本是由程序员控制的。

  假设数据库现在的版本是1,由于业务的变更,修改了数据库表结构,这时候就需要升级软件,升级软件时希望更新用户手机里的数据库表结构,为了实现这一目的,可以把原来的数据库版本设置为2,并且在onUpgrade()方法里面实现表结构的更新。

package com.example.admin.ddplayv11.obj;/* * Created by p4d on 2016/12/13. */import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteOpenHelper;public class DBOpenHandler extends SQLiteOpenHelper{    public DBOpenHandler(Context context, String name, SQLiteDatabase.CursorFactory factory,                         int version) {        super(context, name, factory, version);        // TODO Auto-generated constructor stub    }    @Override    public void onCreate(SQLiteDatabase db) {        // TODO Auto-generated method stub        db.execSQL("CREATE TABLE  t_users1  ( id   INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,  " +                "username   TEXT UNIQUE NOT NULL," +                " password   TEXT NOT NULL, " +                "phone    TEXT, " +                "email   TEXT," +                " money   INTEGER NOT NULL," +                " time   INTEGER NOT NULL)");        db.execSQL("CREATE TABLE t_order ( id   INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,"+                "content  TEXT NOT NULL,"+                "senderid TEXT NOT NULL," +                "receiverid TEXT,"+                "money  INTEGER NOT NULL,"+                "time  INTEGER NOT NULL)");    }    @Override    public void onUpgrade(SQLiteDatabase db, int arg1, int arg2) {        // TODO Auto-generated method stub    }}
2.SqliteDatabase类

   SQLiteOpenHelper 类中的 getWritableDatabase()getReadableDatabase()方法返回这个类的对象

  

  SQLiteDatabase的学习,应该重点掌握execSQL()和rawQuery()方法。

  execSQL()方法可以执行insert、delete、update和CREATE TABLE之类有更改行为的SQL语句;

  rawQuery()方法用于执行select语句。

0 0
原创粉丝点击