使用特定方法操作SQLite資料庫

來源:互聯網
上載者:User

如果開發人員對於SQL文法不熟悉,Android的SQLiteDatabase提供了增、刪、改、查語句來操作資料庫,雖然Android提供了這些所謂的“便捷”方法操作資料庫,但筆者認為這些方法純屬“雞肋”,畢竟SQL文法是程式員的基本功。不過Android既然提供了這些方法,這裡也簡單介紹一下。

1、insert :方法簽名: long insert(String table, String nullColumnHack, ContentValues values)

table:表名。

nullColumnHack:強行插入null值的資料列的列名。當values為null或它包含的索引值對的數量為0時,就起作用了。它不應是主鍵列的列名,也不應是非空列的列名。

values:代表一行記錄的資料。ContentValues類似於Map集合,存放索引值對,鍵為資料列的列名。

2、update:方法簽名: int update(String table, ContentValues values, String whereClause, String[] whereArgs)

table:表名。

values:想更新的資料。

whereClause:條件。

whereArgs:為whereClause子句傳入參數。即用來替代預留位置的內容。

返回的整數是受此update語句影響的記錄的條數。

3、delete:方法簽名: int  delete(String table, String whereClause,String[] whereArgs)

table:表名

whereClause:條件,滿足此條件的記錄將會被刪除。

whereArgs:用於為whereClause子句傳入參數。即替代預留位置。

返回的整數是受此delete語句影響的記錄的條數。

4、query:方法簽名:Cursor query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy)

table:表名

columns:要查詢的列名

selection:查詢條件子句 相當於where關鍵字後面的部分。

selectionArgs:為selection傳入參數,替代預留位置。

groupBy:控制分組,相當於select語句group by後面的部分

having:用於對分組進行過濾,相當於select語句having後面的部分

orderBy:排序。相當於select語句order by後面的部分

下面通過一個簡單一實例來示範它們的使用,代碼如下:

Activity:

package com.lovo.activity;import android.app.Activity;import android.content.ContentValues;import android.database.Cursor;import android.database.sqlite.SQLiteDatabase;import android.os.Bundle;import android.view.View;import android.widget.TextView;import com.lovo.dao.DBUtil;import com.lovo.databasetest.R;public class DatabaseTestActivity extends Activity {private TextView show;private SQLiteDatabase db;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.main);show = (TextView) findViewById(R.id.main_tv_show);db = DBUtil.getInstance(this);}public void click(View v) {switch (v.getId()) {case R.id.main_btn_insert:// 添加指定資料ContentValues insertValues = new ContentValues();insertValues.put("s_name", "李四");insertValues.put("s_age", 23);insertValues.put("s_sex", "男");db.insert("t_stu", null, insertValues);break;case R.id.main_btn_delete:// 根據指定條件刪除資料db.delete("t_stu", "s_name like ?", new String[] { "李_" });break;case R.id.main_btn_update:// 根據指定ID修改資料ContentValues updateValues = new ContentValues();updateValues.put("s_name", "新人名");db.update("t_stu", updateValues, "_id=?", new String[] { "2" });break;case R.id.main_btn_find:// 查詢所有資料Cursor cursor = db.query("t_stu", null, null, null, null, null,null);// 根據指定條件查詢// Cursor cursor=db.query("t_stu", null, "s_name like ?", new// String[]{"張%"},null, null, null);StringBuffer sb = new StringBuffer();while (cursor.moveToNext()) {int id = cursor.getInt(cursor.getColumnIndex("_id"));String name = cursor.getString(cursor.getColumnIndex("s_name"));String sex = cursor.getString(cursor.getColumnIndex("s_sex"));int age = cursor.getInt(cursor.getColumnIndex("s_age"));sb.append(id + " " + name + " " + sex + " " + age + "\n");}show.setText(sb.toString());break;}}}

SQLiteOpenHelper子類(DBUtil):

package com.lovo.dao;import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteDatabase.CursorFactory;import android.database.sqlite.SQLiteOpenHelper;public class DBUtil extends SQLiteOpenHelper {private static DBUtil dbUtil;private DBUtil(Context context, String name, CursorFactory factory,int version) {super(context, name, factory, version);}public static SQLiteDatabase getInstance(Context context) {if (dbUtil == null) {// 指定資料庫名為student,需修改時在此修改;此處使用預設工廠;指定版本為1dbUtil = new DBUtil(context, "student", null, 1);}return dbUtil.getReadableDatabase();}@Overridepublic void onCreate(SQLiteDatabase db) {try {db.execSQL("create table t_stu(_id integer primary key,s_name text,s_age integer,s_sex text)");} catch (Exception e) {e.printStackTrace();}}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {System.out.println("-----onUpgrade Called-----" + oldVersion + "--->"+ newVersion);}}

布局XML:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:orientation="vertical" >    <Button        android:id="@+id/main_btn_insert"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:onClick="click"        android:text="添加" />    <Button        android:id="@+id/main_btn_delete"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:onClick="click"        android:text="刪除" />    <Button        android:id="@+id/main_btn_update"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:onClick="click"        android:text="修改" />    <Button        android:id="@+id/main_btn_find"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:onClick="click"        android:text="尋找" />    <TextView        android:id="@+id/main_tv_show"        android:layout_width="wrap_content"        android:layout_height="wrap_content" /></LinearLayout>

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.