使用SQLiteOpenHelper类对数据库简单操作

一.当操作SQLite数据库时需要,需要得到一个SQLiteOpenHelper对象。但由于SQLiteOpenHelper是一个抽象类,需要自定义一个类来继承它。这样自定义类就实现了SQLiteOpenHelper中的所有方法。
二.创建一个类并继承SQLiteOpenHelper,实现其中的方法。并在构造函数中调用基类的构造函数。

[java]
1.public class SqlLiteHelper extends SQLiteOpenHelper {  
2.       private static final int VERSION =1;  
3.       //TODO 实现基类的构造函数,四个参数的   
4.       public SqlLiteHelper(Contextcontext , String DBname ,CursorFactory factory , int version)  
5.       {  
6.              super(context, DBname,factory, version);  
7.       }  
8.       //TODO 实现基类的构造函数,三个参数的   
9.       public SqlLiteHelper(Context context, String DBname ,int version ) {  
10.              this(context, DBname, null,version);  
11.                
12.       }  
13.       //TODO 实现基类的构造函数,两个参数的   
14.       public SqlLiteHelper(Contextcontext,String DBname) {  
15.              this(context, DBname, null,VERSION);  
16.                
17.       }  
18.         
19.       //当创建数据库时执行   
20.       @Override  
21.       public void onCreate(SQLiteDatabasedb) {  
22.              // TODO Auto-generatedmethod stub   
23.              System.out.println("创建数据库");  
24.              db.execSQL("Createtable user(id int , name varchar(20))");  
25.       }  
26.  
27.       //当更新数据库版本时执行   
28.       @Override  
29.       public voidonUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {  
30.              //TODO Auto-generated method stub   
31.              System.out.println("修改数据库版本号");  
32.       }  
33.} 
三.创建数据库

[java]
1.//创建自定义SqlLiteHelper类的实例,调用两个参数的构造函数   
2.SqlLiteHelper mySqlLiteHelper = new SqlLiteHelper(SqlLiteTestActivity.this,"paj_db_test");  
3.//只有调用了getWritableDatabase()方法才会执行SqlLiteHelper类中的OnCreate中的代码   
4.mySqlLiteHelper.getWritableDatabase();

四.更新数据库版本

[java]
1.//调用三个参数的构造函数更新数据库的版本,数据库版本只能递增。   
2.SqlLiteHelper myhelper = new SqlLiteHelper(getApplicationContext(),"paj_db_test", 2);  
3.myhelper.getReadableDatabase();

五.向数据库中插入信息

[java]
1.//创建SqlLiteHelper自定义类对象,并调用两个参数的构造函数   
2.SqlLiteHelper  myhelper = newSqlLiteHelper(getApplicationContext(), "paj_db_test");         
3.//创建一个ContenValues对象,存储数据   
4.ContentValues contentValues = new ContentValues();  
5.//把数据填充到ContentValues对象中,ContentValues对象中的键和值对应数据库中的列和值。值必须与数据列的类型相同。   
6.contentValues.put("id", 2);  
7.contentValues.put("name", "zhangsan");  
8.//创建可写的SQLiteDatabase对象   
9.SQLiteDatabase db = myhelper.getWritableDatabase();  
10.//调用insert方法写入数据库.第一个参数为表名,第二个为null,第三个参数为CntentValues对象。   
11.db.insert("user", null, contentValues); 
六.更新数据库信息

[java]
1.//创建一个ContentValue对象存放要更新的信息   
2.ContentValues contentValues = new ContentValues();  
3.//把要更新的信息存放到ContentValues对象中。   
4.//第一个参数对应数据库中的列,第二个参数对应列的值。   
5.contentValues.put("name", "zhangsanfeng");  
6.//创建SqlLiteHelper对象   
7.SqlLiteHelper myhelper = new SqlLiteHelper(getApplicationContext(),"paj_db_test");  
8.//创建一个可写的SQLiteDatabase对象   
9.SQLiteDatabase db = myhelper.getWritableDatabase();  
10.//使用update更新数据库   
11.//第一个参数是数据库表名   
12.//第二个参数是ContentValues对象   
13.//第三个参数是SQL语句中的Where条件子语句,其中的?对应第四个参数中String数组。数组中有几个字符就有几个问号。   
14.//第四个参数是Where的条件。使用String数组存放Where条件   
15.db.update("user", contentValues, "id=?", newString[]{"1"}); 
七.查询数据库

[java]
1.//调用两个参数的构造函数实例化SqlLiteHelper自定义类   
2.SqlLiteHelper myhelper = new SqlLiteHelper(SqlLiteTestActivity.this,"paj_db_test");  
3.//创建只读的SQLiteDatabase对象   
4.SQLiteDatabase db = myhelper.getReadableDatabase();  
5.//调用SQLitedatabase的query方法获取检索结果并放入Cursor对象中。   
6.//query方法的第一个参数是表名   
7.//第二个参数是使用String数组存放列名,一个列明占用一个元素   
8.//第三个参数是SQL语句中的Where条件子语句,其中的?对应第四个参数中String数组。数组中有几个字符就有几个问号。   
9.//第三个参数是Where的条件   
10.//第四个参数分组   
11.//第五个参数是SQL中的having   
12.//第六个参数是排序   
13.Cursor cursor = db.query("user", null,null, null, null, null, null);  
14.//使用cursor.moveToNext()把游标下移一行。游标默认在第一行的上一行。   
15.while (cursor.moveToNext()) {  
16.    //使用GetString获取列中的值。参数为使用cursor.getColumnIndex("name")获取的序号。   
17.       String nameString =cursor.getString(cursor.getColumnIndex("name"));  
18.       String idsString = cursor.getString(cursor.getColumnIndex("id"));  
19.       System.out.println("ID--->"+idsString);  
20.       System.out.println("NAME--->"+nameString);  
21.       }

本篇文章来源于 Linux公社网站(www.linuxidc.com)  原文链接:http://www.linuxidc.com/Linux/2012-02/53503.htm

时间: 2024-11-07 22:38:36

使用SQLiteOpenHelper类对数据库简单操作的相关文章

android SQLite使用SQLiteOpenHelper类对数据库进行操作

链接地址:http://byandby.iteye.com/blog/835580 一. SQLite介绍 SQLite是android内置的一个很小的关系型数据库. SQLite的官网是http://www.sqlite.org/,可以去下载一些文档或相关信息. 博客中有一篇有稍微详细一点的介绍,大家可以去看一下. 二. SQLiteOpenHelper的使用方法 SQLiteOpenHelper是一个辅助类来管理数据库的创建和版本. 可以通过继承这个类,实现它的一些方法来对数据库进行一些操作

【安卓9】SQLiteOpenHelper 类、增删改操作

SQLiteOpenHelper 类 SQLiteOpenHelper类是Android提供的用于操作SQLite数据库的工具类,该工具类能方便地创建数据库.表,以及管理数据库版本. 常用方法 1.    synchronized SQLiteDatabase  getReadableDatabase(); 作用:以读写的方式打开数据库对应的SQLiteDatabase类的对象 2.    synchronized SQLiteDatabase  getWriteableDatabase();

android数据库简单操作

1.DbOpenHelper package com.example.dbtest.dbHelper; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; //继承SQLiteOpenHelper类 public class DbOpenHelper extends SQLiteOpenHelp

SQL数据库简单操作

sql语言简介 (1)数据库是文件系统,使用标准sql对数据库进行操作 * 标准sql,在mysql里面使用语句,在oracle.db2都可以使用这个语句 (2)什么是sql * Structured Query Language, 结构化查询语言,对数据库进行操作 * sql非过程性语言,不需要依赖于其他的条件就可以运行 ** 比如 在java里面 *** if(a > 5) { System.out..... } (3)sql的分类 第一类:DDL (数据定义语言) * 创建数据库,创建数据

MongoDB数据库简单操作

之前学过的有mysql数据库,现在我们学习一种非关系型数据库 一.简介 MongoDB是一款强大.灵活.且易于扩展的通用型数据库 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案. MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成.MongoDB 文档类似于 JSON 对象.字段值可以包含其他文档,数组及文档

MySQL 数据库简单操作

对于想要从事或爱好mysql相关工作的童鞋们,有必要掌握在命令行下对mysql实现一些简单的操作.本文从描述了如何登录到mysql数据库服务器,如何在mysql提示符下发布命令,创建数据库,以及执行一些简单的DML操作. 1.连接到与退出mysql 为了连接mysql数据库服务器,当调用mysql时,通常需要提供一个MySQL用户名并且很可能需要一个密码.如果服务器 运行在登录服务器之外的其它机器上,还需要指定主机名.联系管理员以找出进行连接所使用的参数 (即,连接的主机 .用户名和使用的密码)

Yii 2.0 数据库简单操作(转)

开始使用数据库首先需要配置数据库连接组件,通过添加 db 组件到应用配置实现("基础的" Web 应用是 config/web.php),DSN( Data Source Name )是数据源名称,用于指定数据库信息.如下所示: return [ // ... 'components' => [ // ... 'db' => [ 'class' => 'yii\db\Connection', 'dsn' => 'mysql:host=localhost;dbna

oracle数据库简单操作

导入某用户所有表和数据:imp sgp/[email protected]:1521/orcl file=sgp20161025.dmp full=y 导出指定表及数据:exp sgp/[email protected]:1521/orcl file=20160921sgp_table_sysmodule_sysdict.dmp tables=(sgp_sysmodule, sgp_sysdict) 导入指定表及数据:imp sgp/[email protected]:1521/orcl fil

msyql数据库简单操作及事务和索引

Msyql数据库操作:[[email protected] ~]# mysql -u root -p //进入数据库中 mysql> show databases; //查看所有数据库 mysql> use mysql; //进入mysql数据库 mysql> show tables; //查看数据库中的表 mysql> desc user; //查看表的结构 mysql> create database auth; //创建新的空库 mysql> show datab