当前位置:网站首页>Android学习 | 08.SQLiteOpenHelper
Android学习 | 08.SQLiteOpenHelper
2022-08-03 05:22:00 【M_Nobody】
1.SQLiteOpenHelper是什么
SQLiteOpenHelper是android系统提供的用于创建及操作数据库的工具类。该类中提供了创建、升级、降级时的回调方法,对应onCreate(),onUpgrade(),onDowngrade()。在使用时可以根据app功能进行覆写相应的方法,从而实现正确的存储数据。
2.案例:输入信息保存到数据库,实现增删改查
页面效果:
视图:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="@dimen/item_layout_height"
android:orientation="horizontal">
<TextView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:text="@string/name"
android:gravity="center"
android:textSize="@dimen/common_font_size"
android:textColor="@color/black" />
<EditText
android:id="@+id/et_name"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:layout_marginTop="5dp"
android:layout_marginBottom="5dp"
android:background="@drawable/editext_selector"
android:hint="@string/input_name"
android:inputType="text"
android:maxLength="6"
android:textColor="@color/black"
android:textColorHint="@color/grey"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="@dimen/item_layout_height"
android:orientation="horizontal">
<TextView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:text="@string/age"
android:gravity="center"
android:textSize="@dimen/common_font_size"
android:textColor="@color/black" />
<EditText
android:id="@+id/et_age"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginTop="5dp"
android:layout_marginBottom="5dp"
android:layout_weight="1"
android:background="@drawable/editext_selector"
android:hint="@string/input_age"
android:inputType="number"
android:maxLength="6"
android:textColor="@color/black"
android:textColorHint="@color/grey"
android:textSize="@dimen/common_font_size" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="@dimen/item_layout_height"
android:orientation="horizontal">
<TextView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:text="@string/height"
android:gravity="center"
android:textSize="@dimen/common_font_size"
android:textColor="@color/black" />
<EditText
android:id="@+id/et_height"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginTop="5dp"
android:layout_marginBottom="5dp"
android:layout_weight="1"
android:background="@drawable/editext_selector"
android:hint="@string/input_height"
android:inputType="number"
android:maxLength="6"
android:textColor="@color/black"
android:textColorHint="@color/grey"
android:textSize="@dimen/common_font_size" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="@dimen/item_layout_height"
android:orientation="horizontal">
<TextView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:text="@string/weight"
android:gravity="center"
android:textSize="@dimen/common_font_size"
android:textColor="@color/black" />
<EditText
android:id="@+id/et_weight"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginTop="5dp"
android:layout_marginBottom="5dp"
android:layout_weight="1"
android:background="@drawable/editext_selector"
android:hint="@string/input_weight"
android:inputType="number"
android:maxLength="6"
android:textColor="@color/black"
android:textColorHint="@color/grey"
android:textSize="@dimen/common_font_size" />
</LinearLayout>
<CheckBox
android:id="@+id/ck_married"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/married"
android:textSize="@dimen/common_font_size"/>
<Button
android:id="@+id/btn_save"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="添加"
android:textColor="@color/black"
android:textSize="@dimen/common_font_size" />
<Button
android:id="@+id/btn_delete"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="删除"
android:textColor="@color/black"
android:textSize="@dimen/common_font_size" />
<Button
android:id="@+id/btn_update"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="修改"
android:textColor="@color/black"
android:textSize="@dimen/common_font_size" />
<Button
android:id="@+id/btn_query"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="查询"
android:textColor="@color/black"
android:textSize="@dimen/common_font_size" />
</LinearLayout>
对应java文件:
- 获取组件ID值,设置onClick方法
- 在生命周期的onStart()中获得帮助器实例,打开数据库的读写连接。在onStop()中关闭帮助器的连接
- 在onClick()方法中使用switch根据用户选择的不同功能返回Toast(在符合条件的情况下:例如添加的数据至少为一条的条件为true)。
package com.example.chapter06; import androidx.appcompat.app.AppCompatActivity; import android.os.Bundle; import android.util.Log; import android.view.View; import android.widget.CheckBox; import android.widget.EditText; import android.widget.Toast; import com.example.chapter06.database.UserDBHelper; import com.example.chapter06.enity.User; import com.example.chapter06.util.ToastUtil; import java.util.List; public class SQLiteHelperActivity extends AppCompatActivity implements View.OnClickListener { private EditText et_name; private EditText et_age; private EditText et_height; private EditText et_weight; private CheckBox ck_married; private UserDBHelper mHelper; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_sqlite_helper); et_name = findViewById(R.id.et_name); et_age = findViewById(R.id.et_age); et_height = findViewById(R.id.et_height); et_weight = findViewById(R.id.et_weight); ck_married = findViewById(R.id.ck_married); findViewById(R.id.btn_save).setOnClickListener(this); findViewById(R.id.btn_delete).setOnClickListener(this); findViewById(R.id.btn_update).setOnClickListener(this); findViewById(R.id.btn_query).setOnClickListener(this); } @Override protected void onStart() { super.onStart(); // 获得数据库帮助器的实例 mHelper = UserDBHelper.getInstance(this); // 打开数据库帮助器的读写连接 mHelper.openWriteLink(); mHelper.openReadLink(); } @Override protected void onStop() { super.onStop(); mHelper.closeLink(); } @Override public void onClick(View view) { String name = et_name.getText().toString(); String age = et_age.getText().toString(); String height = et_height.getText().toString(); String weight = et_weight.getText().toString(); User user = null; switch (view.getId()) { case R.id.btn_save: user = new User(name, Integer.parseInt(age), Long.parseLong(height), Float.parseFloat(weight), ck_married.isChecked()); if (mHelper.insert(user) > 0) { ToastUtil.show(this,"添加成功"); } break; case R.id.btn_delete: if (mHelper.deleteByName(name) > 0) { ToastUtil.show(this,"删除成功"); } break; case R.id.btn_update: user = new User(name, Integer.parseInt(age), Long.parseLong(height), Float.parseFloat(weight), ck_married.isChecked()); if (mHelper.update(user)> 0) { ToastUtil.show(this,"修改成功"); } break; case R.id.btn_query: List<User> list = mHelper.quertByName(name); for (User u : list) { Log.d("ning", u.toString()); } break; } } }
数据库帮助器类:
- 定义数据库名、表名、数据库版本以及帮助器、读写连接
- 用super访问和调用所在对象的父对象的变量
- 利用单例模式获取数据库帮助器的唯一实例。解释一下getInstance():这是单例模式,一般用于比较大,复杂的对象,只初始化一次,应该还有一个 private的构造函数,使得不能用 new来实例化对象,只能调用getInstance方法来得到对象,而getInstance保证了每次调用都返回相同的对象。
- 定义开关读写连接的方法
- 在生命周期的onCreate()阶段运行sql语句创建数据库
- 增删改查四个方法
package com.example.chapter06.database;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import com.example.chapter06.SQLiteHelperActivity;
import com.example.chapter06.enity.User;
import java.util.ArrayList;
import java.util.List;
public class UserDBHelper extends SQLiteOpenHelper {
private static final String DB_NAME = "user.db";
private static final String TABLE_NAME = "user_info";
private static final int DB_VERSION = 1;
private static UserDBHelper mHelper = null;
private SQLiteDatabase mRDB = null;
private SQLiteDatabase mWDB = null;
private UserDBHelper(Context context) {
super(context, DB_NAME, null, DB_VERSION);
}
//利用单例模式获取数据库帮助器的唯一实例
public static UserDBHelper getInstance(Context context) {
if (mHelper == null) {
mHelper = new UserDBHelper(context);
}
return mHelper;
}
// 打开数据库的读连接
public SQLiteDatabase openReadLink() {
if (mWDB ==null || !mWDB.isOpen()) {
mWDB = mHelper.getReadableDatabase();
}
return mWDB;
}
// 打开数据库的写连接
public SQLiteDatabase openWriteLink() {
if (mRDB ==null || !mRDB.isOpen()) {
mRDB = mHelper.getWritableDatabase();
}
return mRDB;
}
//关闭数据库连接
public void closeLink() {
if (mRDB != null && mRDB.isOpen()) {
mRDB.close();
mRDB = null;
}
if (mWDB != null && mWDB.isOpen()) {
mWDB.close();
mWDB = null;
}
}
// 创建数据库,执行建表语句
@Override
public void onCreate(SQLiteDatabase db) {
String sql = "CREATE TABLE IF NOT EXISTS " + TABLE_NAME +" (" +
"_id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL," +
"name VARCHAR NOT NULL," +
"age INTEGER NOT NULL," +
"height LONG NOT NULL," +
"weight FLOAT NOT NULL," +
"married INTEGER NOT NULL);";
db.execSQL(sql);
}
@Override
public void onUpgrade(SQLiteDatabase db, int i, int i1) {
}
public long insert (User user) {
ContentValues values = new ContentValues();
values.put("name",user.name);
values.put("age",user.age);
values.put("height",user.height);
values.put("weight",user.weight);
values.put("married",user.married);
return mWDB.insert(TABLE_NAME, null, values);
}
public long deleteByName(String name) {
// 删除所有
// mWDB.delete(TABLE_NAME,"1=1", null);
return mWDB.delete(TABLE_NAME, "name=?", new String[]{name});
}
public long update(User user) {
ContentValues values = new ContentValues();
values.put("name",user.name);
values.put("age",user.age);
values.put("height",user.height);
values.put("weight",user.weight);
values.put("married",user.married);
return mWDB.update(TABLE_NAME, values, "name=?", new String[]{user.name});
}
public List<User> quertByName(String name) {
List<User> list = new ArrayList<>();
// 执行记录查询动作,该语句返回结果集的游标
Cursor cursor = mRDB.query(TABLE_NAME, null, "name=?", new String[]{name}, null, null, null);
// 循环取出游标指向的每条记录
while (cursor.moveToNext()) {
User user = new User();
user.id = cursor.getInt(0);
user.name = cursor.getString(1);
user.age = cursor.getInt(2);
user.height = cursor.getLong(3);
user.weight = cursor.getFloat(4);
// SQLite没有布尔类型,用0表示false,用1表示true
user.married = (cursor.getInt(5) == 0) ? false : true;
list.add(user);
}
return list;
}
}
User类:
定义变量,返回变量的值
package com.example.chapter06.enity;
public class User {
public int id;
public String name;
public int age;
public long height;
public float weight;
public boolean married;
public User() {
}
public User(String name, int age, long height, float weight, boolean married) {
this.name = name;
this.age = age;
this.height = height;
this.weight = weight;
this.married = married;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", name='" + name + '\'' +
", age=" + age +
", height=" + height +
", weight=" + weight +
", married=" + married +
'}';
}
}
ToastUtil.java:
根据上下文的内容弹出toast
package com.example.chapter06.util;
import android.content.Context;
import android.widget.Toast;
public class ToastUtil {
public static void show(Context ctx, String desc) {
Toast.makeText(ctx, desc, Toast.LENGTH_SHORT).show();
}
}
最终效果可在数据库中查看:
边栏推荐
猜你喜欢
随机推荐
【DC-5靶场渗透】
浅谈函数递归汉诺塔
【DC-4靶场渗透】
【DC-2靶场渗透】
嵌入式实验二注意点
C语言简单实现扫雷小游戏
mysql 客户端SSL错误2026 (HY000)
玩转Markdown(2) —— 抽象语法树的提取与操纵
7.16(6)
动态调整web主题(2) 萃取篇
用iPhone前摄3D人像建模,Meta:我看行
软件测试 -- 入门 1 软件测试是什么?
【数组】arr,&arr,arr+1,&arr+1以及内存单元的占用
中国生物反应器行业发展现状及前景规划分析报告报告2022~2028年
Greetings(状压DP,枚举子集转移)
Sqli-labs-master shooting range 1-23 customs clearance detailed tutorial (basic)
【CSRF,SSRF,XXE,PHP反序列化,Burpsuite】
中国磷化铟晶圆行业发展前景与投资规划分析报告2022~2028年
Haproxy服务监控
用C语言来实现扫雷小游戏