前言
使用Android Studio工具,實現SQLite數據庫的CRUD。
附上項目鏈接🎈
- Gitee: MySQLite_Demo
- Git:MySQLite_Demo
基本功能
- 增加 :
輸入相應姓名、年齡,點擊“添加”按鈕,數據插入到數據庫並在下方展示; - 修改 :
點擊相應記錄,重新輸入要修改的數據,點擊“添加”按鈕,數據庫中記錄數據得到修改,並在下方展示; - 刪除 :
點擊相應記錄,再點擊“刪除”按鈕,數據庫中記錄得到刪除; - 查詢 :
在操作下方,以一行一條記錄的方式展示數據庫中數據。
開發參考
參考blog: SQLite數據庫編程
項目運行效果截圖
-
進入界面
-
添加
-
修改
-
刪除
項目核心代碼🔑
- DbHelper:
/*
SQLite數據庫打開助手DbHelper作爲抽象類SQLiteOpenHelper的子類
需要重寫2個抽象方法onCreate()和onUpgrade()
*/
public class DbHelper extends SQLiteOpenHelper{
public static final String TB_NAME = "friends"; //表名
//構造方法:第1參數爲上下文,第2參數庫庫名,第3參數爲遊標工廠,第4參數爲版本
public DbHelper(Context context, String dbname, CursorFactory factory, int version) {
super(context, dbname, factory, version); //創建或打開數據庫
}
@Override
public void onCreate(SQLiteDatabase db) {
//當表不存在時,創建表;第一字段爲自增長類型
db.execSQL("CREATE TABLE IF NOT EXISTS " +
TB_NAME + "( _id integer primary key autoincrement," +
"name varchar," + "age integer"+ ")");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// 執行SQL命令
db.execSQL("DROP TABLE IF EXISTS " + TB_NAME);
onCreate(db);
}
}
- MyDAO:
/*
本類MyDAO調用了打開數據庫的助手類DbHelper
本類MyDAO提供的CRUD針對數據庫test.db的表friends
查詢數據庫表所有記錄的方法:allQuery()
插入記錄的方法:insertInfo(String name,int age)
刪除記錄的方法:deleteInfo(String selId)
修改記錄方法:updateInfo(String name,int age,String selId)
*/
public class MyDAO {
private SQLiteDatabase myDb; //類的成員
private DbHelper dbHelper; //類的成員
public MyDAO(Context context) { //構造方法,參數爲上下文對象
//第1參數爲上下文,第2參數爲數據庫名
dbHelper = new DbHelper(context,"test.db",null,1);
}
public Cursor allQuery(){ //查詢所有記錄
myDb = dbHelper.getReadableDatabase();
return myDb.rawQuery("select * from friends",null);
}
public int getRecordsNumber(){ //返回數據表記錄數
myDb = dbHelper.getReadableDatabase();
Cursor cursor= myDb.rawQuery("select * from friends",null);
return cursor.getCount();
}
public void insertInfo(String name,int age){ //插入記錄
myDb = dbHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name", name);
values.put("age", age);
long rowid=myDb.insert(DbHelper.TB_NAME, null, values);
if(rowid==-1)
Log.i("myDbDemo", "數據插入失敗!");
else
Log.i("myDbDemo", "數據插入成功!"+rowid);
}
public void deleteInfo(String selId){ //刪除記錄
String where = "_id=" + selId;
int i = myDb.delete(DbHelper.TB_NAME, where, null);
if (i > 0)
Log.i("myDbDemo", "數據刪除成功!");
else
Log.i("myDbDemo", "數據未刪除!");
}
public void updateInfo(String name,int age,String selId){ //修改記錄
//方法中的第三參數用於修改選定的記錄
ContentValues values = new ContentValues();
values.put("name", name);
values.put("age", age);
String where="_id="+selId;
int i=myDb.update(DbHelper.TB_NAME, values, where, null);
//上面幾行代碼的功能可以用下面的一行代碼實現
//myDb.execSQL("update friends set name = ? ,age = ? where _id = ?",new Object[]{name,age,selId});
if(i>0)
Log.i("myDbDemo","數據更新成功!");
else
Log.i("myDbDemo","數據未更新!");
}
}
- MainActivity程序代碼:
/*
本程序中對數據庫的插入操作和查詢,使用了MyDAO類的相關方法
首次運行時,增加2條記錄並使用ListView控件顯示出來
*/
public class MainActivity extends Activity implements View.OnClickListener{
private MyDAO myDAO; //數據庫訪問對象
private ListView listView;
private List<Map<String,Object>> listData;
private Map<String,Object> listItem;
private SimpleAdapter listAdapter;
private EditText et_name; //數據表包含3個字段,第1字段爲自增長類型
private EditText et_age;
private String selId=null; //選擇項id
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button bt_add= (Button) findViewById(R.id.bt_add);bt_add.setOnClickListener(this);
Button bt_modify=(Button)findViewById(R.id.bt_modify);bt_modify.setOnClickListener(this);
Button bt_del=(Button)findViewById(R.id.bt_del);bt_del.setOnClickListener(this);
et_name=(EditText)findViewById(R.id.et_name);
et_age=(EditText)findViewById(R.id.et_age);
myDAO = new MyDAO(this); //創建數據庫訪問對象
if(myDAO.getRecordsNumber()==0) { //防止重複運行時重複插入記錄
myDAO.insertInfo("tian", 20); //插入記錄
myDAO.insertInfo("wang", 40); //插入記錄
}
displayRecords(); //顯示記錄
}
public void displayRecords(){ //顯示記錄方法定義
listView = (ListView)findViewById(R.id.listView);
listData = new ArrayList<Map<String,Object>>();
Cursor cursor = myDAO.allQuery();
while (cursor.moveToNext()){
int id=cursor.getInt(0); //獲取字段值
String name=cursor.getString(1);
//int age=cursor.getInt(2);
int age=cursor.getInt(cursor.getColumnIndex("age"));//推薦此種方式
listItem=new HashMap<String,Object>(); //必須在循環體裏新建
listItem.put("_id", id); //第1參數爲鍵名,第2參數爲鍵值
listItem.put("name", name);
listItem.put("age", age);
listData.add(listItem); //添加一條記錄
}
listAdapter = new SimpleAdapter(this,
listData,
R.layout.list_item, //自行創建的列表項佈局
new String[]{"_id","name","age"},
new int[]{R.id.tv_id,R.id.tvname,R.id.tvage});
listView.setAdapter(listAdapter); //應用適配器
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { //列表項監聽
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
Map<String,Object> rec= (Map<String, Object>) listAdapter.getItem(position); //從適配器取記錄
et_name.setText(rec.get("name").toString()); //刷新文本框
et_age.setText(rec.get("age").toString());
Log.i("ly",rec.get("_id").toString());
selId=rec.get("_id").toString(); //供修改和刪除時使用
}
});
}
@Override
public void onClick(View v) { //實現的接口方法
if(selId!=null) { //選擇了列表項後,可以增加/刪除/修改
String p1 = et_name.getText().toString().trim();
int p2 = Integer.parseInt(et_age.getText().toString());
switch (v.getId()){
case R.id.bt_add:
myDAO.insertInfo(p1,p2);
break;
case R.id.bt_modify:
myDAO.updateInfo(p1,p2,selId);
Toast.makeText(getApplicationContext(),"更新成功!",Toast.LENGTH_SHORT).show();
break;
case R.id.bt_del:
myDAO.deleteInfo(selId);
Toast.makeText(getApplicationContext(),"刪除成功!",Toast.LENGTH_SHORT).show();
et_name.setText(null);et_age.setText(null); selId=null; //提示
}
}else{ //未選擇列表項
if(v.getId()==R.id.bt_add) { //單擊添加按鈕
String p1 = et_name.getText().toString();
String p2=et_age.getText().toString();
if(p1.equals("")||p2.equals("")){ //要求輸入了信息
Toast.makeText(getApplicationContext(),"姓名和年齡都不能空!",Toast.LENGTH_SHORT).show();
}else{
myDAO.insertInfo(p1, Integer.parseInt(p2)); //第2參數轉型
}
} else{ //單擊了修改或刪除按鈕
Toast.makeText(getApplicationContext(),"請先選擇記錄!",Toast.LENGTH_SHORT).show();
}
}
displayRecords();//刷新ListView對象
}
}
附上項目鏈接🎈
- Gitee: MySQLite_Demo
- Git:MySQLite_Demo
項目總結✔
本次項目是在已有的項目教程下,一步步實現,實現的過程較簡單,但是其中的機制涉及到了數據庫的部分操作,包括增刪改查;本程序中對數據庫的插入操作和查詢,使用了MyDAO類的相關方法,首次運行時,增加2條記錄並使用ListView控件顯示出來。