数据库是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中。是不是很有意思呢?
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Python轻量级ORM框架Peewee访问sqlite数据库的方法详解,包括了Python轻量级ORM框架Peewee访问sqlite数据库的方法详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python轻量级ORM框架Peewee访问sqlite数据库的方法。分享给大家供大家参考,具体如下: ORM框架就是 object relation model,对象关系模型,
本文向大家介绍Android SQLite数据库中的表详解,包括了Android SQLite数据库中的表详解的使用技巧和注意事项,需要的朋友参考一下 Android SQLite数据库 前言 以前写PHP的时候,内置了print_r()和var_dump()两个函数用于打印输出任意类型的数据内部结构,现在做Android的开发,发现并没有这种类似的函数,对于数据库的查看很不方便,于是就写了一下查
问题内容: 我目前在一个网站上工作,该网站必须存在于内存可用性非常低的VM上(目前被告知要达到512mb)。不幸的是,至少在不久的将来,数据库和Web应用程序必须是同一台服务器。 现在,我已经在这里通读了一些问题,并尝试进行自己的研究,但是这里有很多选择。从本质上讲,什么是可以安装的轻巧的数据库服务器?SQL或NoSQL并不重要;它不会占用大量数据库资源,但我现在不想随我现在选择的内容而受到限制。
本文向大家介绍详解Android数据存储—使用SQLite数据库,包括了详解Android数据存储—使用SQLite数据库的使用技巧和注意事项,需要的朋友参考一下 SQLite是Android自带的关系型数据库,是一个基于文件的轻量级数据库。Android提供了3种操作数据的方式,SharedPreference(共享首选项)、文件存储以及SQLite数据库。 SQLite数据库文件被保存在/da
本文向大家介绍Python变量和数据类型详解,包括了Python变量和数据类型详解的使用技巧和注意事项,需要的朋友参考一下 Python 变量类型 变量存储在内存中的值。这就意味着在创建变量时会在内存中开辟一个空间。 基于变量的数据类型,解释器会分配指定内存,并决定什么数据可以被存储在内存中。 因此,变量可以指定不同的数据类型,这些变量可以存储整数,小数或字符。 变量赋值
本文向大家介绍详解JavaScript的变量和数据类型,包括了详解JavaScript的变量和数据类型的使用技巧和注意事项,需要的朋友参考一下 对于一门编程语言,肯定包含变量和数据类型。今天我们就来看看JavaScript脚本语言的变量和数据类型。相对 于其他的Java,C++等高级程序语言,JavaScript显得很简单。 一、变量 JavaScript的变量是松散类型的,所谓松散