当前位置:数据库 > SQLite >>

《一》Android 数据库 SQlite SQLiteOpenHelper

 */
众所周知,数据库是很重要的。市面上的大大小小的软件差不多都要用到数据库。
在Android中数据库为SQlite,因为小巧便捷,占用的空间少,易于操作。使用很受欢迎。
数据库不外乎查询(query)新增(insert)修改(update)删除(delete)。
本例子
1.使用Menu按键来做数据库的查询(query)新增(insert)修改(update)删除(delete)。
2.搭配ListView Widget来触发单击事件和鼠标滚轮事件。
下面就看一下数据库。
首先建一个辅助类MyDataBase继承SQLiteOpenHelpe,必须实现它的onCreate()和 onUpdate()方法;
数据库创建时,会调用onCreate()方法,所以可将要添加的表(table)写在里面。
创建的方法如下所示:
[java]
@Override 
    public void onCreate(SQLiteDatabase db) { 
        // TODO Auto-generated method stub 
        /* 建立表table */ 
        Log.i(TAG, " onCreate() "); 
        String sql = "CREATE TABLE " + TABLE_NAME + " (" + FIELD_id 
                + " INTEGER PRIMARY KEY AUTOINCREMENT," + " " + FIELD_TEXT 
                + " TEXT)"; 
        db.execSQL(sql); 
    } 
当更新数据库时会调用onUpdate()方法。
所以要将更新table的SQL写在里面。
 
[java]
//更新数据库 
    @Override 
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 
        // TODO Auto-generated method stub 
        Log.i(TAG, " onUpgrade() "); 
        //删除表的SQL 
        String sql = "DROP TABLE IF EXITS " + TABLE_NAME; 
        db.execSQL(sql); 
        onCreate(db); 
    } 
2.得到SQLiteDatabasedb对象,
通过db=MyOpenHelper.getReadableDatabase();//得到只读的数据存储对象,如果数据库不存在择创建一个数据库
db= MyOpenHelper.getWritableDatabase();//得到可读可写的数据哭对象。
如果数据库不存在择创建一个数据库
数据库的文件会自行产生在/data/data/package名称/database下在Eclipse来查询数据库是否创建成功。
根据自己的需要选择不同的方法;
到此我们的数据库就创建成功了。
(一)查询:
Cursor  cursor=db.query(table,columns, selection, selectionArgs, groupBy, having,orderBy);
返回的是一个游标对象。
游标的作用是指项数据库的表的行我们可以通过 cursor.moveToNext();或者
Cursor.moveToPosition();来控制游标的位置;
 
字段虽然比较多,但了解数据库的人应该很清楚,
第一个参数是表名table_name
第二个参数是要查询的字段
第三个参数是查询的条件
这里说一下这个查询条件
查询所有的数据:
//asc是升序,desc是降序,默认为asc
mSQLiteDatabase.query(TABLENAME, new String[] { ID, stuName, stuNumber,stuScore }, null, null, null, null, ID+" asc");
查询有条件的数据:
               Cursor cursor = db.query(TABLENAME, new String[] { ID, stuName, stuNumber,stuScore }, " stuName =?",
              new String[] {“zhnagsan”}, null, null, null)
 这样写的话第四个参数就是第三个参数?的替代值。
//Returns A Cursor object, whichis positioned before the first entry
      Cursorcur= mSQLiteDatabase.query(TABLENAME,  new String[] { ID,stuName,stuNumber,stuScore }, stuNumber+"="+number, null, null, null, null);
也可以把第四个参数置空,直接在第三个参数完成数据的查询条件。
两种方法都可以。
在完成游标的生成之后。
如果这个cursor不为空,择我们进行查询的时候要让游标移到第一个数据。
Cursor.moveTofirst();
 因为游标默认的是指向第一行数据的上一行,如果我们不指向第一行就会报错,越界的异常。
(二)增加
[java]
// 增加数据 
    public long addMethod(String str) { 
        /* 将新增的值放入ContentValues */ 
        ContentValues cv = new ContentValues(); 
        cv.put(FIELD_TEXT, str);//键值对 
        long row = db.insert(TABLE_NAME, null, cv); 
        Log.i(TAG, "addMethod row=" + row); 
        return row; 
    } 
 
第一个参数是你想往哪张表中插入数据的表名。
第二个参数是不允许插入一个完全为空的一条记录。
第二个参数是键值对,封装在一个ContentValues对象中。
(三)修改
[java] 
// 修改 
    public void modMethod(int id, String str) { 
        ContentValues values = new ContentValues(); 
        values.put(FIELD_TEXT, str); 
        String[] whereArgs = { Integer.toString(id) }; 
        int rowsaffected = db.update(TABLE_NAME, values, FIELD_id + " = ?", 
                whereArgs);   www.zzzyk.com
        Log.i(TAG, "modMethod() rowsaffected=" + rowsaffected); 
    }<span style="color:black;"> </span> 
参数已经很清楚了。
返回的是受影响的行数,是一行还是2行。
(四)删除
[java] 
// 删除 
    public void deleteMethod(int id) { 
        String[] whereArgs = { Integer.toString(id) }; 
        int rowsaffected = db.delete(TABLE_NAME, FIELD_id + "=?", whereArgs); 
        Log.i(TAG, "deleteMethod() rowsaffected=" + rowsaffected); 
    } 

 
参数已经很清楚了。
返回的是受影响的行数,是一行还是2行。
(五)关闭数据库
[java] 
//关闭数据库 
    @Override 
    public synchronized void close() { 
        // TODO Auto-generated method stub 
        Log.i(TAG, " close() "); 
        db.close(); 
        super.close(); 
    } 
作者:ta893115871

补充:移动开发 , Android ,
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,