【问题标题】:How to create more than one table in sqlite in android?如何在android的sqlite中创建多个表?
【发布时间】:2011-07-21 17:39:49
【问题描述】:

我的数据库中有三个表。我尝试了很多关于在 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);" ;

有什么想法吗?

【问题讨论】:

  • 您遇到什么错误?你的 sql 语句是什么样的?在你的问题中提供这个。我们无法猜测这些事情。
  • 这在应用程序中并不是真正的错误,因为我只需要在 sqlite 的数据库中创建表,但它只创建第一个表 table1 n 没有表 2 n 3 为什么?谢谢
  • 你看到了吗?提供一个好的问题,提供好的答案会更容易;)

标签: android database sqlite


【解决方案1】:

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

【讨论】:

  • @sayvortana - 有时这就是生活 :) ...记得标记正确答案!
【解决方案2】:

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

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

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

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

【讨论】:

  • 你能看看我刚刚编辑的问题吗,因为我已经这样做了
  • 您的字段类型有问题。请参阅 sqlite sqlite.org/datatype3.html 中支持的列类型
猜你喜欢
  • 2011-07-10
  • 2016-12-05
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-06-02
相关资源
最近更新 更多