如何在android中的sqlite中创建多个表?

时间:2011-07-21 08:25:21

标签: android database sqlite

我的数据库中有三个表。我尝试了许多关于在sqlite中创建db的示例,并且找出它们中的大多数只是一个表....

我尝试了很多方法,比如执行查询db.execSQL(查询)来创建onCreate中的每个表但是它有错误..

SO创建多个表的任何好策略???我应该为每个表创建许多类表示扩展SQLiteOpenHelper ???

THX

这是我的类的一部分扩展SQLiteOpenHelper

public void onCreate(SQLiteDatabase db) {
    // TODO Auto-generated method stub
    try{
        db.execSQL(CREATE_TABLE_1);
        db.execSQL(CREATE_TABLE_2);
        db.execSQL(CREATE_TABLE_3);
    }catch( Exception e){
        Log.e("dbAdapter", e.getMessage().toString());
    }

}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    // TODO Auto-generated method stub
    db.execSQL("DROP TABLE IF EXISTS " + TABLE_1);
    db.execSQL("DROP TABLE IF EXISTS " + TABLE_2);
    db.execSQL("DROP TABLE IF EXISTS " + TABLE_3);
    onCreate(db);
}

似乎是table2,而table3没有创建 因为当我将数据插入表2时,我得到错误 - 没有找到这样的table2 !!!

这里是我创建的表字符串:

//create script patient
public static String CREATE_TABLE_1= "create table " +
TABLE_USER + " (" +
USER_ID + " integer primary key autoincrement, " +
USER_NAME + " text not null, " +
DEVICE_KEY + " text not null  );" ;

public static String CREATE_TABLE_2= "create table " +
TABLE_GPS_SETTING + " (" +
SETTIN + " integer primary key autoincrement, " +
REFRESVAL + " long not null, " +
ODE + " varchar(20), " +
_TYPE + " varchar(20) );" ;

public static String CREATE_TABLE_3= "create table " +
TABLE_W + " (" +
GPD + " integer primary key autoincrement, " +
LITUDE + " double, " +
LITUDE + " double, " + 
ATUDE + "integer,"+
M + "integer,"+
DTION + "integer,"+
DANCE + "integer,"+
LDD + "integer,"+
SESID + "double,"+
ACCCY + "double,"+
TMP + "long,"+
TATE + "TEXT,"+
D_ID + "TEXT);" ;

有什么想法吗?

2 个答案:

答案 0 :(得分:4)

您可以像这样创建任意数量的表格。

 db.execSQL(TABLE1);
 db.execSQL(TABLE2);

其中TABLE1是包含表创建命令的字符串

问题是您在创建数据库后尝试创建表。卸载应用程序,然后使用sql语句运行以在数据库中创建表。

答案 1 :(得分:4)

我相信有no such thing as a varchar in SQLite。使用text