您好!欢迎来到源码码网

Android SQLite数据库操作想实例

  • 源码教程
  • 来源:源码码网
  • 编辑:admin
  • 时间:2021-02-20 19:30
  • 阅读:1203

Android SQLite数据库操作项目实例演示了使用 SQLiteOpenHelper 和 SQLiteDatabase 对数据库进行操作的过程,其运行效果如图 1 所示。

MyDbDemo界面

图 1  MyDbDemo界面

实例 MyDbDemo 使用 SQLiteOpenHelper 对象建立了数据库文件“mydb”,通过 SQLiteDatabase 对象对该数据库进行数据的查询、插入、修改和删除操作,并显示到 ListView 组件中。

实例 MyDbDemo 的运行界面实际上由两个 XML 文件组成,分别是 main.xml 和 listview.xml。其中 main.xml 文件的代码如下:


  1. <?xml version="1.0" encoding="utf-8"?>


  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

  3. android:layout_width="fill_parent"

  4. android:layout_height="fill_parent"

  5. android:orientation="vertical">


  6. <LinearLayout

  7. android:layout_width="fill_parent"

  8. android:layout_height="wrap_content"

  9. android:addStatesFromChildren="true">


  10. <TextView

  11. android:layout_width="wrap_content"

  12. android:layout_height="wrap_content"

  13. android:text="姓名"

  14. android:textColor="?android:attr/textColorSecondary" />


  15. <EditText

  16. android:id="@+id/et_name"

  17. android:layout_width="wrap_content"

  18. android:layout_height="wrap_content"

  19. android:layout_weight="1"

  20. android:singleLine="true" />

  21. </LinearLayout>


  22. <LinearLayout

  23. android:layout_width="fill_parent"

  24. android:layout_height="wrap_content"

  25. android:addStatesFromChildren="true">


  26. <TextView

  27. android:layout_width="wrap_content"

  28. android:layout_height="wrap_content"

  29. android:text="年龄"

  30. android:textColor="?android:attr/textColorSecondary" />


  31. <EditText

  32. android:id="@+id/et_age"

  33. android:layout_width="wrap_content"

  34. android:layout_height="wrap_content"

  35. android:layout_weight="1"

  36. android:singleLine="true" />

  37. </LinearLayout>


  38. <LinearLayout

  39. android:layout_width="fill_parent"

  40. android:layout_height="wrap_content"

  41. android:addStatesFromChildren="true"

  42. android:gravity="center">


  43. <Button

  44. android:id="@+id/bt_add"

  45. android:layout_width="wrap_content"

  46. android:layout_height="wrap_content"

  47. android:onClick="addbutton"

  48. android:text="添加"></Button>


  49. <Button

  50. android:id="@+id/bt_modify"

  51. android:layout_width="wrap_content"

  52. android:layout_height="wrap_content"

  53. android:onClick="updatebutton"

  54. android:text="修改"></Button>


  55. <Button

  56. android:id="@+id/bt_del"

  57. android:layout_width="wrap_content"

  58. android:layout_height="wrap_content"

  59. android:onClick="updatebutton"

  60. android:text="删除"></Button>


  61. <Button

  62. android:id="@+id/bt_query"

  63. android:layout_width="wrap_content"

  64. android:layout_height="wrap_content"

  65. android:onClick="querybutton"

  66. android:text="查询"></Button>

  67. </LinearLayout>


  68. <ListView

  69. android:id="@+id/listView"

  70. android:layout_width="fill_parent"

  71. android:layout_height="wrap_content"

  72. android:padding="5dip"></ListView>

  73. </LinearLayout>

由代码可见,main.xml 实际上实现的是如图 2 所示的效果。

main.xml运行界面

图 2  main.xml 界面

该布局中放置了两个 TextView、两个 EditText 和 4 个按钮,在按钮的下面是一个 ListView 组件,但是该 ListView 没有对显示效果进行任何的限制。

实例 MyDbDemo 中 listview.xml 文件的代码如下:

  1. <?xml version="1.0" encoding="utf-8"?>

  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

  3.     android:id="@+id/linear"

  4.     android:layout_width="wrap_content"

  5.     android:layout_height="wrap_content"

  6.     android:padding="5dip">


  7.     <TextView

  8.         android:id="@+id/tvID"

  9.         android:layout_width="80dp"

  10.         android:layout_height="wrap_content" />


  11.     <TextView

  12.         android:id="@+id/tvName"

  13.         android:layout_width="80dp"

  14.         android:layout_height="wrap_content" />


  15.     <TextView

  16.         android:id="@+id/tvAge"

  17.         android:layout_width="80dp"

  18.         android:layout_height="wrap_content" />

  19. </LinearLayout>

可见 listview.xml 布局中横向放置了三个 TextView 用于显示数据。

该实例实际的运行效果是使用 listview.xml 中的数据格式替换 main.xml 中 ListView 组件的数据格式后实现的。该效果通过 LayoutInflater 类的对象进行实现。

实例 MyDbDemo 中 AndroidManifest.xml 文件的代码如下:

  1. <?xml version="1.0" encoding="utf-8"?>

  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"

  3. package="introduction.android.mydbdemo"

  4. android:versionCode="1"

  5. android:versionName="1.0">


  6. <uses-sdk android:minSdkVersion="14" />

  7. <application

  8. android:allowBackup="true"

  9. android:icon="@mipmap/ic_launcher"

  10. android:label="@string/app_name"

  11. android:roundIcon="@mipmap/ic_launcher_round"

  12. android:supportsRtl="true"

  13. android:theme="@style/AppTheme">

  14. <activity android:name=".MainActivity">

  15. <intent-filter>

  16. <action android:name="android.intent.action.MAIN" />

  17. <category android:name="android.intent.category.LAUNCHER" />

  18. </intent-filter>

  19. </activity>

  20. </application>


  21. </manifest>

实例 MyDbDemo 中 SQLiteOpenHelper 的子类 dbHelper 的实现代码如下:

image.png

子类 dbHelper 重写了父类 SQLiteOpenHelper 的两个抽象方法 onCreate() 和 onUpgrade()。

在 onCreate() 方法中创建了一个名为 friends 的数据表,该数据表有 _id、name 和 age三个字段,其中 _id 为自增加主键。

onUpgrade() 方法实现了删除现有数据表并且重建的功能。

实例 MyDbDemo 中的主 Activity 所对应文件 MainActivity.java 的代码如下:

image.png

image.pngimage.pngimage.pngimage.pngimage.png

MainActivity 在 onCreate() 方法中调用 dbHelper 创建了数据库文件“mydb”,获取到该数据库的可写 SQLiteDatabase 对象,并将数据库中所有的数据显示到 listview 中。

MainActivity 为 main.xml 中的 4 个按钮分别添加按钮单击监视器并进行处理,通过 SQLiteDatabase 对象实现对数据库的 CRUD 操作。

其中:

  1. listAdapter = new SimpleAdapter(this, data,

  2. R.layout.listview,

  3. new String[]{"_id", "name", "age"},

  4. new int[]{R.id.tvID, R.id.tvName, R.id.tvAge});

  5. listview.setAdapter(listAdapter);


这几行代码通过 SimpleAdapter 将 listview.xml 文件中定义的 TextView 组件与 main.xml 中的 ListView 组件进行关联,这样就使 main.xml 中的 ListView 组件以 listview.xml 文件中定义的格式将数据显示出来。

  1. cursor = db.query(dbHelper.TB_NAME, null, null, null, null, null, "_id ASC");

  2. cursor.moveToFirst();

  3. while (!cursor.isAfterLast()) {

  4. String id = cursor.getString(0);

  5. String name = cursor.getString(1);

  6. String age = cursor.getString(2);

  7. item = new HashMap<String, Object>();

  8. item.put("_id", id);

  9. item.put("name", name);

  10. item.put("age", age);

  11. data.add(item);

  12. cursor.moveToNext();

  13. }


这几行代码从 friends 数据表中查询出所有数据,并按_id升序排列。

cursor.getString() 方法按照列将每条数据的对应字段分别取出来,通过 while 循环将所有数据保存到 data 中。

  1. listview.setOnItemClickListener(new AdapterView.OnItemClickListener() {

  2. @Override

  3. public void onItemClick(AdapterView<?> parent, View v, int position, long id) {

  4. // TODO Auto-generated method stub

  5. Map<String, Object> listItem = (Map<String, Object>) listview.getItemAtPosition(position);

  6. et_name.setText((String) listItem.get("name"));

  7. et_age.setText((String) listItem.get("age"));

  8. selId = (String) listItem.get("_id");

  9. Log.i("mydbDemo", "id=" + selId);

  10. }

  11. });

这几行代码为 ListView 组件添加了单击监听器,并对单击事件进行了处理。

当用户单击 ListView 组件中的某条数据时,将该条数据的 name 和 age 字段显示到 main.xml 文件的 EditText 中,并将该记录的“_id”值存储到 selId 中,以便于对该条记录进行操作。

实例 MyDbDemo 中对数据库的 CRUD 操作分别通过 SQLiteDatabase 对象的 query、insert、update、delete 方法实现,此处不再描述。

特别声明:
1、如无特殊说明,内容均为本站原创发布,转载请注明出处;
2、部分转载文章已注明出处,转载目的为学习和交流,如有侵犯,请联系客服删除;
3、编辑非《源码码网》的文章均由用户编辑发布,不代表本站立场,如涉及侵犯,请联系删除;
全部评论(0)
推荐阅读
  • 大型后台管理系统,用户登录状态该如何保存?
  • 大型后台管理系统,用户登录状态该如何保存?
  • 大型后台管理系统的用户登录状态保存需要综合考虑安全性、用户体验和系统架构。以下是企业级的完整方案:1.多层级存储策略class AuthManager {    constructor() {        this.storage = { &n
  • 源码教程
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2025-11-06 12:16
  • 阅读:350
  • 源码交易平台的支付困局与解决方案:如何通过专业支付系统提升交易效率
  • 源码交易平台的支付困局与解决方案:如何通过专业支付系统提升交易效率
  • 在数字经济蓬勃发展的今天,源码交易市场已成为互联网创业者和开发商的重要资源池。从电商系统源码到社交应用框架,从小程序解决方案到企业级管理系统,越来越多的开发者、初创企业和传统商家通过源码交易平台快速获取技术资产,实现商业目标的加速。源码交易市场的繁荣反映了数字化转型的迫切需求——企业需要快速迭代,开发者需要快速变现,用户需要快速启动。然而,在这个高速发展的市场中,一个长期被忽视但至关重要的问题浮现出来:支付系统的效率与安全性已成为制约交
  • 行业资讯
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2025-10-23 15:16
  • 阅读:297
  • Spring Boot 工程中 maven-surefire-plugin 测试执行失败及解决方法
  • Spring Boot 工程中 maven-surefire-plugin 测试执行失败及解决方法
  • 在SpringBoot工程编译时遇到maven-surefire-plugin的测试执行失败错误(Failedtoexecutegoalorg.apache.maven.plugins:maven-surefire-plugin:3.5.3:test),通常与测试环节相关。以下是常见原因及解决方法:1.测试用例执行失败• 原因:最常见的是测试用例(*Test.java)运行时抛出异常(如断言失败、空指针等),导
  • 源码教程
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2025-10-13 10:57
  • 阅读:362
  • WeMark - 微信小程序图片水印
  • WeMark - 微信小程序图片水印
  • 一个纯前端的微信小程序图片水印工具。支持文字/图片水印、单个与全屏两种模式,透明度与角度调节、单个水印位置X/Y控制,预览与对比模态、历史记录(100条)等功能。
  • 源码教程
  • 来源:源码码用户
  • 编辑:yg
  • 时间:2025-09-22 16:09
  • 阅读:287
联系客服
源码代售 源码咨询 素材咨询 联系客服
029-84538663
手机版

扫一扫进手机版
返回顶部