標籤:
1.編寫類繼承SQLitHelper;
public class SQLiteHelper extends SQLiteOpenHelper {}
2.實現其建構函式;
public SQLiteHelper(Context context){ this(context, TABLE_NAME, null, DB_VERSION); } public SQLiteHelper(Context context, String name, CursorFactory factory, int version) { super(context, TABLE_NAME, factory, DB_VERSION); }
3.定義資料庫的名稱、表名、版本以及表的所有列明
private static final String DB_NAME = "playerdatas";//資料庫名稱 private static final String TABLE_NAME = "datas";//表名 private static final int DB_VERSION = 1;//資料庫版本 //表的列名 private static final String TABLE_ID = "_ID"; private static final String TABLE_VIDEOID = "videoId"; private static final String TABLE_URL = "url"; private static final String TABLE_TITLE = "title"; private static final String TABLE_CONTENT = "content"; private static final String TABLE_ACTORS = "actors"; private static final String TABLE_DIRECTOR = "director"; private static final String TABLE_TYPE = "type"; private static final String TABLE_ICON = "icon";
4.實現onCreate方法,編寫SQL語句,建立表
@Override public void onCreate(SQLiteDatabase db) { this.db = db; StringBuilder builder = new StringBuilder(); builder.append("create table if not exists "); builder.append(TABLE_NAME); builder.append("("); builder.append(TABLE_ID).append(" Integer primary key autoincrement, "); builder.append(TABLE_VIDEOID).append(" Integer, "); builder.append(TABLE_ICON).append(" Integer, "); builder.append(TABLE_URL).append(" varchar(50), "); builder.append(TABLE_TITLE).append(" varchar(30), "); builder.append(TABLE_CONTENT).append(" varchar(50) "); builder.append(" ) "); db.execSQL(builder.toString()); }
5 實現onUpgrade方法,當版本升級時調用
/** * 版本更新 */ @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { db.execSQL(" DROP TABLE IF EXISTS " + TABLE_NAME ); onCreate(db); }
6.編寫查詢、刪除、更新等操作方法。
/** * 查詢所有資料 * @return */ public Cursor query(){ SQLiteDatabase db = getReadableDatabase(); //擷取Corsor Cursor c = db.query(TABLE_NAME, null, null, null, null, null, null); return c; } /** * 根據id尋找資料 * @param id * @return */ public Cursor queryById(int videoId){ SQLiteDatabase db = getReadableDatabase(); Cursor c = db.query(TABLE_NAME, new String[]{TABLE_VIDEOID}, "videoId=?", new String[]{String.valueOf(videoId)}, null, null, null); return c; } /** * 根據唯一標識_ID 來刪除資料 * @param id */ public void delete(int id){ SQLiteDatabase db = getWritableDatabase(); System.out.println(">>>>>>>>>>>>>>>>>>>>>>>>>>"+db); db.delete(TABLE_NAME, "_ID=?", new String[]{String.valueOf(id)}); } /** * 插入方法 * @param values插入值 */ public void insert(ContentValues values){ SQLiteDatabase db = getWritableDatabase(); db.insert(TABLE_NAME, null, values); db.close(); }
7.關閉資料庫的方法
/** * 關閉資料庫 */ public void close(){ if(db != null){ db.close(); } }
SQLite資料庫淺談