天天看点

SQLLite常用代码

SQLiteOpenHelper是一个抽象类,用户需要继承这个类,并实现该类中的一些方法。

1、继承SQLiteOpenHelper之后就拥有了以下两个方法:

◆getReadableDatabase() 创建或者打开一个查询数据库

◆getWritableDatabase()创建或者打开一个可写数据库

◆他们都会返回SQLiteDatabase对象,用户通过得到的SQLiteDatabase对象进行后续操作

2、同时用户还可以覆盖以下回调函数,再对数据库进行操作的时候回调以下方法:

◆onCreate(SQLiteDatabase):在数据库第一次创建的时候会调用这个方法,一般我们在这个方法里边创建数据库表。

◆onUpgrade(SQLiteDatabase,int,int):当数据库需要修改的时候,Android系统会主动的调用这个方法。一般我们在这个方法里边删除数据库表,并建立新的数据库表,当然是否还需要做其他的操作,完全取决于应用程序的需求。

◆onOpen(SQLiteDatabase):这是当打开数据库时的回调函数,一般也不会用到。  

创建DatebaseHelper对象:

public DatabaseHelper(Context context, String name, CursorFactory factory,  

   int version) {  

  //必须通过super调用父类当中的构造函数  

  super(context, name, factory, version);  } 

第一个参数为该类本身;第二个参数为数据库的名字;第3个参数是用来设置游标对象的,这里一般设置为null;参数四是数据库的版本号。

public void execSQL (String sql)

  该函数是类SQLiteDatabase中的一个函数,其功能是执行一条SQL语句命令,这条语句的内容就是该函数的参数。因此参数sql需要符合SQL语法规则。

public ContentValues ()

  ContentValues是用于数据库中存放数据的类,也是采用的键值对来存放数据的,有点类似content和bundle等。该构造函数是建立一个默认大小的空的数据集。

创建并得到对象:

DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db",2);       

SQLiteDatabase db = dbHelper.getReadableDatabase();   //getWritableDatabase()

从应用界面直接获取对象:

Context.createDatabase(String name,int version ,int mode,CursorFactory factory)

例子:SQLiteDatabase DataBase=this.openOrCreateDatabase("DataBase.db",  MODE_PRIVATE,

new CursorFactory(){   

//创建新的数据库,名称Database,模式MODE_PRIVATE   

public Cursor newCursor(SQLiteDatabase db,SQLiteCursorDriver masterQuery,String editTable,SQLiteQuery query){return null;}}); 

打开数据库:

Context.openDatabase(String file,CursorFactory factory); 

关闭数据库:

DataBase.close();   

//千万不要忘记关闭数据库哦  

数据库删除:

this.deleteDatabase("Database.db");  

插入数据:

ContentValues values = new ContentValues();

            //想该对象当中插入键值对,其中键是列名,值是希望插入到这一列的值,值必须和数据库当中的数据类型一致        

            values.put("id", 1);

            values.put("name","zhangsan"); 

            DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db",2);

            SQLiteDatabase db = dbHelper.getWritableDatabase();       

          db.insert("user", null, values);  //调用insert方法,就可以将数据插入到数据库当中       

数据库查询:

DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db");     

SQLiteDatabase db = dbHelper.getReadableDatabase();

Cursor cursor = db.query("user", new String[]{"id","name"}, "id=?", new String[]{"1"}, null, null, null);     

while(cursor.moveToNext()){       

                String name = cursor.getString(cursor.getColumnIndex("name"));        

                System.out.println("query--->" + name); 

}

数据库的更新:

//得到一个可写的SQLiteDatabase对象     

            DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db");

            SQLiteDatabase db = dbHelper.getWritableDatabase();       

            ContentValues values = new ContentValues();       

            values.put("name", "zhangsanfeng");            //第一个参数是要更新的表名        //第二个参数是一个ContentValeus对象      //第三个参数是where子句       

            db.update("user", values, "id=?", new String[]{"1"});