我的编程空间,编程开发者的网络收藏夹
学习永远不晚

详解Android轻量型数据库SQLite

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

详解Android轻量型数据库SQLite

数据库是Android存储方案的核心,在Andorid中SQLite非常轻量,而且执行sql语句甚至比MySQL还要快。
SQLiteDatabase 是 Android 中操作数据库的核心类之一,使用SQLiteDatabase可以打开数据库,也可以对数据库进行操作,然而,为了数据库升级以及使用更加方便,我们常用SQLiteOpenHelper的子类来完成创建,打开数据库的操作。
SQLiteOpenHelper是一个抽象类,在该类中有下面两个必须实现的方法:


public void onCreate(SQLiteDatabase db);// 该函数在数据库第一次被建立时调用
public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion);// 数据库更新升级操作

我们新建一个类DBHelper extends SQLiteOpenHelper


import java.util.Random;
import android.R.bool;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
public class DBHelper extends SQLiteOpenHelper {
 // 设置数据库默认版本
 private static final int VERSON = 1;
 // 自定义数据库名,可以随便取名字
 private static final String DBNAME = "mydb";
 // 继承SQLiteOpenHelper类的类必须有自己的构造函数
 // 该构造函数4个参数,直接调用父类的构造函数。其中第一个参数为该类本身;第二个参数为数据库的名字;
 public DBHelper(Context context, String name, CursorFactory factory,
   int version) {
  super(context, name, factory, version);
 }
 // 该构造函数有3个参数,因为它把上面函数的第3个参数固定为null了
 public DBHelper(Context context, String name, int verson) {
  this(context, name, null, verson);
 }
 // 该构造函数只有2个参数,在上面函数 的基础上将版本号固定了
 public DBHelper(Context context, String name) {
  this(context, name, VERSON);
 }
 // 该构造函数只有1个参数,固定默认数据库,在这里我们实现增删改查为了方便,就用它了
 public DBHelper(Context context) {
  this(context, DBNAME, null, VERSON);
 }
 // 该函数在数据库第一次被建立时调用
 public void onCreate(SQLiteDatabase db) {
  System.out.println("create a sqlite database");
  //建表语句(注意:因为在绑定数据时,Cursor对象返回的记录集中必须包含一个"_id"字段,否则无法完成数据绑定
  String sql = "CREATE TABLE [test]("+
      "[_id] AUTOINC,"+
      "[name] varchar(20),"+
      "[age] varchar(20),"+
      "PRIMARY KEY ([_id]))";
  db.execSQL(sql);
  //向test表中插入10条数据
  for (int i = 1; i <= 10; i++) {
   String name = "Jepson";
   name+=i;
   String age = "age";
   age+=i;
   db.execSQL("insert into test(name,age) values(?,?)",new Object[]{name,age});
  }
 }
 // 数据库更新操作
 public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
  System.out.println("update a sqlite database");
 }
 //自定义query方法,用以执行查询语句,返回Cursor对象
 public Cursor query(String sql,String[] args){
  //调用 getReadableDatabase方法时,如果数据库文件不存在,会调用 onCreate方法
  SQLiteDatabase db = this.getReadableDatabase();
  Cursor cursor = db.rawQuery(sql, args);
  return cursor;
 }
}

这样,我们的DBHelper 类写好了,我们来实现一个查询操作。

第一步,activity_main.xml添加 listview 展示控件

activity_main.xml


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:background="#FFFFFF"
 android:orientation="vertical"
 tools:context=".MainActivity" >
 <ListView
  android:id="@android:id/list"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:layout_weight="1"
  android:divider="#6b6f74"
  android:dividerHeight="1px" >
 </ListView>
</LinearLayout>

第二步,新建一个xml布局文件,用来作为列表项使用的布局资源

user_list_cell.xml


<?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" 
 android:background="#FFFFFF">
 <!-- 大字体TextView,用以展示 name姓名 -->
 <TextView
  android:id="@+id/tvName"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:text="Large"
  android:textColor="#000000"
  android:textSize="20dp" />
 <!-- 小字体TextView,用以展示 age年龄 -->
 <TextView
  android:id="@+id/tvAge"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:text="Small"
  android:textColor="#000000"
  android:textSize="14dp" />
</LinearLayout>

第三步,主Activity


import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;
public class MainActivity extends ListActivity {
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initView();
 }
 public void initView(){
  //调用只有1个参数的构造函数,实例化dbHelper
  DBHelper dbHelper = new DBHelper(this);
  //新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
  Cursor cursor = dbHelper.query("select * from test", null);
  //创建SimpleCursorAdapter对象,5个参数,
  //第一个是context,就写当前this就行
  //第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
  //第三个就是Cursor对象
  //第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
  //第五个就是对应列表项布局中的控件ID了
  SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
    R.layout.user_list_cell, cursor,
    new String[] { "name", "age" }, new int[] { R.id.tvName,
      R.id.tvAge });
  setListAdapter(simpleCursorAdapter);
  Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();
 }
}

执行一下看看,我们是不是查询成功了?

操作SQLite数据库应了解,对数据库的增删改查都有两种方法,一种是前面的使用 rawQuery方法直接执行SQL语句,另一种就是使用SQLiteDatabase类的相应方法来操作,下面举一个第二种的例子,比如我们要插入数据 name=11 age=22


import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;
public class MainActivity extends ListActivity {
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initView();
 }
 public void initView(){
  //执行添加操作
  DBHelper dbHelper = new DBHelper(this);
  //获得写入权限getWritableDatabase
  SQLiteDatabase db = dbHelper.getWritableDatabase();
  //新建contentvalues保存insert数据
  ContentValues cv = new ContentValues();
  cv.put("name", "11");
  cv.put("age", "22");
  db.insert("test", null, cv);
  Toast.makeText(this, "添加成功", Toast.LENGTH_SHORT).show();
  ////查询操作
  ////调用只有1个参数的构造函数,实例化dbHelper
  //DBHelper dbHelper = new DBHelper(this);
  ////新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
  //Cursor cursor = dbHelper.query("select * from test", null);
  ////创建SimpleCursorAdapter对象,5个参数,
  ////第一个是context,就写当前this就行
  ////第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
  ////第三个就是Cursor对象
  ////第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
  ////第五个就是对应列表项布局中的控件ID了
  //SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
  //  R.layout.user_list_cell, cursor,
  //  new String[] { "name", "age" }, new int[] { R.id.tvName,
  //    R.id.tvAge });
  //setListAdapter(simpleCursorAdapter);
  //Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();
 }
} 

执行插入成功以后,再将插入语句注释,将查询语句去掉注释,重新启动,会发现最后一多了一个item,添加成功。

另外查询记录获得的Cursor对象,需要使用movetoFirst,moveToNext,movToPosition(position)等方法将指针移动相应的位置,来进行查询结果的读取。


import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;
public class MainActivity extends ListActivity {
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initView();
 }
 public void initView(){
  //解析Cursor对象的查询操作
  DBHelper dbHelper = new DBHelper(this);
  SQLiteDatabase db = dbHelper.getWritableDatabase();
  Cursor cursor = db.query("test", null, null, null, null, null, null,
    null);
  //定义结果字符串
  String result = "";
  // 判断cursor不为空 这个很重要
  if (cursor != null) {
   while (cursor.moveToNext()) {
    String name = cursor.getString(cursor.getColumnIndex("name"));// 获取name列的值
    String age = cursor.getString(cursor.getColumnIndex("age"));// 获取age列的值
    result += "姓名:" + name + ",年龄:" + age + "\n";
   }
  }
  cursor.close();
  db.close();
  System.out.println(result);
  Toast.makeText(this, result, Toast.LENGTH_SHORT).show();
  // //执行添加操作
  // DBHelper dbHelper = new DBHelper(this);
  // //获得写入权限getWritableDatabase
  // SQLiteDatabase db = dbHelper.getWritableDatabase();
  // //新建contentvalues保存insert数据
  // ContentValues cv = new ContentValues();
  // cv.put("name", "11");
  // cv.put("age", "22");
  // db.insert("test", null, cv);
  // Toast.makeText(this, "添加成功", Toast.LENGTH_SHORT).show();
  ////查询操作
  ////调用只有1个参数的构造函数,实例化dbHelper
  //DBHelper dbHelper = new DBHelper(this);
  ////新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
  //Cursor cursor = dbHelper.query("select * from test", null);
  ////创建SimpleCursorAdapter对象,5个参数,
  ////第一个是context,就写当前this就行
  ////第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
  ////第三个就是Cursor对象
  ////第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
  ////第五个就是对应列表项布局中的控件ID了
  //SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
  //  R.layout.user_list_cell, cursor,
  //  new String[] { "name", "age" }, new int[] { R.id.tvName,
  //    R.id.tvAge });
  //setListAdapter(simpleCursorAdapter);
  //Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();
 }
} 

执行以后,可以发现,name和age全都获取到了,并显示在了Toast和system.out中。是不是很有意思呢?

您可能感兴趣的文章:Android SQLite数据库增删改查操作的使用详解Android开发之SQLite的使用方法Android使用SQLite数据库的简单实例android创建数据库(SQLite)保存图片示例深入Android SQLite 事务处理详解Android--SQLite(增,删,改,查)操作实例代码Android中的SQL查询语句LIKE绑定参数问题解决办法(sqlite数据库)android中sqlite的按条件查找的小例子android开发教程之listview显示sqlite数据Android 用SQLite实现事务的方法


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

详解Android轻量型数据库SQLite

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

详解Android轻量型数据库SQLite

数据库是Android存储方案的核心,在Andorid中SQLite非常轻量,而且执行sql语句甚至比MySQL还要快。 SQLiteDatabase 是 Android 中操作数据库的核心类之一,使用SQLiteDatabase可以打开
2022-06-06

详解Android数据存储—使用SQLite数据库

SQLite是Android自带的关系型数据库,是一个基于文件的轻量级数据库。Android提供了3种操作数据的方式,SharedPreference(共享首选项)、文件存储以及SQLite数据库。 SQLite数据库文件被保存在/data
2022-06-06

Android批量插入数据到SQLite数据库

Android中在sqlite插入数据的时候默认一条语句是一个事务,因此如果存在上万条数据插入的话,那需要执行上万次插入操作,操作速度可想而知。因此在Android中插入数据时,使用批量插入的方式可以大大提高插入速度。有时需要把一些数据内置
2022-06-06

Android编程操作嵌入式关系型SQLite数据库实例详解

本文实例分析了Android编程操作嵌入式关系型SQLite数据库的方法。分享给大家供大家参考,具体如下: SQLite特点 1.Android平台中嵌入了一个关系型数据库SQLite,和其他数据库不同的是SQLite存储数据时不区分类型
2022-06-06

Android编程之SQLite数据库操作方法详解

本文实例讲述了Android SQLite数据库操作方法。分享给大家供大家参考,具体如下:SQLite and AndroidSQLite简介SQLite是一个非常流行的嵌入式数据库,它支持SQL语言,并且只利用很少的内存就有很好的性能。此
2023-05-30

Android批量插入数据到SQLite数据库的方法

Android中在sqlite插入数据的时候默认一条语句就是一个事务,因此如果存在上万条数据插入的话,那就需要执行上万次插入操作,操作速度可想而知。因此在Android中插入数据时,使用批量插入的方式可以大大提高插入速度。有时需要把一些数据
2022-06-06

Android入门之使用SQLite内嵌式数据库详解

Android内带SQLite内嵌式数据库了。这对于我们存储一些更复杂的结构化数据带来了极大的便利。本文就来和大家聊聊具体的使用方法,希望对大家有所帮助
2022-12-22

Android SQLite数据库增删改查操作的使用详解

一、使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库——SQLite,SQLite3支持NULL、INTEGER、REAL(浮点数字)、 TEXT(字符串文本)和BLOB(二进制对象)数据类型
2022-06-06

SQLite数据库数据量过大卡顿怎么解决

解决SQLite数据库数据量过大导致卡顿的问题,可以考虑以下几种方法:数据库优化:对数据库进行优化,包括索引的建立、查询语句的优化等,可以提高数据库的性能。可以使用SQLite提供的工具进行数据库性能分析,找出影响性能的瓶颈。数据分区:将数
SQLite数据库数据量过大卡顿怎么解决
2024-04-09

SQLite本地轻量化数据库使用配置(全套)===》Net

原文:https://www.cnblogs.com/jsll/p/14140257.html
SQLite本地轻量化数据库使用配置(全套)===》Net
2022-03-11

Qt操作SQLite数据库的教程详解

SQLite是一款开源、轻量级、跨平台的数据库,无需server,无需安装和管理配置。它的设计目标是嵌入式的,所以很适合小型应用,也是Qt应用开发种常用的一种数据库。本文为大家介绍了Qt操作SQLite数据库的示例,希望对大家有所帮助
2022-12-08

Android SQLite数据库版本升级原理解析

Android使用SQLite数据库保存数据,那数据库版本升级是怎么回事呢,这里说一下。一、软件v1.0安装v1.0,假设v1.0版本只有一个account表,这时走继承SQLiteOpenHelper的onCreate,不走onUpgra
2022-06-06

MySQL数据库的数据类型decimal详解

在MySQL数据库中,decimal数据类型用于存储精确的小数值。它比其他浮点类型(如float和double)更适合用于存储货币金额、利率等需要精确计算的数据。decimal数据类型的语法如下:DECIMAL(M, D)其中,M是总的数字
2023-09-14

Python变量和数据类型详解

Python变量和数据类型Python中数据类型Python之print语句Python的注释Python中什么是变量Python中定义字符串Python中raw字符串与多行字符串Python中Unicode字符串Python中整数和浮点数
2022-06-04

Android操作SQLite数据库(增、删、改、查、分页等)及ListView显示数据的方法详解

本文实例讲述了Android操作SQLite数据库(增、删、改、查、分页等)及ListView显示数据的方法。分享给大家供大家参考,具体如下: 由于刚接触android开发,故此想把学到的基础知识记录一下,以备查询,故此写的比较啰嗦: 步骤
2022-06-06

详细解说关系型数据库

目录1、认识关系型数据库1.1.1 什么是关系型数据库1.1.2  实体关系模型1.1.3  关系型数据库管理系统RDBMS1.1.4  使用SQL语言管理数据库1、认识关系型数据库数据库简而言之就是数据的集合,它是由文件系统存储数据发展起来的,数据库系统解决
详细解说关系型数据库
2016-07-24

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录