Android Studio運用MySQLite

前言

使用Android Studio工具,實現SQLite數據庫的CRUD。

附上項目鏈接🎈

基本功能

  1. 增加
    輸入相應姓名、年齡,點擊“添加”按鈕,數據插入到數據庫並在下方展示;
  2. 修改
    點擊相應記錄,重新輸入要修改的數據,點擊“添加”按鈕,數據庫中記錄數據得到修改,並在下方展示;
  3. 刪除
    點擊相應記錄,再點擊“刪除”按鈕,數據庫中記錄得到刪除;
  4. 查詢
    在操作下方,以一行一條記錄的方式展示數據庫中數據。

開發參考

參考blog: SQLite數據庫編程

項目運行效果截圖

  1. 進入界面
    在這裏插入圖片描述

  2. 添加
    添加

  3. 修改
    修改

  4. 刪除
    刪除

項目核心代碼🔑

  1. 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);
    }
}
  1. 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","數據未更新!");
    }
}
  1. 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對象
    }
}

附上項目鏈接🎈

項目總結✔

本次項目是在已有的項目教程下,一步步實現,實現的過程較簡單,但是其中的機制涉及到了數據庫的部分操作,包括增刪改查;本程序中對數據庫的插入操作和查詢,使用了MyDAO類的相關方法,首次運行時,增加2條記錄並使用ListView控件顯示出來。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章