• [android] android下创建一个sqlite数据库


    Sqlite数据库是开源的c语言写的数据库,androidiphone都使用的这个,首先需要创建数据库,然后创建表和字段,android提供了一个apiSQLiteOpenHelper数据库的打开和创建类。

    具体使用比如:创建一个classPersonSQLiteOpenHelper用户数据库类,继承SQLiteOpenHelper,父类是个抽象类要实现onCreate()onUpgrate()方法,此时会报错要求创建构造方法,构造方法的参数:Context上下文作用是告诉程序数据库创建在哪个目录下,String name数据库文件的名字,factory游标工厂一般我们都写null系统默认的,version数据库的版本从1开始,构造方法完成数据库就可以被创建。

    OnCreate(SQLiteDatabase db)方法是数据库第一次被创建时回掉,用来创建表以及初始化参数,参数就是我们创建的数据库。调用SQLiteDatabase对象的execSQL()方法执行sql语句,首先要创建表和mysql的基本一样,执行这条sql语句,create table person (id integer primary key autoincrement,name  varchar(20) not null default “” ) varchar的数字实际没有意义,给程序员看的,超过了也无所谓。

    new出来helper对象的时候,数据库并不会被创建,只有当helper对象调用了getWritableDatabase()方法或者getReadableDatabase()时候才会被创建。使用测试用例来测试一下,但是helper类需要上下文对象,测试框架提供了一个方法叫getContext()来得到上下文对象,数据库文件的地址/data/data/包名/database/下面,是私有的权限

    helper代码:

    package com.tsh.database;
    
    import android.content.Context;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteOpenHelper;
    
    public class PersonSQLiteOpenHelper extends SQLiteOpenHelper {
        /**
         * 构造方法
         * @param context
         */
        public PersonSQLiteOpenHelper(Context context) {
            super(context, "person.db", null, 1);
        }
        /**
         * 数据库第一次创建完成的回调
         */
        @Override
        public void onCreate(SQLiteDatabase db) {
            String sql="create table person (id integer primary key autoincrement,name varchar(10) not null default '')";
            db.execSQL(sql);
        }
    
        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            // TODO Auto-generated method stub
    
        }
    
    }

    测试用例:

    package com.tsh.database.test;
    
    import com.tsh.database.PersonSQLiteOpenHelper;
    
    import android.test.AndroidTestCase;
    
    public class TestPersonDb extends AndroidTestCase {
        public void testPerson() throws Exception{
            PersonSQLiteOpenHelper helper =new PersonSQLiteOpenHelper(getContext());
            helper.getWritableDatabase();
        }
    }
  • 相关阅读:
    php的源代码包构建一个空的php扩展。
    Web服务器上可能被包含或被请求的不同脚本源代码文件
    是否采用Sybase形式的自动字符串转义(用 '' 表示 ')
    数据库导入的大小是否要分段处理?
    Maven常用参数及其说明【转:http://blog.csdn.net/wangjunjun2008/article/details/18982089】
    bat常用命令,转【http://www.cnblogs.com/yplong/archive/2013/04/02/2996550.html】
    ftp链接、上传、下载、断开
    maven配置中国下载源【转:http://www.cnblogs.com/libingbin/p/5949483.html】
    经经经!!!!
    spring中quartz的使用。【转http://www.cnblogs.com/kay/archive/2007/11/02/947372.html】
  • 原文地址:https://www.cnblogs.com/taoshihan/p/5252008.html
Copyright © 2020-2023  润新知