zoukankan      html  css  js  c++  java
  • android SQLite使用SQLiteOpenHelper类对数据库进行操作

     转载
     
    一、 SQLite介绍 
    SQLite是android内置的一个很小的关系型数据库。 
    SQLite的官网是http://www.sqlite.org/,可以去下载一些文档或相关信息。 
    博客中有一篇有稍微详细一点的介绍,大家可以去看一下。 

    二、 SQLiteOpenHelper的使用方法 
    SQLiteOpenHelper是一个辅助类来管理数据库的创建和版本。 
    可以通过继承这个类,实现它的一些方法来对数据库进行一些操作。 
    所有继承了这个类的类都必须实现下面这样的一个构造方法: 
    public DatabaseHelper(Context context, String name, CursorFactory factory, int version) 
    第一个参数:Context类型,上下文对象。 
    第二个参数:String类型,数据库的名称 
    第三个参数:CursorFactory类型 
    第四个参数:int类型,数据库版本 
    下面是这个类的几个方法: 

    方法名 返回类型 描述 备注 
    getReadableDatabase() synchronized SQLiteDatabase 创建或打开一个数据库 可以通过这两个方法返回的SQLiteDatabase对象对数据库进行一系列的操作,如新建一个表,插入一条数据等 
    getWritableDatabase() synchronized SQLiteDatabase 创建或打开一个可以读写的数据库 
    onCreate(SQLiteDatabase db) abstract void 第一次创建的时候调用 
    onOpen(SQLiteDatabase db) void 打开数据库 
    onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion) abstract void 升级数据库 
    close() synchronized void 关闭所有打开的数据库对象 

    下面有一个例子,当点击按钮时进行相应的操作,效果图如下: 

     
    介于代码中有详细备注了,在此我就不多写了,直接贴代码了,代码如下: 
    DatabaseHelper类: 
    Java代码  收藏代码
    1. package android.sqlite;  
    2.   
    3. import android.content.Context;  
    4. import android.database.sqlite.SQLiteDatabase;  
    5. import android.database.sqlite.SQLiteOpenHelper;  
    6. import android.database.sqlite.SQLiteDatabase.CursorFactory;  
    7.   
    8. /** 
    9.  * SQLiteOpenHelper是一个辅助类,用来管理数据库的创建和版本他,它提供两个方面的功能 
    10.  * 第一,getReadableDatabase()、getWritableDatabase()可以获得SQLiteDatabase对象,通过该对象可以对数据库进行操作 
    11.  * 第二,提供了onCreate()、onUpgrade()两个回调函数,允许我们再创建和升级数据库时,进行自己的操作 
    12.  */  
    13. public class DatabaseHelper extends SQLiteOpenHelper {  
    14.     private static final int VERSION = 1;  
    15.   
    16.     /** 
    17.      * 在SQLiteOpenHelper的子类当中,必须有该构造函数 
    18.      * @param context   上下文对象 
    19.      * @param name      数据库名称 
    20.      * @param factory 
    21.      * @param version   当前数据库的版本,值必须是整数并且是递增的状态 
    22.      */  
    23.     public DatabaseHelper(Context context, String name, CursorFactory factory,  
    24.             int version) {  
    25.         //必须通过super调用父类当中的构造函数  
    26.         super(context, name, factory, version);  
    27.     }  
    28.       
    29.     public DatabaseHelper(Context context, String name, int version){  
    30.         this(context,name,null,version);  
    31.     }  
    32.   
    33.     public DatabaseHelper(Context context, String name){  
    34.         this(context,name,VERSION);  
    35.     }  
    36.   
    37.     //该函数是在第一次创建的时候执行,实际上是第一次得到SQLiteDatabase对象的时候才会调用这个方法  
    38.     @Override  
    39.     public void onCreate(SQLiteDatabase db) {  
    40.         // TODO Auto-generated method stub  
    41.         System.out.println("create a database");  
    42.         //execSQL用于执行SQL语句  
    43.         db.execSQL("create table user(id int,name varchar(20))");  
    44.     }  
    45.   
    46.     @Override  
    47.     public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {  
    48.         // TODO Auto-generated method stub  
    49.         System.out.println("upgrade a database");  
    50.     }  
    51. }  


    Activity类: 
    Java代码  收藏代码
    1. package android.sqlite;  
    2.   
    3. import android.app.Activity;  
    4. import android.content.ContentValues;  
    5. import android.database.Cursor;  
    6. import android.database.sqlite.SQLiteDatabase;  
    7. import android.os.Bundle;  
    8. import android.view.View;  
    9. import android.view.View.OnClickListener;  
    10. import android.widget.Button;  
    11.   
    12. public class SQLiteActivity extends Activity {  
    13.     /** Called when the activity is first created. */  
    14.     private Button createDatabaseButton = null;  
    15.     private Button updateDatabaseButton = null;  
    16.     private Button insertButton = null;  
    17.     private Button updateButton = null;  
    18.     private Button selectButton = null;  
    19.     private Button deleteButton = null;  
    20.   
    21.     @Override  
    22.     public void onCreate(Bundle savedInstanceState) {  
    23.         super.onCreate(savedInstanceState);  
    24.         setContentView(R.layout.main);  
    25.         // 根据控件id获得相应的控件对象  
    26.         createDatabaseButton = (Button) findViewById(R.id.createDatabase);  
    27.         updateDatabaseButton = (Button) findViewById(R.id.updateDatabase);  
    28.         insertButton = (Button) findViewById(R.id.insert);  
    29.         updateButton = (Button) findViewById(R.id.update);  
    30.         selectButton = (Button) findViewById(R.id.select);  
    31.         deleteButton = (Button) findViewById(R.id.delete);  
    32.         // 为按钮设置监听器  
    33.         createDatabaseButton  
    34.                 .setOnClickListener(new CreateDatabaseOnClickListener());  
    35.         updateDatabaseButton  
    36.                 .setOnClickListener(new UpdateDatabaseOnClickListener());  
    37.         insertButton.setOnClickListener(new InsertOnClickListener());  
    38.         updateButton.setOnClickListener(new UpdateOnClickListener());  
    39.         selectButton.setOnClickListener(new SelectOnClickListener());  
    40.         deleteButton.setOnClickListener(new DeleteOnClickListener());  
    41.     }  
    42.   
    43.     // createDatabaseButton点击事件监听器  
    44.     class CreateDatabaseOnClickListener implements OnClickListener {  
    45.         public void onClick(View v) {  
    46.             // 创建了一个DatabaseHelper对象,只执行这句话是不会创建或打开连接的  
    47.             DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,  
    48.                     "test_yangyz_db");  
    49.             // 只有调用了DatabaseHelper的getWritableDatabase()方法或者getReadableDatabase()方法之后,才会创建或打开一个连接  
    50.             SQLiteDatabase sqliteDatabase = dbHelper.getReadableDatabase();  
    51.         }  
    52.     }  
    53.   
    54.     // updateDatabaseButton点击事件监听器  
    55.     class UpdateDatabaseOnClickListener implements OnClickListener {  
    56.         public void onClick(View v) {  
    57.             // TODO Auto-generated method stub  
    58.             DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,  
    59.                     "test_yangyz_db", 2);  
    60.             // 得到一个只读的SQLiteDatabase对象  
    61.             SQLiteDatabase sqliteDatabase = dbHelper.getReadableDatabase();  
    62.         }  
    63.   
    64.     }  
    65.   
    66.     // insertButton点击事件监听器  
    67.     class InsertOnClickListener implements OnClickListener {  
    68.         public void onClick(View v) {  
    69.             // 创建ContentValues对象  
    70.             ContentValues values = new ContentValues();  
    71.             // 向该对象中插入键值对,其中键是列名,值是希望插入到这一列的值,值必须和数据库当中的数据类型一致  
    72.             values.put("id", 1);  
    73.             values.put("name", "yangyz");  
    74.             // 创建DatabaseHelper对象  
    75.             DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,  
    76.                     "test_yangyz_db", 2);  
    77.             // 得到一个可写的SQLiteDatabase对象  
    78.             SQLiteDatabase sqliteDatabase = dbHelper.getWritableDatabase();  
    79.             // 调用insert方法,就可以将数据插入到数据库当中  
    80.             // 第一个参数:表名称  
    81.             // 第二个参数:SQl不允许一个空列,如果ContentValues是空的,那么这一列被明确的指明为NULL值  
    82.             // 第三个参数:ContentValues对象  
    83.             sqliteDatabase.insert("user", null, values);  
    84.         }  
    85.     }  
    86.   
    87.     // updateButton点击事件监听器  
    88.     class UpdateOnClickListener implements OnClickListener {  
    89.         public void onClick(View v) {  
    90.             // 创建一个DatabaseHelper对象  
    91.             DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,  
    92.                     "test_yangyz_db", 2);  
    93.             // 得到一个可写的SQLiteDatabase对象  
    94.             SQLiteDatabase sqliteDatabase = dbHelper.getWritableDatabase();  
    95.             // 创建一个ContentValues对象  
    96.             ContentValues values = new ContentValues();  
    97.             values.put("name", "zhangsan");  
    98.             // 调用update方法  
    99.             // 第一个参数String:表名  
    100.             // 第二个参数ContentValues:ContentValues对象  
    101.             // 第三个参数String:where字句,相当于sql语句where后面的语句,?号是占位符  
    102.             // 第四个参数String[]:占位符的值  
    103.             sqliteDatabase.update("user", values, "id=?", new String[] { "1" });  
    104.             System.out.println("-----------update------------");  
    105.         }  
    106.     }  
    107.   
    108.     // selectButton点击事件监听器  
    109.     class SelectOnClickListener implements OnClickListener {  
    110.         public void onClick(View v) {  
    111.             String id = null;  
    112.             String name = null;  
    113.             //创建DatabaseHelper对象  
    114.             DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,  
    115.                     "test_yangyz_db", 2);  
    116.             // 得到一个只读的SQLiteDatabase对象  
    117.             SQLiteDatabase sqliteDatabase = dbHelper.getReadableDatabase();  
    118.             // 调用SQLiteDatabase对象的query方法进行查询,返回一个Cursor对象:由数据库查询返回的结果集对象  
    119.             // 第一个参数String:表名  
    120.             // 第二个参数String[]:要查询的列名  
    121.             // 第三个参数String:查询条件  
    122.             // 第四个参数String[]:查询条件的参数  
    123.             // 第五个参数String:对查询的结果进行分组  
    124.             // 第六个参数String:对分组的结果进行限制  
    125.             // 第七个参数String:对查询的结果进行排序  
    126.             Cursor cursor = sqliteDatabase.query("user", new String[] { "id",  
    127.                     "name" }, "id=?", new String[] { "1" }, null, null, null);  
    128.             // 将光标移动到下一行,从而判断该结果集是否还有下一条数据,如果有则返回true,没有则返回false  
    129.             while (cursor.moveToNext()) {  
    130.                 id = cursor.getString(cursor.getColumnIndex("id"));  
    131.                 name = cursor.getString(cursor.getColumnIndex("name"));  
    132.             }  
    133.             System.out.println("-------------select------------");  
    134.             System.out.println("id: "+id);  
    135.             System.out.println("name: "+name);  
    136.         }  
    137.     }  
    138.   
    139.     // deleteButton点击事件监听器  
    140.     class DeleteOnClickListener implements OnClickListener {  
    141.         public void onClick(View v) {  
    142.             //创建DatabaseHelper对象  
    143.             DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_yangyz_db",2);  
    144.             //获得可写的SQLiteDatabase对象  
    145.             SQLiteDatabase sqliteDatabase = dbHelper.getWritableDatabase();  
    146.             //调用SQLiteDatabase对象的delete方法进行删除操作  
    147.             //第一个参数String:表名  
    148.             //第二个参数String:条件语句  
    149.             //第三个参数String[]:条件值  
    150.             sqliteDatabase.delete("user", "id=?", new String[]{"1"});  
    151.             System.out.println("----------delete----------");  
    152.         }  
    153.     }  
    154. }  


    布局文件: 
    Xml代码  收藏代码
    1. <?xml version="1.0" encoding="utf-8"?>  
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    3.     android:orientation="vertical"  
    4.     android:layout_width="fill_parent"  
    5.     android:layout_height="fill_parent"  
    6.     >  
    7. <TextView    
    8.     android:layout_width="fill_parent"   
    9.     android:layout_height="wrap_content"   
    10.     android:text="@string/hello"  
    11.     />  
    12.       
    13.     <Button  
    14.         android:id="@+id/createDatabase"  
    15.         android:layout_width="fill_parent"  
    16.         android:layout_height="wrap_content"  
    17.         android:text="@string/createDatabaseButton"  
    18.     />  
    19.       
    20.     <Button  
    21.         android:id="@+id/updateDatabase"  
    22.         android:layout_width="fill_parent"  
    23.         android:layout_height="wrap_content"  
    24.         android:text="@string/updateDatabaseButton"  
    25.     />  
    26.       
    27.     <Button  
    28.         android:id="@+id/insert"  
    29.         android:layout_width="fill_parent"  
    30.         android:layout_height="wrap_content"  
    31.         android:text="@string/insertButton"  
    32.     />  
    33.       
    34.     <Button  
    35.         android:id="@+id/update"  
    36.         android:layout_width="fill_parent"  
    37.         android:layout_height="wrap_content"  
    38.         android:text="@string/updateButton"  
    39.     />  
    40.       
    41.     <Button  
    42.         android:id="@+id/select"  
    43.         android:layout_width="fill_parent"  
    44.         android:layout_height="wrap_content"  
    45.         android:text="@string/selectButton"  
    46.     />  
    47.       
    48.     <Button  
    49.         android:id="@+id/delete"  
    50.         android:layout_width="fill_parent"  
    51.         android:layout_height="wrap_content"  
    52.         android:text="@string/deleteButton"  
    53.     />  
    54. </LinearLayout>  


    String文件: 
    Xml代码  收藏代码
    1. <?xml version="1.0" encoding="utf-8"?>  
    2. <resources>  
    3.     <string name="hello">Hello World, SQLiteActivity!</string>  
    4.     <string name="app_name">SQLiteTest</string>  
    5.     <string name="createDatabaseButton">createDatabase</string>  
    6.     <string name="updateDatabaseButton">updateDatabase</string>  
    7.     <string name="insertButton">insert</string>  
    8.     <string name="updateButton">update</string>  
    9.     <string name="selectButton">select</string>  
    10.     <string name="deleteButton">delete</string>  
    11. </resources>  
  • 相关阅读:
    在QLabel上点击获得的效果
    Linux内核源代码解析——TCP状态转移图以及其实现
    SQL Server 执行计划缓存
    leetcode:Gray Code
    poj1459 Power Network
    eclipse 设置代码大小和布局里面代码大小
    shareSDK的初步使用(shareSDK中微信、qq等兼容问题,以及cocoapods支持架构冲突问题的解决)
    算法6-4:哈希表现状
    问题解决——限制窗体的最小尺寸
    Android用canvas画哆啦A梦
  • 原文地址:https://www.cnblogs.com/minghualiyan/p/5377410.html
Copyright © 2011-2022 走看看