android studio数据存储建立SQLite数据库实现增删查改
作者:wow_awsl_qwq 发布时间:2023-11-29 17:11:42
标签:vandroid,studio,数据存储,SQLite,数据库,增,删,查,改
实验目的:
分别使用sqlite3
工具和Android
代码的方式建立SQLite
数据库。在完成建立数据库的工作后,编程实现基本的数据库操作功能,包括数据的添加、删除和更新。
实验要求:
1.创建一个学生管理的应用,基本信息包含学生姓名,班级,学号。采用数据库存储这些信息。
2.应用应该至少包含信息录入和删除功能。
3.数据显示考虑采用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("成功添加数据,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("数据库中没有数据");
return;
}
String t="数据库:\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("已删除所有数据!");
}
});
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()+"的数据" + (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("成功更新数据,"+String.valueOf(n)+"条");
}
}
});
}
@Override
protected void onStop() {
super.onStop();
dbAdapter.close();
}
}
来源:https://blog.csdn.net/qq_42641977/article/details/121970828
0
投稿
猜你喜欢
- 本文介绍了Android多渠道打包的方法步骤,分享给大家,具体如下:1.生成签名文件点击 Build -> Generate Sign
- 面试题一:判断下列程序运行结果package String_test;public class test_1 { public static
- 使用java制作一款简单的扫雷游戏,供大家参考,具体内容如下import java.util.*;public class nephelok
- 传统方式克隆羊问题现在有一只羊 tom,姓名为: tom,年龄为:1,颜色为:白色,请编写程序创建和 tom羊属性完全相同的10只羊。传统方
- 在有些需求中会遇到,当鼠标滑过某个UI物体上方时,为了提醒用户该物体是可以交互时,我们需要添加一个动效和提示音。这样可以提高产品的体验感。解
- 本文实例讲述了winform用datagridview制作课程表的方法。分享给大家供大家参考。具体分析如下:课程表的最终效果如下图所示:具体
- 1>方法一之前在配置 Maven 的 settings.xml 时,都会设置 mirror 节点,例如:<mirrors>
- 概述java.lang.String 类代表字符串。Java程序中所有的字符串文字(例如"abc" )都可以被看作是实现
- 项目前端由于采用Extjs4,列表分页需要返回三个参数:totalCount(记录总数)、start(开始位置)、limit(每页条数)。由
- 概述RocketMQ 支持发送延迟消息,但不支持任意时间的延迟消息的设置,仅支持内置预设值的延迟时间间隔的延迟消息;预设值的延迟时间间隔为:
- 泛型与类型擦除泛型,JDK 1.5新特性,本质是参数化类型(Parametersized Type) 的应用,即所操作的数据类型被指定为一个
- 本文实例分析了C#中Convert.ToString和ToString的区别,对于初学者来说是很有必要加以熟练掌握的。具体分析如下:1.Co
- 本文介绍了Spring Boot + MyBatis读写分离,有需要了解Spring+MyBatis读写分离的朋友可参考。希望此文章对各位有
- ID说明 设备唯一标识符(UDID):设备唯一硬件标识,设备生产时根据特定的硬件信息生成,可用于设备的生产环境及合法性校验。不对第
- 经过测试 将resultMap="java.lang.Integer"改成resultType="java.l
- 实验目的在C#和Rest/Restful以及其它的Web服务交互过程中,大量使用到JSON传递数据,如何快捷的转化C#对象到JSON和转化J
- 如下:public static void CreateConfig(){ //c#可以添加内置的app.conf
- 本文实例讲述了C#控件闪烁的解决方法。分享给大家供大家参考。具体分析如下:如果你在Form中绘图的话,不论是不是采用的双缓存,都会看到图片在
- jQuery的方法连缀使用起来非常方便,可以简化语句,让代码变得清晰简洁。那C#的类方法能不能也实现类似的功能呢?基于这样的疑惑,研究了一下
- forward_list 概述forward_list 是 C++ 11 新增的容器,它的实现为单链表。forward_list 是支持从容