android?studio數(shù)據(jù)存儲建立SQLite數(shù)據(jù)庫實現(xiàn)增刪查改
實驗目的:
分別使用sqlite3工具和Android代碼的方式建立SQLite數(shù)據(jù)庫。在完成建立數(shù)據(jù)庫的工作后,編程實現(xiàn)基本的數(shù)據(jù)庫操作功能,包括數(shù)據(jù)的添加、刪除和更新。
實驗要求:
- 1.創(chuàng)建一個學生管理的應用,基本信息包含學生姓名,班級,學號。采用數(shù)據(jù)庫存儲這些信息。
- 2.應用應該至少包含信息錄入和刪除功能。
- 3.數(shù)據(jù)顯示考慮采用ListView。
實驗效果:

工程結構:

源代碼:
DBAdapter.java
package com.example.shiyan6_sqlite;
import android.annotation.SuppressLint;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
public class DBAdapter {
private static final String DB_NAME = "student.db";
private static final String DB_TABLE = "peopleinfo";
private static final int DB_VERSION = 1;
public static final String KEY_ID = "_id";
public static final String KEY_NAME = "name";
public static final String KEY_BANJI = "banji";
public static final String KEY_XUEHAO = "xuehao";
private SQLiteDatabase db;
private final Context context;
private DBOpenHelper dbOpenHelper;
public DBAdapter(Context _context) {
context = _context;
}
public void close() {
if(db !=null)
{
db.close();
db=null;
}
}
public void open() throws SQLiteException {
dbOpenHelper = new DBOpenHelper(context, DB_NAME, null, DB_VERSION);
try {
db = dbOpenHelper.getWritableDatabase();
}
catch (SQLiteException ex) {
db = dbOpenHelper.getReadableDatabase();
}
}
public long insert(People people) {
ContentValues newValues = new ContentValues();
newValues.put(KEY_NAME, people.Name);
newValues.put(KEY_BANJI, people.Banji);
newValues.put(KEY_XUEHAO, people.Xuehao);
return db.insert(DB_TABLE, null, newValues);
}
public People[] queryAllData() {
Cursor results = db.query(DB_TABLE, new String[] { KEY_ID, KEY_NAME, KEY_BANJI, KEY_XUEHAO},
null, null, null, null, null);
return ConvertToPeople(results);
}
public People[] queryOneData(long id) {
Cursor results = db.query(DB_TABLE, new String[] { KEY_ID, KEY_NAME, KEY_BANJI, KEY_XUEHAO},
KEY_ID + "=" + id, null, null, null, null);
return ConvertToPeople(results);
}
@SuppressLint("Range")
private People[] ConvertToPeople(Cursor cursor){
int resultCounts = cursor.getCount();
if (resultCounts == 0 || !cursor.moveToFirst()){
return null;
}
People[] peoples = new People[resultCounts];
for (int i = 0 ; i<resultCounts; i++){
peoples[i] = new People();
peoples[i].ID = cursor.getInt(0);
peoples[i].Name = cursor.getString(cursor.getColumnIndex(KEY_NAME));
peoples[i].Banji = cursor.getString(cursor.getColumnIndex(KEY_BANJI));
peoples[i].Xuehao = cursor.getString(cursor.getColumnIndex(KEY_XUEHAO));
cursor.moveToNext();
}
return peoples;
}
public long deleteAllData() {
return db.delete(DB_TABLE, null, null);
}
public long deleteOneData(long id) {
return db.delete(DB_TABLE, KEY_ID + "=" + id, null);
}
public long updateOneData(long id , People people){
ContentValues updateValues = new ContentValues();
updateValues.put(KEY_NAME, people.Name);
updateValues.put(KEY_BANJI, people.Banji);
updateValues.put(KEY_XUEHAO, people.Xuehao);
return db.update(DB_TABLE, updateValues, KEY_ID + "=" + id, null);
}
private static class DBOpenHelper extends SQLiteOpenHelper {
public DBOpenHelper(Context context, String name, CursorFactory factory, int version) {
super(context, name, factory, version);
}
private static final String DB_CREATE = "create table " +
DB_TABLE + " (" + KEY_ID + " integer primary key autoincrement, " +
KEY_NAME+ " text not null, " + KEY_BANJI+ " text not null," + KEY_XUEHAO + " text not null);";
@Override
public void onCreate(SQLiteDatabase _db) {
_db.execSQL(DB_CREATE);
}
@Override
public void onUpgrade(SQLiteDatabase _db, int _oldVersion, int _newVersion) {
_db.execSQL("DROP TABLE IF EXISTS " + DB_TABLE);
onCreate(_db);
}
}
}
People.java
package com.example.shiyan6_sqlite;
public class People {
public int ID = -1;
public String Name;
public String Banji;
public String Xuehao;
@Override
public String toString(){
String result = "";
result += "ID:" + this.ID + ",";
result += "姓名:" + this.Name + ",";
result += "班級:" + this.Banji + ", ";
result += "學號:" + this.Xuehao;
return result;
}
}
MainActivity.java
package com.example.shiyan6_sqlite;
import androidx.appcompat.app.AppCompatActivity;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
EditText e_xm,e_nl,e_sg,e_id;
TextView t_1;
Button b_add,b_allsee,b_clearsee,b_alldel,b_delid,b_seeid,b_updid;
DBAdapter dbAdapter;
SQLiteDatabase db;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
e_xm=findViewById(R.id.e_xm);
e_nl=findViewById(R.id.e_nl);
e_sg=findViewById(R.id.e_sg);
b_add=findViewById(R.id.b_add);
b_allsee=findViewById(R.id.b_allsee);
b_clearsee=findViewById(R.id.b_clearall);
b_alldel=findViewById(R.id.b_delall);
b_delid=findViewById(R.id.b_delid);
b_seeid=findViewById(R.id.b_seeid);
b_updid=findViewById(R.id.b_updid);
e_id=findViewById(R.id.e_id);
t_1=findViewById(R.id.t_1);
dbAdapter=new DBAdapter(this);
dbAdapter.open();
b_add.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
People t=new People();
t.Name=e_xm.getText().toString();
t.Banji=e_nl.getText().toString();
t.Xuehao=e_sg.getText().toString();
long colunm=dbAdapter.insert(t);
if (colunm == -1 ){
t_1.setText("添加過程錯誤!");
} else {
t_1.setText("成功添加數(shù)據(jù),ID:"+String.valueOf(colunm));
}
}
});
b_allsee.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
People [] peoples =dbAdapter.queryAllData();
if (peoples == null){
t_1.setText("數(shù)據(jù)庫中沒有數(shù)據(jù)");
return;
}
String t="數(shù)據(jù)庫:\n";
for(int i=0;i<peoples.length;++i){
t+=peoples[i].toString()+"\n";
}
t_1.setText(t);
}
});
b_clearsee.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
t_1.setText("");
}
});
b_alldel.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
dbAdapter.deleteAllData();
t_1.setText("已刪除所有數(shù)據(jù)!");
}
});
b_delid.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
int id=Integer.parseInt(e_id.getText().toString());
long result=dbAdapter.deleteOneData(id);
String msg = "刪除ID為"+e_id.getText().toString()+"的數(shù)據(jù)" + (result>0?"成功":"失敗");
t_1.setText(msg);
}
});
b_seeid.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
int id=Integer.parseInt(e_id.getText().toString());
People people[]=dbAdapter.queryOneData(id);
if(people==null){
t_1.setText("Id為"+id+"的記錄不存在!");
}
else{
t_1.setText("查詢成功:\n"+people[0].toString());
}
}
});
b_updid.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
int id=Integer.parseInt(e_id.getText().toString());
People t=new People();
t.Name=e_xm.getText().toString();
t.Banji=e_nl.getText().toString();
t.Xuehao=e_sg.getText().toString();
long n=dbAdapter.updateOneData(id,t);
if (n<0){
t_1.setText("更新過程錯誤!");
} else {
t_1.setText("成功更新數(shù)據(jù),"+String.valueOf(n)+"條");
}
}
});
}
@Override
protected void onStop() {
super.onStop();
dbAdapter.close();
}
}
到此這篇關于vandroid studio數(shù)據(jù)存儲建立SQLite數(shù)據(jù)庫實現(xiàn)增刪查改的文章就介紹到這了,更多相關數(shù)據(jù)存儲建立SQLite數(shù)據(jù)庫實現(xiàn)增刪查改內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- Android 通過SQLite數(shù)據(jù)庫實現(xiàn)數(shù)據(jù)存儲管理
- Android四種數(shù)據(jù)存儲的應用方式
- Android基礎教程數(shù)據(jù)存儲之文件存儲
- Android SharedPreferences實現(xiàn)數(shù)據(jù)存儲功能
- android使用SharedPreferences進行數(shù)據(jù)存儲
- Android開發(fā)教程之ContentProvider數(shù)據(jù)存儲
- 詳解Android的網(wǎng)絡數(shù)據(jù)存儲
- 5種Android數(shù)據(jù)存儲方式匯總
- 詳解Android數(shù)據(jù)存儲之SQLCipher數(shù)據(jù)庫加密
- Android 單例模式實現(xiàn)可復用數(shù)據(jù)存儲的詳細過程
相關文章
深入理解與運行Android Jetpack組件之ViewModel
ViewModel是Android Jetpack組件之一,是一種用于管理UI相關數(shù)據(jù)的架構組件,它能夠幫助開發(fā)者實現(xiàn)優(yōu)雅的數(shù)據(jù)驅動和生命周期管理,本文將深入淺出地介紹ViewModel的使用和原理,帶你一步步掌握這個強大的組件2023-08-08
Kotlin + Flow 實現(xiàn)Android 應用初始化任務啟動庫
這篇文章主要介紹了Kotlin + Flow 實現(xiàn)Android 應用初始化任務啟動庫的方法,幫助大家更好的理解和學習使用Android,感興趣的朋友可以了解下2021-03-03
一文理解Android系統(tǒng)中強指針的實現(xiàn)
因為Android中很多地方代碼是用C++編寫,為了能夠保證C++中指針能夠被正確的釋放,于是Android引入了其實在C++中已經(jīng)有的智能指針技術2021-10-10
Android DrawableTextView圖片文字居中顯示實例
在我們開發(fā)中,TextView設置Android:drawableLeft一定使用的非常多,但Drawable和Text同時居中顯示可能不好控制,小編想到通過自定義TextView實現(xiàn),具體詳情大家參考下本文2017-03-03
Android ApiDemo示例工程的創(chuàng)建
本文主要介紹Android ApiDemo示例工程的創(chuàng)建,這里SDK中的示例工程做了大致介紹,并說明如何創(chuàng)建ApiDemo 示例工程,有需要看自帶代碼的朋友可以參考下2016-09-09

