Android中SQLite数据库增删改查/使用ListView显示数据库内容(有完整源码)
创始人
2024-01-21 09:29:59
0

android作业笔记

文章目录

  • 效果展示
  • 一、前言
    • 源码获取
    • 实验功能描述
    • 注意事项
    • 实现步骤
  • 二、代码展示
    • activity_main.xml布局文件
    • MyOpenHelper.java
    • MainActivity.java
    • List_item.xml
  • 三、(补充)ListView实现数据列表显示

效果展示

编写SQLite数据库相关操作的代码,实现下图中的功能

SQLite展示

一、前言

源码获取

先上源码:https://gitee.com/meng-fanyang/SQLiteWork
在这里插入图片描述
里边有三个分支,对应这不同的写法:

  1. master主分支是写的可以说是最完善的了
  2. nogood_branch分支把该有的功能都实现了,但是代码冗余度较大
  3. AddListView是存有刚能点击全部显示在ListView显示数据
    在这里插入图片描述

实验功能描述

  1. 使用安卓自带的SQLite数据库实现数据的增删改查
  2. 点击添加数据只显示新添加的和连续点击添加的
  3. 全部删除时数据不再显示
  4. 使用ListView控件显示数据

注意事项

  1. 表的主键必须是 == _id == (_id_id_id重要的事情说三遍),具体解释下次更新(我的源码中建表第一次写错了,没有换,请读者自己建立对的表)
  2. 使用了SimpleCursorAdapter来方便数据库和listView之间的数据传递
  3. 代码中很多是注释掉的,有一部分是用来在控制台的Logcat输出的,可以在调试时查看具体情况

实现步骤

创建数据库和数据表的步骤

  1. 新建类继承SQLiteOpenHelper
  2. 实现构造方法
  3. 重写onCreate方法
  4. 重写onUpgrade方法
  5. 实例化SQLiteOpenHelper 的子类对象- MyOpenHelper;
  6. 实现点击事件

二、代码展示

activity_main.xml布局文件



MyOpenHelper.java

package com.example.sqlitework;import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;public class MyOpenHelper extends SQLiteOpenHelper {//上面的建表建错了,要有下面的这建表,必须主键为_id,_id,_id重要的事情说三遍。这里设置主键_id自增private final static String SQL_PERSON_id="create table person_id" +"(_id integer primary key autoincrement,name text,age text,height text)";//通过调用父类的构造方法完成数据库的创建MyOpenHelper(Context context){super(context,"Allperson.db",null,1);}@Overridepublic void onCreate(SQLiteDatabase sqLiteDatabase) {//在本方法中完成数据库对象的创建sqLiteDatabase.execSQL(SQL_PERSON);}@Overridepublic void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {//在本方法中进行数据库的升级操作}
}

MainActivity.java

这一步部分太长了,就先不贴全部了,全部的在上边gitee仓库中可以查看

public class MainActivity extends AppCompatActivity {//先定义一些全局的,每次都要用的private ListView viewById;private SimpleCursorAdapter adapter;
//    private Cursor cursor;//SimpleCursorAdapter所需要的参数String from[] = new String[]{"_id", "name", "age", "height"};int[] to = new int[]{R.id.tv_id, R.id.tv_name, R.id.tv_age, R.id.tv_height};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);MyOpenHelper myOpenHelper = new MyOpenHelper(this);//打开数据库SQLiteDatabase sqLiteDatabase = myOpenHelper.getReadableDatabase();//关闭数据库sqLiteDatabase.close();viewById = (ListView) findViewById(R.id.LV);}/*** 插入数据* @param view*/public void addData(View view){Log.d(MainActivity.class.getSimpleName(),"=============接收到插入数据点击==============");count = count+1;nameText = (EditText) findViewById(R.id.name);ageText = (EditText) findViewById(R.id.age);heightText = (EditText) findViewById(R.id.height);String Name = nameText.getText().toString();String Age = ageText.getText().toString();String Height = heightText.getText().toString();MyOpenHelper myOpenHelper = new MyOpenHelper(this);SQLiteDatabase sqLiteDatabase = null;try {//打开数据库sqLiteDatabase = myOpenHelper.getReadableDatabase();//开启事务sqLiteDatabase.beginTransaction();//执行插入操作ContentValues contentValues = new ContentValues();contentValues.put("name", Name);contentValues.put("age", Age);contentValues.put("height", Height);sqLiteDatabase.insert("person_id",null,contentValues);Toast.makeText(this, "Successful insert data", Toast.LENGTH_SHORT).show();sqLiteDatabase.setTransactionSuccessful();//提交sqLiteDatabase.endTransaction();//关闭事务} catch (Exception e) {e.printStackTrace();}finally {String limit = String.valueOf(count);Cursor cursor = sqLiteDatabase.query("person_id", new String[]{"_id","name","age","height"},null,null,null,null,"_id desc" , limit);
//        db.execSQL("select * from person_id order by _id desc limit 0,i;");  //此处是直接执行SQL语句adapter = new SimpleCursorAdapter(this, R.layout.list_item, cursor, from, to, CursorAdapter.FLAG_REGISTER_CONTENT_OBSERVER);viewById.setAdapter(adapter);if(sqLiteDatabase != null){//关闭数据库sqLiteDatabase.close();}}}

List_item.xml

这是用来分列展示




三、(补充)ListView实现数据列表显示

要将数据库中的数据列表显示在屏幕上,我们要使用ListView这个控件,当用户从数据库中取出数据时,要将数据绑定到显示控件上,如何绑定呢,我们需要创建适配器进行绑定,创建适配器有两种方式:
第一种是用SimpleAdapter创建(要求绑定的数据是List>数据类型)
第二种是用SimpleCursorAdapter创建(要求绑定的数据是Cursor数据类型)
注意:使用第二种方式在获取数据集合时必须指定主键"_id"
Android采用ListView实现数据列表显示

参考文章:
Android开发使用SQLite数据库和Listview实现数据的存储与展示
Android创建SQLite数据库和表
android中sqlite数据库的基本使用和添加多张表
Android——ListView与数据库的结合

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
一帆风顺二龙腾飞三阳开泰祝福语... 本篇文章极速百科给大家谈谈一帆风顺二龙腾飞三阳开泰祝福语,以及一帆风顺二龙腾飞三阳开泰祝福语结婚对应...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
美团联名卡审核成功待激活(美团... 今天百科达人给各位分享美团联名卡审核成功待激活的知识,其中也会对美团联名卡审核未通过进行解释,如果能...