android SQLite數(shù)據(jù)庫總結
SQLite
SQLite是一種超輕量級的嵌入式數(shù)據(jù)庫,大小只有幾百KB,但是其語法支持標準SQL語法,同時還遵循了數(shù)據(jù)庫的ACID事務,所以學過其他數(shù)據(jù)庫的開發(fā)人員都很容易掌握其使用。
sql語法就不介紹了,直接看在android中的使用
SQLiteOpenHelper——封裝好的數(shù)據(jù)庫操作輔助類,需重寫
重寫方法
onCreate:初始化數(shù)據(jù)庫,創(chuàng)建表,添加初始數(shù)據(jù)
onUpgrade:數(shù)據(jù)庫版本升級時的數(shù)據(jù)庫操作,如備份刪除數(shù)據(jù)庫等
常用方法
getReadableDatabase() 獲取SQLiteDatabase對象,操作數(shù)據(jù)庫
getWritableDatabase() 獲取SQLiteDatabase對象,操作數(shù)據(jù)庫
區(qū)別:在磁盤空間滿或不可寫時,1方法將獲得只讀的數(shù)據(jù)庫對象,而2方法會報錯,在正常情況下,獲取到的都是可讀寫的數(shù)據(jù)庫對象。
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class DBHelper extends SQLiteOpenHelper {
private static final String name="my";//數(shù)據(jù)庫名
private static final int version=1;//版本號
//重寫構造方法的時候選擇參數(shù)少的一項
public DBHelper(Context context) {
//1:上下文 2:數(shù)據(jù)庫名稱 3:游標創(chuàng)建工廠 4:數(shù)據(jù)庫版本 版本只能是整數(shù) 1 2 3..
super(context, name, null, version);
}
//數(shù)據(jù)庫的初始化 SQLiteDatabase數(shù)據(jù)庫操作對象
//一般只在第一次運行和版本更新的時候調用
@Override
public void onCreate(SQLiteDatabase db) {
//創(chuàng)建數(shù)據(jù)庫 主鍵默認自增
db.execSQL("create table student(" +
"_id integer not null primary key autoincrement," +
"name varchar(20)," +
"phone varchar(11)," +
"gender varchar(2))");
//添加一條測試數(shù)據(jù)
db.execSQL("insert into student values(null,?,?,?)"
,new Object[]{"小黑","12345678901","男"});
}
/**
* 在版本升級的時候調用
* 修改version 為2 表示版本升級 就會調用這個方法
* @param db 數(shù)據(jù)庫操作對象
* @param oldVersion 舊版本號
* @param newVersion 新版本號
*/
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
在android數(shù)據(jù)庫的創(chuàng)建是需要創(chuàng)建對象才能創(chuàng)建的
在activity類中創(chuàng)建出一個數(shù)據(jù)庫類對象
創(chuàng)建好數(shù)據(jù)對象就可以操作數(shù)據(jù)了 通過SQLiteDatabase獲取 兩種獲取方法的區(qū)別上面已經提到過了
//創(chuàng)建數(shù)據(jù) DBHelper helper =new DBHelper(this); //調用數(shù)據(jù)操作對象 SQLiteDatabase dbWrite=helper.getWritableDatabase(); SQLiteDatabase dbRead=helper.getReadableDatabase();
SQLiteDatabase給我們提供了很多操作數(shù)據(jù)的方法
刪除:(int) delete(String table,String whereClause,String[] whereArgs)
table: 表名
whereClause:where條件 列名 占位符 id=?
whereArgs:參數(shù)值數(shù)組
添加:(long) insert(String table,String nullColumnHack,ContentValues values)
nullColumnHack:為空列
ContentValues values:通過鍵值對存儲添加的數(shù)據(jù) key為列 value為值
insert方法 底層是通過拼接字符串的方式 如果ContentValues是空的 拼接成的sql語句無法執(zhí)行會報錯 所以給一個可以為空的列當ContentValues為空時也可以執(zhí)行 有興趣的可以看一下源碼
更新:(int) update(String table, ContentValues values, String whereClause, String[] whereArgs)
參數(shù)意思同上
查詢:(Cursor) query(boolean distinct,String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit)
返回值是一個游標 這個query參數(shù)較多 簡單的查詢就還是寫一條sql語句簡單點
boolean distinct 去重復
String table 表名
String[] columns要查詢的列
String selection查詢條件
String[] selectionArgs查詢參數(shù)值
String groupBy分組
String having分組條件
String orderBy排序
String limit分頁查詢限制
關閉數(shù)據(jù)庫:(void) close()
執(zhí)行一條sql語句:(void) execSQL(String sql) 增刪改查
查詢查詢sql:(Cursor) rawQuery(String sql, String[] selectionArgs)
事務
try {
db.beginTransaction();//開啟事務
// db.update();
// db.insert();
db.setTransactionSuccessful(); //沒有設置事物成功 finally就會回滾
} catch (Exception e) {
e.printStackTrace();
}finally {
db.endTransaction();
}
貼代碼咯 執(zhí)行sql語句 和封裝好的方法
查詢
private void query() {
StringBuffer sb=new StringBuffer("select * from student where 1=1");
//參數(shù)集合
List<String> params=new ArrayList<>();
if(!TextUtils.isEmpty(id)){
sb.append(" and _id=?");
params.add(id);
}
if(!TextUtils.isEmpty(phone)){
sb.append(" and phone=?");
params.add(phone);
}
if(!TextUtils.isEmpty(name)){
sb.append(" and name=?");
params.add(name);
}
if(!TextUtils.isEmpty(gender)){
sb.append(" and gender=?");
params.add(gender);
}
SQLiteDatabase db=helper.getReadableDatabase();
String [] projection=new String [params.size()];
params.toArray(projection);
//返回值 游標
Cursor cursor=db.rawQuery(sb.toString(),projection);
//判斷游標是否為空,是否有一個值
while(cursor!=null&&cursor.moveToNext()){
// getColumnIndex獲取列的下標 cursor.getXXXX()獲取指定列的值
String name=cursor.getString(cursor.getColumnIndex("name"));
Integer id=cursor.getInt(cursor.getColumnIndex("_id"));
}
}
用不到的參數(shù)就讓它為空吧 遍歷數(shù)據(jù)就while循環(huán)就好咯
Cursor c = db.query("student",null,null,null,null,null,null);//查詢并獲得游標
更新
private void update() {
StringBuffer sb=new StringBuffer("update student set ");
List params=new ArrayList();
if(!TextUtils.isEmpty(phone)){
sb.append("phone=?,");
params.add(phone);
}
if(!TextUtils.isEmpty(name)){
sb.append("name=?,");
params.add(name);
}
if(!TextUtils.isEmpty(gender)){
sb.append("gender=?,");
params.add(gender);
}
if (params.size()!=0){
//更新操作拼接字符串末尾有一個","需要去除
//刪除最后一位的“,”
sb.setLength(sb.length()-1);
sb.append(" where 1=1");
//通過id指定 更新那行數(shù)據(jù)
if(!TextUtils.isEmpty(id)){
sb.append(" and _id=?");
params.add(id);
}else{
Toast.makeText(this,"請?zhí)顚慽d",Toast.LENGTH_SHORT).show();
return;
}
SQLiteDatabase db=helper.getWritableDatabase();
Object [] o=new Object[params.size()];
params.toArray(o);//將數(shù)據(jù)存放到指定的數(shù)組中
db.execSQL(sb.toString(),o);
}
}
ContentValues cv = new ContentValues();//實例化ContentValues
cv.put("name","123");//添加要更改的字段及內容
String whereClause = "phone=?";//修改條件
String[] whereArgs = {"12312313213"};//修改條件的參數(shù)
db.update("student",cv,whereClause,whereArgs);//執(zhí)行修改
刪除
private void delete() {
getAllText();
//拼接sql語句
StringBuffer sb=new StringBuffer("delete from student where 1=1");
//保存參數(shù)的list
List params=new ArrayList();
//判斷條件 動態(tài)拼接
if(!TextUtils.isEmpty(id)){
sb.append(" and _id=?");
params.add(id);
}
if(!TextUtils.isEmpty(phone)){
sb.append(" and phone=?");
params.add(phone);
}
if(!TextUtils.isEmpty(name)){
sb.append(" and name=?");
params.add(name);
}
if(!TextUtils.isEmpty(gender)){
sb.append(" and gender=?");
params.add(gender);
}
SQLiteDatabase db=helper.getWritableDatabase();
if (params.size()!=0){
Object [] o=new Object[params.size()];
params.toArray(o);//將數(shù)據(jù)存放到指定的數(shù)組中
//執(zhí)行刪除
db.execSQL(sb.toString(),o);
}else{
db.execSQL(sb.toString());
}
Toast.makeText(this,"刪除完成",Toast.LENGTH_SHORT).show();
}
String whereClause = "name=?";//刪除的條件
String[] whereArgs = {"123"};//刪除的條件參數(shù)
db.delete("student",whereClause,whereArgs);//執(zhí)行刪除
增加
private void insert() {//保存數(shù)據(jù)到object數(shù)組
Object [] o=new Object[]{name,phone,gender};
//獲取數(shù)據(jù)庫操作對象
SQLiteDatabase db=helper.getWritableDatabase();
//sql:sql語句 bingArgs:參數(shù)數(shù)組
db.execSQL("insert into student values(null,?,?,?)",o);
//關閉連接
db.close();
Toast.makeText(this,"增加成功",Toast.LENGTH_SHORT).show();
}
ContentValues cv = new ContentValues();//實例化一個ContentValues用來裝載待插入的數(shù)據(jù)
cv.put("name","123");
db.insert("student",null,cv);//執(zhí)行插入操作
以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關文章
解決EditText編輯時hint 在6.0 手機上顯示不出來的問題
下面小編就為大家?guī)硪黄鉀QEditText編輯時hint 在6.0 手機上顯示不出來的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05
Android ViewDragHelper完全解析 自定義ViewGroup神器
這篇文章主要為大家詳細介紹了Android ViewDragHelper完全解析,自定義ViewGroup神器,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03
Android Jetpack導航組件Navigation創(chuàng)建使用詳解
這篇文章主要為大家介紹了Android Jetpack導航組件Navigation創(chuàng)建及使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
Android 選擇相冊照片并返回功能的實現(xiàn)代碼
這篇文章主要介紹了Android 從相冊中選擇照片并返回功能,需要的朋友可以參考下2018-03-03
Android 雙擊Back鍵退出應用的實現(xiàn)方法
這篇文章主要介紹了Android 雙擊Back鍵退出應用的實現(xiàn)方法的相關資料,希望通過本文能幫助到大家,讓大家實現(xiàn)這樣的功能,需要的朋友可以參考下2017-10-10
Android進階Handler應用線上卡頓監(jiān)控詳解
這篇文章主要為大家介紹了Android進階Handler應用線上卡頓監(jiān)控詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01
Flutter使用Provider進行狀態(tài)管理的實現(xiàn)
Provider是Flutter中一個非常流行的狀態(tài)管理工具,它可以幫助開發(fā)者更有效地管理Widget樹中的數(shù)據(jù),本文主要介紹了Flutter使用Provider進行狀態(tài)管理的實現(xiàn),感興趣的可以了解一下2024-04-04

