android创建sqlite数据库

android创建sqlite数据库

●sqlite数据库是开源的用C语言实现的移动平台下的嵌入式数据库,适用于移动平台,处理器比较慢,内存小,iphone的数据库也是sqlite的,类型比mysql数据库少很多

●数据库的创建方法:

步骤一:建一个工程

步骤二:创建一个存储person信息的数据库打开帮助类,使用api  SQLiteOpenHelper(数据库创建与打开帮助类),让这个类继承SQLiteOpenHelper

示例代码:

 1 package com.itheima.db;
 2 
 3 import android.content.Context;
 4 
 5 import android.database.sqlite.SQLiteDatabase;
 6 
 7 import android.database.sqlite.SQLiteDatabase.CursorFactory;
 8 
 9 import android.database.sqlite.SQLiteOpenHelper;
10 
11 public class PersonSQLiteOpenHelper extends SQLiteOpenHelper {
12 
13               /**
14 
15                * 数据库的构造方法,用于定义数据库的名称  数据库查询的结果集 数据库的版本
16 
17                * @param context 上下文
18 
19                *
20 
21                */
22 
23               public PersonSQLiteOpenHelper(Context context) {
24 
25                             //name 数据库的名称
26 
27                             //factory 结果集的指针,指向数据条目的位置,写成null是使用系统默认的游标工程
28 
29                             //version 数据库的版本,最小从1开始
30 
31                             super(context, "person.db", null, 1);                          
32 
33               }
34 
35               /**
36 
37                * 在数据第一次被创建的时候被调用,创建数据库的表结构和存放一些初始化的参数
38 
39                *db 被创建的数据库
40 
41                */
42 
43               @Override
44 
45               public void onCreate(SQLiteDatabase db) {
46 
47                             //初始化数据库的表结构
48 
49                             db.execSQL("create table person (id integer primary key autoincrement,name varchar(20),number varchar(20))");            
50 
51               }
52 
53               @Override
54 
55               public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
56 
57               }
58 
59 }

步骤三:测试所写的代码

新建一个包,在包里创建出一个class,让这个class继承AndroidTestCase

 

 1 package com.itheima.db.test;
 2 
 3 import com.itheima.db.PersonSQLiteOpenHelper;
 4 
 5 import android.test.AndroidTestCase;
 6 
 7 public class TestPersonDB extends AndroidTestCase {
 8 
 9               public void testCreateDB() throws Exception
10 
11               {            
12 
13                             //这时候不能用this代表上下文了,测试框架提供getContext()获得上下文
14 
15                             PersonSQLiteOpenHelper helper = new PersonSQLiteOpenHelper(getContext());
16 
17                             helper.getWritableDatabase();
18 
19               }
20 
21 }

步骤四:配置测试junit框架,如果不会写代码,可以new出来android下面的一个测试工程,把里面的manifest.xml文件里面的代码贴到自己创建的工程的manifest.xml文件下

 1 <?xml version="1.0" encoding="utf-8"?>
 2 
 3 <manifest xmlns:android="http://schemas.android.com/apk/res/android"
 4 
 5     package="com.itheima.db"
 6 
 7     android:versionCode="1"
 8 
 9     android:versionName="1.0" >
10 
11     <uses-sdk
12 
13         android:minSdkVersion="19"
14 
15         android:targetSdkVersion="19" />   
16 
17     <instrumentation
18 
19         android:name="android.test.InstrumentationTestRunner"
20 
21         android:targetPackage="com.itheima.db" />
22 
23  
24 
25     <application
26 
27         android:allowBackup="true"
28 
29         android:icon="@drawable/ic_launcher"
30 
31         android:label="@string/app_name"
32 
33         android:theme="@style/AppTheme" >
34 
35            <uses-library android:name="android.test.runner" />
36 
37         <activity
38 
39             android:name="com.itheima.db.MainActivity"
40 
41             android:label="@string/app_name" >
42 
43             <intent-filter>
44 
45                 <action android:name="android.intent.action.MAIN" />
46 
47                 <category android:name="android.intent.category.LAUNCHER" />
48 
49             </intent-filter>
50 
51         </activity>
52 
53     </application>
54 
55 </manifest>

步骤五:运行测试代码:

 

步骤六:用到数据库的查看工具

 

posted @ 2015-01-20 22:37  BAOXF  阅读(828)  评论(0编辑  收藏  举报