Android對Sqlite提供了徹底友好的支持,在應用程序內部,均可以經過名稱訪問任何的數據庫。建議經過SQLiteOpenHelpe的子類並經過重寫onCreate() 方法進行建立數據表。本文主要講解Andriod開發中Sqlite的簡單應用(增刪改查),僅供學習分享使用。android
以下圖所示:sql
代碼以下:數據庫
1 package com.hex.demosqlite; 2 3 import android.content.Context; 4 import android.database.sqlite.SQLiteDatabase; 5 import android.database.sqlite.SQLiteOpenHelper; 6 7 /** 8 * Created by Administrator on 2019/4/4. 9 */ 10 public class DatabaseHelper extends SQLiteOpenHelper { 11 12 private static final String DB_NAME="persons.db"; 13 14 private static final int DB_VERSION=1; 15 16 public DatabaseHelper(Context context) { 17 super(context, DB_NAME, null, DB_VERSION); 18 } 19 20 /** 21 * 建立數據庫,指定數據庫名稱,版本號 22 * @param db 23 */ 24 @Override 25 public void onCreate(SQLiteDatabase db) { 26 String sql="create table person(_id integer primary key autoincrement not null, name char(10),nickname char(10))"; 27 db.execSQL(sql); 28 } 29 30 /** 31 * 數據庫升級 32 * @param db 33 * @param oldVersion 34 * @param newVersion 35 */ 36 @Override 37 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 38 if(newVersion>oldVersion){ 39 onCreate(db); 40 } 41 } 42 }
代碼以下:ide
1 /** 2 * 新增 3 * 4 * @param v 5 */ 6 public void add(View v) { 7 /** //通常不使用此種方法,由於execSQL方法沒有返回值 8 String sql="insert into person(name,nickname)values('宋江','及時雨')"; 9 db.execSQL(sql); 10 */ 11 ContentValues values = new ContentValues(); 12 values.put("name", "宋江"); 13 values.put("nickname", "及時雨"); 14 //返回值爲插入行的行號 15 long result = db.insert("person", null, values); 16 if (result > 0) { 17 Toast.makeText(this, "插入成功", Toast.LENGTH_SHORT).show(); 18 } else { 19 Toast.makeText(this, "插入失敗", Toast.LENGTH_SHORT).show(); 20 } 21 }
代碼以下:學習
1 /** 2 * 查詢 3 * 4 * @param v 5 */ 6 public void query(View v) { 7 /* 8 String sql="select * from person where name=?"; 9 Cursor cursor = db.rawQuery(sql,new String[]{"宋江"}); 10 */ 11 //columns 若是爲空,則表示全部列 12 Cursor cursor = db.query("person", null, "name=?", new String[]{"宋江"}, null, null, null); 13 while (cursor.moveToNext()) { 14 int nameIndex = cursor.getColumnIndex("name"); 15 int nickIndex = cursor.getColumnIndex("nickname"); 16 String nameValue = cursor.getString(nameIndex); 17 String nickValue = cursor.getString(nickIndex); 18 String s = "name=" + nameValue + ",nickname=" + nickValue; 19 Toast.makeText(this, s, Toast.LENGTH_SHORT).show(); 20 } 21 adaper.swapCursor(cursor); 22 adaper.notifyDataSetChanged(); 23 }
代碼以下:this
1 /** 2 * 更新 3 * 4 * @param v 5 */ 6 public void update(View v) { 7 // String sql="update person set nickname=? where name=?"; 8 9 ContentValues values = new ContentValues(); 10 values.put("nickname", "及時雨2"); 11 //更新語句受影響的行數 12 int result = db.update("person", values, "name=?", new String[]{"宋江"}); 13 if (result > 0) { 14 Toast.makeText(this, "更新成功", Toast.LENGTH_SHORT).show(); 15 } else { 16 Toast.makeText(this, "更新失敗", Toast.LENGTH_SHORT).show(); 17 } 18 }
代碼以下:spa
1 /** 2 * 刪除 3 * 4 * @param v 5 */ 6 public void delete(View v) { 7 //String sql="delete person where name=?"; 8 9 //受刪除語句影響的行數 10 int result = db.delete("person", "name=?", new String[]{"宋江"}); 11 if (result > 0) { 12 Toast.makeText(this, "刪除成功", Toast.LENGTH_SHORT).show(); 13 } else { 14 Toast.makeText(this, "沒有刪除成功", Toast.LENGTH_SHORT).show(); 15 } 16 }
千里之行,始於足下!code