1. 程式人生 > >Android 之採用execSQL和rawQuery方法完成資料的添刪改查操作

Android 之採用execSQL和rawQuery方法完成資料的添刪改查操作

  1. /* 
  2. Android提供了一個名為SQLiteDatabase的類,該類封裝了一些操作資料庫的API,使用該類可以完成對資料進行新增(Create)、查詢(Retrieve)、更新(Update)和刪除(Delete)操作(這些操作簡稱為CRUD)。對SQLiteDatabase的學習,我們應該重點掌握execSQL()和rawQuery()方法。 execSQL()方法可以執行insert、delete、update和CREATE TABLE之類有更改行為的SQL語句; rawQuery()方法用於執行select語句。 
  3. execSQL()方法的使用例子:
     
  4. SQLiteDatabase db = ....; 
  5. db.execSQL("insert into person(name, age) values('測試資料', 4)"); 
  6. db.close(); 
  7. 執行上面SQL語句會往person表中新增進一條記錄,在實際應用中, 語句中的“測試資料”這些引數值會由使用者輸入介面提供,如果把使用者輸入的內容原樣組拼到上面的insert語句, 當用戶輸入的內容含有單引號時,組拼出來的SQL語句就會存在語法錯誤。要解決這個問題需要對單引號進行轉義,也就是把單引號轉換成兩個單引號。有些時候使用者往往還會輸入像“ & ”這些特殊SQL符號,為保證組拼好的SQL語句語法正確,必須對SQL語句中的這些特殊SQL符號都進行轉義,顯然,對每條SQL語句都做這樣的處理工作是比較煩瑣的。 SQLiteDatabase類提供了一個過載後的execSQL(String sql, Object[] bindArgs)方法,使用這個方法可以解決前面提到的問題,因為這個方法支援使用佔位符引數(?)。使用例子如下:
     
  8. SQLiteDatabase db = ....; 
  9. db.execSQL("insert into person(name, age) values(?,?)", new Object[]{"測試資料", 4});  
  10. db.close(); 
  11. execSQL(String sql, Object[] bindArgs)方法的第一個引數為SQL語句,第二個引數為SQL語句中佔位符引數的值,引數值在陣列中的順序要和佔位符的位置對應。
     
  12. */  



  1. public class DatabaseHelper extends SQLiteOpenHelper {  
  2.     //類沒有例項化,是不能用作父類構造器的引數,必須宣告為靜態  
  3.          private static final String name = "itcast"//資料庫名稱  
  4.          private static final int version = 1//資料庫版本  
  5.          public DatabaseHelper(Context context) {  
  6. //第三個引數CursorFactory指定在執行查詢時獲得一個遊標例項的工廠類,設定為null,代表使用系統預設的工廠類  
  7.                 super(context, name, null, version);  
  8.          }  
  9.         @Override public void onCreate(SQLiteDatabase db) {  
  10.               db.execSQL("CREATE TABLE IF NOT EXISTS person (personid integer primary key autoincrement, name varchar(20), age INTEGER)");     
  11.          }  
  12.         @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {  
  13.                db.execSQL(" ALTER TABLE person ADD phone VARCHAR(12) NULL "); //往表中增加一列  
  14.     // DROP TABLE IF EXISTS person 刪除表  
  15.        }  
  16. }  
  17. //在實際專案開發中,當資料庫表結構發生更新時,應該避免使用者存放於數//據庫中的資料丟失。  


  1. /* 
  2. Android提供了一個名為SQLiteDatabase的類,該類封裝了一些操作資料庫的API,使用該類可以完成對資料進行新增(Create)、查詢(Retrieve)、更新(Update)和刪除(Delete)操作(這些操作簡稱為CRUD)。對SQLiteDatabase的學習,我們應該重點掌握execSQL()和rawQuery()方法。 execSQL()方法可以執行insert、delete、update和CREATE TABLE之類有更改行為的SQL語句; rawQuery()方法用於執行select語句。 
  3. execSQL()方法的使用例子: 
  4. SQLiteDatabase db = ....; 
  5. db.execSQL("insert into person(name, age) values('測試資料', 4)"); 
  6. db.close(); 
  7. 執行上面SQL語句會往person表中新增進一條記錄,在實際應用中, 語句中的“測試資料”這些引數值會由使用者輸入介面提供,如果把使用者輸入的內容原樣組拼到上面的insert語句, 當用戶輸入的內容含有單引號時,組拼出來的SQL語句就會存在語法錯誤。要解決這個問題需要對單引號進行轉義,也就是把單引號轉換成兩個單引號。有些時候使用者往往還會輸入像“ & ”這些特殊SQL符號,為保證組拼好的SQL語句語法正確,必須對SQL語句中的這些特殊SQL符號都進行轉義,顯然,對每條SQL語句都做這樣的處理工作是比較煩瑣的。 SQLiteDatabase類提供了一個過載後的execSQL(String sql, Object[] bindArgs)方法,使用這個方法可以解決前面提到的問題,因為這個方法支援使用佔位符引數(?)。使用例子如下: 
  8. SQLiteDatabase db = ....; 
  9. db.execSQL("insert into person(name, age) values(?,?)", new Object[]{"測試資料", 4});  
  10. db.close(); 
  11. execSQL(String sql, Object[] bindArgs)方法的第一個引數為SQL語句,第二個引數為SQL語句中佔位符引數的值,引數值在陣列中的順序要和佔位符的位置對應。 
  12. */  


  1. /* 
  2. SQLiteDatabase的rawQuery() 用於執行select語句,使用例子如下:  SQLiteDatabase db = ....; 
  3. Cursor cursor = db.rawQuery(“select * from person”, null); 
  4. while (cursor.moveToNext()) { 
  5.     int personid = cursor.getInt(0); //獲取第一列的值,第一列的索引從0開始 
  6.     String name = cursor.getString(1);//獲取第二列的值 
  7.     int age = cursor.getInt(2);//獲取第三列的值 
  8. } 
  9. cursor.close(); 
  10. db.close();  
  11. rawQuery()方法的第一個引數為select語句;第二個引數為select語句中佔位符引數的值,如果select語句沒有使用佔位符,該引數可以設定為null。帶佔位符引數的select語句使用例子如下: 
  12. Cursor cursor = db.rawQuery("select * from person where name like ? and age=?", new String[]{"%傳智%", "4"}); 
  13. Cursor是結果集遊標,用於對結果集進行隨機訪問,如果大家熟悉jdbc, 其實Cursor與JDBC中的ResultSet作用很相似。使用moveToNext()方法可以將遊標從當前行移動到下一行,如果已經移過了結果集的最後一行,返回結果為false,否則為true。另外Cursor 還有常用的moveToPrevious()方法(用於將遊標從當前行移動到上一行,如果已經移過了結果集的第一行,返回值為false,否則為true )、moveToFirst()方法(用於將遊標移動到結果集的第一行,如果結果集為空,返回值為false,否則為true )和moveToLast()方法(用於將遊標移動到結果集的最後一行,如果結果集為空,返回值為false,否則為true ) 。 
  14.  
  15. */  


  1. /* 
  2. 除了前面給大家介紹的execSQL()和rawQuery()方法, SQLiteDatabase還專門提供了對應於新增、刪除、更新、查詢的操作方法: insert()、delete()、update()和query() 。這些方法實際上是給那些不太瞭解SQL語法的菜鳥使用的,對於熟悉SQL語法的程式設計師而言,直接使用execSQL()和rawQuery()方法執行SQL語句就能完成資料的新增、刪除、更新、查詢操作。 
  3. Insert()方法用於新增資料,各個欄位的資料使用ContentValues進行存放。 ContentValues類似於MAP,相對於MAP,它提供了存取資料對應的put(String key, Xxx value)和getAsXxx(String key)方法,  key為欄位名稱,value為欄位值,Xxx指的是各種常用的資料型別,如:String、Integer等。 
  4. SQLiteDatabase db = databaseHelper.getWritableDatabase(); 
  5. ContentValues values = new ContentValues(); 
  6. values.put("name", "測試資料"); 
  7. values.put("age", 4); 
  8. long rowid = db.insert(“person”, null, values);//返回新添記錄的行號,與主鍵id無關 
  9. 不管第三個引數是否包含資料,執行Insert()方法必然會新增一條記錄,如果第三個引數為空,會新增一條除主鍵之外其他欄位值為Null的記錄。Insert()方法內部實際上通過構造insert SQL語句完成資料的新增,Insert()方法的第二個引數用於指定空值欄位的名稱,相信大家對該引數會感到疑惑,該引數的作用是什麼?是這樣的:如果第三個引數values 為Null或者元素個數為0, 由於Insert()方法要求必須新增一條除了主鍵之外其它欄位為Null值的記錄,為了滿足SQL語法的需要, insert語句必須給定一個欄位名,如:insert into person(name) values(NULL),倘若不給定欄位名 , insert語句就成了這樣: insert into person() values(),顯然這不滿足標準SQL的語法。對於欄位名,建議使用主鍵之外的欄位,如果使用了INTEGER型別的主鍵欄位,執行類似insert into person(personid) values(NULL)的insert語句後,該主鍵欄位值也不會為NULL。如果第三個引數values 不為Null並且元素的個數大於0 ,可以把第二個引數設定為null。 
  10. */


  1. /* 
  2. delete()方法的使用: 
  3. SQLiteDatabase db = databaseHelper.getWritableDatabase(); 
  4. db.delete("person", "personid<?", new String[]{"2"}); 
  5. db.close(); 
  6. 上面程式碼用於從person表中刪除personid小於2的記錄。 
  7. update()方法的使用: 
  8. SQLiteDatabase db = databaseHelper.getWritableDatabase(); 
  9. ContentValues values = new ContentValues(); 
  10. values.put(“name”, “測試資料”);//key為欄位名,value為值 
  11. db.update("person", values, "personid=?", new String[]{"1"});  
  12. db.close(); 
  13. 上面程式碼用於把person表中personid等於1的記錄的name欄位的值改為“測試資料”。 
  14.  
  15. */  


  1. /* 
  2. query()方法實際上是把select語句拆分成了若干個組成部分,然後作為方法的輸入引數: 
  3. SQLiteDatabase db = databaseHelper.getWritableDatabase(); 
  4. Cursor cursor = db.query("person", new String[]{"personid,name,age"}, "name like ?", new String[]{"%傳智%"}, null, null, "personid desc", "1,2"); 
  5. while (cursor.moveToNext()) { 
  6.          int personid = cursor.getInt(0); //獲取第一列的值,第一列的索引從0開始 
  7.         String name = cursor.getString(1);//獲取第二列的值 
  8.         int age = cursor.getInt(2);//獲取第三列的值 
  9. } 
  10. cursor.close(); 
  11. db.close();  
  12. 上面程式碼用於從person表中查詢name欄位含有“傳智”的記錄,匹配的記錄按personid降序排序,對排序後的結果略過第一條記錄,只獲取2條記錄。 
  13. query(table, columns, selection, selectionArgs, groupBy, having, orderBy, limit)方法各引數的含義: 
  14. table:表名。相當於select語句from關鍵字後面的部分。如果是多表聯合查詢,可以用逗號將兩個表名分開。 
  15. columns:要查詢出來的列名。相當於select語句select關鍵字後面的部分。 
  16. selection:查詢條件子句,相當於select語句where關鍵字後面的部分,在條件子句允許使用佔位符“?” 
  17. selectionArgs:對應於selection語句中佔位符的值,值在陣列中的位置與佔位符在語句中的位置必須一致,否則就會有異常。 
  18. groupBy:相當於select語句group by關鍵字後面的部分 
  19. having:相當於select語句having關鍵字後面的部分 
  20. orderBy:相當於select語句order by關鍵字後面的部分,如:personid desc, age asc; 
  21. limit:指定偏移量和獲取的記錄數,相當於select語句limit關鍵字後面的部分。 
  22. */  




  1. package com.zyq.db;  
  2. import android.app.Activity;  
  3. import android.os.Bundle;  
  4. 相關推薦

    Android 採用execSQLrawQuery方法完成資料刪改操作

    /*  Android提供了一個名為SQLiteDatabase的類,該類封裝了一些操作資料庫的API,使用該類可以完成對資料進行新增(Create)、查詢(Retrieve)、更新(Update)和刪除(Delete)操作(這些操作簡稱為CRUD)。對SQLiteData

    Mybatis環境搭建進行簡單的CRUD增刪改操作

    1:首先引入所需要的jar包。包括mybatis-3.2.8.jar、mysql-connector-java-3.1.12-bin.jar、junit4.4.jar、log4j-1.2.17.jar。其中後面2個不是必須需要的。只需要mybatis的和mysql驅動包就行

    AndroidJNI動態註冊native方法JNI資料簡單使用

    1、介紹JNI註冊方式 JVM 查詢 native 方法有兩種方式:     1)、按照 JNI 規範的命名規則(靜態註冊)    2) 、呼叫 JNI 提供的 RegisterNatives 函式,將本地函式註冊到 JVM 中(動態註冊) 2、動態註冊的步驟

    Android系列網路(三)----使用HttpClient傳送HTTP請求(分別通過GETPOST方法傳送資料

     【正文】 在前兩篇文章中,我們學習到了和HTTP相關的基礎知識。文章連結如下: 一、GET和POST的對比: 在漫長的時間當中,其他的方法逐漸的退出了歷史舞臺,最常用的只剩下GET和POST方法。而之前已經講過了通過GET方法獲取資料,今天來學習一下如何分別通過

    java靜態屬性靜態方法

    person pri 技術分享 周期 銷毀 out 方法 class 屬性的區別 前言 靜態屬性和方法必須用static修飾符 靜態屬性和非靜態屬性的區別: 1、在內存中存放位置不同 所有帶static修飾符的屬性或者方法都存放在內存中的方法區 而非靜態屬性存放在內存

    Java構造器構造方法的使用意義

    但是 屬性 end 定義 檢查 初始化 當我 還需要 初學 java中構造方法是一個重要的概念,初學時有人會對此構造方法的使用特別是其作用不清楚,下面我就來談談我對java中構造方法的理解,有不對或不清楚的地方希望各位看官提出意見,謝謝! 一.構造方法的定義聲明 構造方法

    Android Fragment使用hideshow方法的問題

           Fragment的強大是毋庸置疑的,現在是越來越喜歡使用它了,但是使用中我也是頭疼了好一陣,各種小bug層出,記錄一下:        我們使用Fragment去

    Android隱藏Activity介面的方法

    moveTaskToBack(true);//activity 隱藏 清單檔案 activity: android:configChanges="orientation|keyboardHidden|keyboard" android:launchMode="singleI

    Android螢幕常亮的方法

    private void lock() { PowerManager mPowerManager = (PowerManager) getSystemService(POWER_SERVICE); wakeLock = mPowerManager.newWakeL

    跟老齊學Python私有函式專有方法

    在任何語言中,都會規定某些物件(屬性、方法、函式、類等)只能夠在某個範圍內訪問,出了這個範圍就不能訪問了。這是“公”、“私”之分。此外,還會專門為某些特殊的東西指定一些特殊表示,比如類的名字就不能用class,def等,這就是保留字。除了保留字,python中還為類的名字做了某些特殊準備,就是“專有

    Android靜態文字按鈕的互動

    佈局程式碼 <?xml version="1.0" encoding="utf-8"?> <AbsoluteLayout xmlns:android="http://schemas.android.com/apk/res/android"

    C#抽象類抽象方法

    一、前言 在學習C#的時候經常會看到一個名詞“抽象類”,那什麼是抽象類,抽象類是用來幹什麼的,在看了很多部落格和資料,都說的很官方,理解起來很難,並且好多部落格資料都是不斷地抄襲抄襲,寫的千篇一律,基本都很相似,那下面小編就根據自己的理解說以下抽象來,結合抽象類把抽象方法也說了。 抽象方

    AndroidIntent顯示隱式呼叫

    intent就是意圖的意思。Intent分兩種:顯式(Explicit intent)和隱式(Implicit intent)。 一、顯式(設定Component) 顯式,即直接指定需要開啟的activity對應的類。 以下多種方式都是一樣的,實際上都是設定Component直接指定Acti

    SSHhibernate——getload方法的區別

           hibernate查詢資料可以用get()和load()方法,但是它們的機制還有一些不同,下面講解具體的區別。 一、建實體類User,並配置對映檔案         因為實體類建立非常簡

    Python私有函式專有方法

    在任何語言中,都會規定某些物件(屬性、方法、函式、類等)只能夠在某個範圍內訪問,出了這個範圍就不能訪問了。這是“公”、“私”之分。此外,還會專門為某些特殊的東西指定一些特殊表示,比如類的名字就不能用class,def等,這就是保留字。除了保留字,python中還為類的名字

    androidMTP框架流程分析

    1 static void android_mtp_MtpServer_add_storage(JNIEnv *env, jobject thiz, jobject jstorage) 2 { 3 Mutex::Autolock autoLock(sMutex); 4 5

    Android MTP框架流程分析 (3)

    前面轉發了篇部落格介紹了MTP, 偏重於上層,已經很清楚了。這篇側重於底層,按照一定的流程講。 1. 程式碼位置 packages/providers/MediaProvider/src/com/android/providers/media/MtpReceiver.j

    androidJNI引數傳遞 (Java方法呼叫)

    從Java 1.1開始,Java Native Interface (JNI)標準成為java平臺的一部分,它允許Java程式碼和其他語言寫的程式碼進行互動。JNI一開始是為了本地已編譯語言,尤其是C和C++而設計 的,但是它並不妨礙你使用其他語言,只要呼叫約定受支援就可

    HTTP基礎與Android——使用HttpClientHttpURLConnection

    1、客戶端連線伺服器實現內部的原理: 分析上圖,步驟如下: 第一步:在瀏覽器客戶端中得到使用者輸入的內容。 第二步:瀏覽器得到這個網址之後,內部會將這個域名傳送到DNS上,進行域名解析。得到它的IP之後就會連結到指定的伺服器上,假如伺服器的地址是:221.104.13.32:80,從瀏覽器

    Android什麼時候呼叫onSaveInstance方法的時候(為什麼按Home鍵盤會呼叫,按Back不呼叫)

    1、函式介紹 1)、onCreate(Bundle savedInstanceState) 方法 Activity 建立時回撥 : 該方法會自動傳入一個 Bundle 物件, 該 Bundle 物件就是上次被系統銷燬時在 onSaveInstanceState 或者 on