详解Android轻量型数据库SQLite

详解Android轻量型数据库SQLite,第1张

概述数据库是Android存储方案的核心,在Andorid中SQLite非常轻量,而且执行sql语句甚至比MySQL还要快。

数据库是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,int verson) {  this(context,null,verson); } // 该构造函数只有2个参数,在上面函数 的基础上将版本号固定了 public DBHelper(Context context,String name) {  this(context,VERSON); } // 该构造函数只有1个参数,固定默认数据库,在这里我们实现增删改查为了方便,就用它了 public DBHelper(Context context) {  this(context,DBname,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",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,//  new String[] { "name",//    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);  //定义结果字符串  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",cv);  // Toast.makeText(this,Toast.LENGTH_SHORT).show(); }} 

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

总结

以上是内存溢出为你收集整理的详解Android轻量型数据库SQLite全部内容,希望文章能够帮你解决详解Android轻量型数据库SQLite所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1147987.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存