Android 之採用execSQL和rawQuery方法完成資料的添刪改查操作
- /*
- Android提供了一個名為SQLiteDatabase的類,該類封裝了一些操作資料庫的API,使用該類可以完成對資料進行新增(Create)、查詢(Retrieve)、更新(Update)和刪除(Delete)操作(這些操作簡稱為CRUD)。對SQLiteDatabase的學習,我們應該重點掌握execSQL()和rawQuery()方法。 execSQL()方法可以執行insert、delete、update和CREATE TABLE之類有更改行為的SQL語句; rawQuery()方法用於執行select語句。
- execSQL()方法的使用例子:
- SQLiteDatabase db = ....;
- db.execSQL("insert into person(name, age) values('測試資料', 4)");
- db.close();
- 執行上面SQL語句會往person表中新增進一條記錄,在實際應用中, 語句中的“測試資料”這些引數值會由使用者輸入介面提供,如果把使用者輸入的內容原樣組拼到上面的insert語句, 當用戶輸入的內容含有單引號時,組拼出來的SQL語句就會存在語法錯誤。要解決這個問題需要對單引號進行轉義,也就是把單引號轉換成兩個單引號。有些時候使用者往往還會輸入像“ & ”這些特殊SQL符號,為保證組拼好的SQL語句語法正確,必須對SQL語句中的這些特殊SQL符號都進行轉義,顯然,對每條SQL語句都做這樣的處理工作是比較煩瑣的。 SQLiteDatabase類提供了一個過載後的execSQL(String sql, Object[] bindArgs)方法,使用這個方法可以解決前面提到的問題,因為這個方法支援使用佔位符引數(?)。使用例子如下:
- SQLiteDatabase db = ....;
- db.execSQL("insert into person(name, age) values(?,?)", new Object[]{"測試資料", 4});
- db.close();
- execSQL(String sql, Object[] bindArgs)方法的第一個引數為SQL語句,第二個引數為SQL語句中佔位符引數的值,引數值在陣列中的順序要和佔位符的位置對應。
- */
- public class DatabaseHelper extends SQLiteOpenHelper {
- //類沒有例項化,是不能用作父類構造器的引數,必須宣告為靜態
- private static final String name = "itcast"; //資料庫名稱
- private static final int version = 1; //資料庫版本
- public DatabaseHelper(Context context) {
- //第三個引數CursorFactory指定在執行查詢時獲得一個遊標例項的工廠類,設定為null,代表使用系統預設的工廠類
- super(context, name, null, version);
- }
- @Override public void onCreate(SQLiteDatabase db) {
- db.execSQL("CREATE TABLE IF NOT EXISTS person (personid integer primary key autoincrement, name varchar(20), age INTEGER)");
- }
- @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
- db.execSQL(" ALTER TABLE person ADD phone VARCHAR(12) NULL "); //往表中增加一列
- // DROP TABLE IF EXISTS person 刪除表
- }
- }
- //在實際專案開發中,當資料庫表結構發生更新時,應該避免使用者存放於數//據庫中的資料丟失。
- /*
- Android提供了一個名為SQLiteDatabase的類,該類封裝了一些操作資料庫的API,使用該類可以完成對資料進行新增(Create)、查詢(Retrieve)、更新(Update)和刪除(Delete)操作(這些操作簡稱為CRUD)。對SQLiteDatabase的學習,我們應該重點掌握execSQL()和rawQuery()方法。 execSQL()方法可以執行insert、delete、update和CREATE TABLE之類有更改行為的SQL語句; rawQuery()方法用於執行select語句。
- execSQL()方法的使用例子:
- SQLiteDatabase db = ....;
- db.execSQL("insert into person(name, age) values('測試資料', 4)");
- db.close();
- 執行上面SQL語句會往person表中新增進一條記錄,在實際應用中, 語句中的“測試資料”這些引數值會由使用者輸入介面提供,如果把使用者輸入的內容原樣組拼到上面的insert語句, 當用戶輸入的內容含有單引號時,組拼出來的SQL語句就會存在語法錯誤。要解決這個問題需要對單引號進行轉義,也就是把單引號轉換成兩個單引號。有些時候使用者往往還會輸入像“ & ”這些特殊SQL符號,為保證組拼好的SQL語句語法正確,必須對SQL語句中的這些特殊SQL符號都進行轉義,顯然,對每條SQL語句都做這樣的處理工作是比較煩瑣的。 SQLiteDatabase類提供了一個過載後的execSQL(String sql, Object[] bindArgs)方法,使用這個方法可以解決前面提到的問題,因為這個方法支援使用佔位符引數(?)。使用例子如下:
- SQLiteDatabase db = ....;
- db.execSQL("insert into person(name, age) values(?,?)", new Object[]{"測試資料", 4});
- db.close();
- execSQL(String sql, Object[] bindArgs)方法的第一個引數為SQL語句,第二個引數為SQL語句中佔位符引數的值,引數值在陣列中的順序要和佔位符的位置對應。
- */
- /*
- SQLiteDatabase的rawQuery() 用於執行select語句,使用例子如下: SQLiteDatabase db = ....;
- Cursor cursor = db.rawQuery(“select * from person”, null);
- while (cursor.moveToNext()) {
- int personid = cursor.getInt(0); //獲取第一列的值,第一列的索引從0開始
- String name = cursor.getString(1);//獲取第二列的值
- int age = cursor.getInt(2);//獲取第三列的值
- }
- cursor.close();
- db.close();
- rawQuery()方法的第一個引數為select語句;第二個引數為select語句中佔位符引數的值,如果select語句沒有使用佔位符,該引數可以設定為null。帶佔位符引數的select語句使用例子如下:
- Cursor cursor = db.rawQuery("select * from person where name like ? and age=?", new String[]{"%傳智%", "4"});
- Cursor是結果集遊標,用於對結果集進行隨機訪問,如果大家熟悉jdbc, 其實Cursor與JDBC中的ResultSet作用很相似。使用moveToNext()方法可以將遊標從當前行移動到下一行,如果已經移過了結果集的最後一行,返回結果為false,否則為true。另外Cursor 還有常用的moveToPrevious()方法(用於將遊標從當前行移動到上一行,如果已經移過了結果集的第一行,返回值為false,否則為true )、moveToFirst()方法(用於將遊標移動到結果集的第一行,如果結果集為空,返回值為false,否則為true )和moveToLast()方法(用於將遊標移動到結果集的最後一行,如果結果集為空,返回值為false,否則為true ) 。
- */
- /*
- 除了前面給大家介紹的execSQL()和rawQuery()方法, SQLiteDatabase還專門提供了對應於新增、刪除、更新、查詢的操作方法: insert()、delete()、update()和query() 。這些方法實際上是給那些不太瞭解SQL語法的菜鳥使用的,對於熟悉SQL語法的程式設計師而言,直接使用execSQL()和rawQuery()方法執行SQL語句就能完成資料的新增、刪除、更新、查詢操作。
- Insert()方法用於新增資料,各個欄位的資料使用ContentValues進行存放。 ContentValues類似於MAP,相對於MAP,它提供了存取資料對應的put(String key, Xxx value)和getAsXxx(String key)方法, key為欄位名稱,value為欄位值,Xxx指的是各種常用的資料型別,如:String、Integer等。
- SQLiteDatabase db = databaseHelper.getWritableDatabase();
- ContentValues values = new ContentValues();
- values.put("name", "測試資料");
- values.put("age", 4);
- long rowid = db.insert(“person”, null, values);//返回新添記錄的行號,與主鍵id無關
- 不管第三個引數是否包含資料,執行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。
- */
- /*
- delete()方法的使用:
- SQLiteDatabase db = databaseHelper.getWritableDatabase();
- db.delete("person", "personid<?", new String[]{"2"});
- db.close();
- 上面程式碼用於從person表中刪除personid小於2的記錄。
- update()方法的使用:
- SQLiteDatabase db = databaseHelper.getWritableDatabase();
- ContentValues values = new ContentValues();
- values.put(“name”, “測試資料”);//key為欄位名,value為值
- db.update("person", values, "personid=?", new String[]{"1"});
- db.close();
- 上面程式碼用於把person表中personid等於1的記錄的name欄位的值改為“測試資料”。
- */
- /*
- query()方法實際上是把select語句拆分成了若干個組成部分,然後作為方法的輸入引數:
- SQLiteDatabase db = databaseHelper.getWritableDatabase();
- Cursor cursor = db.query("person", new String[]{"personid,name,age"}, "name like ?", new String[]{"%傳智%"}, null, null, "personid desc", "1,2");
- while (cursor.moveToNext()) {
- int personid = cursor.getInt(0); //獲取第一列的值,第一列的索引從0開始
- String name = cursor.getString(1);//獲取第二列的值
- int age = cursor.getInt(2);//獲取第三列的值
- }
- cursor.close();
- db.close();
- 上面程式碼用於從person表中查詢name欄位含有“傳智”的記錄,匹配的記錄按personid降序排序,對排序後的結果略過第一條記錄,只獲取2條記錄。
- query(table, columns, selection, selectionArgs, groupBy, having, orderBy, limit)方法各引數的含義:
- table:表名。相當於select語句from關鍵字後面的部分。如果是多表聯合查詢,可以用逗號將兩個表名分開。
- columns:要查詢出來的列名。相當於select語句select關鍵字後面的部分。
- selection:查詢條件子句,相當於select語句where關鍵字後面的部分,在條件子句允許使用佔位符“?”
- selectionArgs:對應於selection語句中佔位符的值,值在陣列中的位置與佔位符在語句中的位置必須一致,否則就會有異常。
- groupBy:相當於select語句group by關鍵字後面的部分
- having:相當於select語句having關鍵字後面的部分
- orderBy:相當於select語句order by關鍵字後面的部分,如:personid desc, age asc;
- limit:指定偏移量和獲取的記錄數,相當於select語句limit關鍵字後面的部分。
- */
- package com.zyq.db;
- import android.app.Activity;
- import android.os.Bundle;
-
相關推薦
Android 之採用execSQL和rawQuery方法完成資料的添刪改查操作
/* 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驅動包就行
Android之JNI動態註冊native方法和JNI資料簡單使用
1、介紹JNI註冊方式 JVM 查詢 native 方法有兩種方式: 1)、按照 JNI 規範的命名規則(靜態註冊) 2) 、呼叫 JNI 提供的 RegisterNatives 函式,將本地函式註冊到 JVM 中(動態註冊) 2、動態註冊的步驟
Android系列之網路(三)----使用HttpClient傳送HTTP請求(分別通過GET和POST方法傳送資料)
【正文】 在前兩篇文章中,我們學習到了和HTTP相關的基礎知識。文章連結如下: 一、GET和POST的對比: 在漫長的時間當中,其他的方法逐漸的退出了歷史舞臺,最常用的只剩下GET和POST方法。而之前已經講過了通過GET方法獲取資料,今天來學習一下如何分別通過
java之靜態屬性和靜態方法
person pri 技術分享 周期 銷毀 out 方法 class 屬性的區別 前言 靜態屬性和方法必須用static修飾符 靜態屬性和非靜態屬性的區別: 1、在內存中存放位置不同 所有帶static修飾符的屬性或者方法都存放在內存中的方法區 而非靜態屬性存放在內存
Java之構造器和構造方法的使用和意義
但是 屬性 end 定義 檢查 初始化 當我 還需要 初學 java中構造方法是一個重要的概念,初學時有人會對此構造方法的使用特別是其作用不清楚,下面我就來談談我對java中構造方法的理解,有不對或不清楚的地方希望各位看官提出意見,謝謝! 一.構造方法的定義聲明 構造方法
Android Fragment使用hide和show方法的問題
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#的時候經常會看到一個名詞“抽象類”,那什麼是抽象類,抽象類是用來幹什麼的,在看了很多部落格和資料,都說的很官方,理解起來很難,並且好多部落格資料都是不斷地抄襲抄襲,寫的千篇一律,基本都很相似,那下面小編就根據自己的理解說以下抽象來,結合抽象類把抽象方法也說了。 抽象方
Android之Intent顯示和隱式呼叫
intent就是意圖的意思。Intent分兩種:顯式(Explicit intent)和隱式(Implicit intent)。 一、顯式(設定Component) 顯式,即直接指定需要開啟的activity對應的類。 以下多種方式都是一樣的,實際上都是設定Component直接指定Acti
SSH之hibernate——get和load方法的區別
hibernate查詢資料可以用get()和load()方法,但是它們的機制還有一些不同,下面講解具體的區別。 一、建實體類User,並配置對映檔案 因為實體類建立非常簡
Python之私有函式和專有方法
在任何語言中,都會規定某些物件(屬性、方法、函式、類等)只能夠在某個範圍內訪問,出了這個範圍就不能訪問了。這是“公”、“私”之分。此外,還會專門為某些特殊的東西指定一些特殊表示,比如類的名字就不能用class,def等,這就是保留字。除了保留字,python中還為類的名字
android之MTP框架和流程分析
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
android之JNI引數傳遞 (Java方法呼叫)
從Java 1.1開始,Java Native Interface (JNI)標準成為java平臺的一部分,它允許Java程式碼和其他語言寫的程式碼進行互動。JNI一開始是為了本地已編譯語言,尤其是C和C++而設計 的,但是它並不妨礙你使用其他語言,只要呼叫約定受支援就可
HTTP基礎與Android之——使用HttpClient和HttpURLConnection
1、客戶端連線伺服器實現內部的原理: 分析上圖,步驟如下: 第一步:在瀏覽器客戶端中得到使用者輸入的內容。 第二步:瀏覽器得到這個網址之後,內部會將這個域名傳送到DNS上,進行域名解析。得到它的IP之後就會連結到指定的伺服器上,假如伺服器的地址是:221.104.13.32:80,從瀏覽器
Android之什麼時候呼叫onSaveInstance方法的時候(為什麼按Home鍵盤會呼叫,按Back不呼叫)
1、函式介紹 1)、onCreate(Bundle savedInstanceState) 方法 Activity 建立時回撥 : 該方法會自動傳入一個 Bundle 物件, 該 Bundle 物件就是上次被系統銷燬時在 onSaveInstanceState 或者 on