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

标签 android database sqlite

我的数据库中有三个表。我尝试了很多关于在 sqlite 中创建数据库的示例,结果发现它们中的大多数只是一个表....

我尝试了很多方法,比如执行查询 db.execSQL(query) 在 onCreate 中创建每个表,但它出错了..

SO 有什么好的策略可以创建多个表???我应该为每个表创建许多类代表扩展 SQLiteOpenHelper 吗???

谢谢

这是我的类扩展 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 时出现错误 - 找不到这样的表 2!!!

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

//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);" ;

有什么想法吗?

最佳答案

我相信有 no such thing as a varchar in SQLite .使用文本

关于android - 如何在android中的sqlite中创建多个表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6773207/

相关文章:

php - 使用 PHP 将 XML 数据存储到 MySQL

android - 添加到 android 后无法从数据库中看到更改?

SQL 查询慢?应该吗?

android - ViewPager 内的 ViewPager。如何水平滚动父寻呼机而不是滚动子寻呼机,但保持子寻呼机垂直滚动?

java - 生成公钥/私钥之前的 RSA 加密强制关闭

java - 膨胀类 NavigationView 时出错

sqlite - 添加迁移命令在 UWP 应用程序的 EF 7 中不起作用

javascript - HTML5 Canvas 支持和 Android Webview

database - docker-compose:将变量传递给 tomcat 上下文

mysql - db :schema:dump on RDS with mysql. 错误:无法转储表 "",因为以下 NoMethodError 未定义方法 `type' for "int(11)":String