繁体   English   中英

如何使用来自 Java 字符串变量的参数在我的 SQLite 数据库中创建一个新表?

[英]How can I create a new table in my SQLite Database using a param from a Java String variable?

我正在尝试使用预先存在的 Java 字符串变量在 SQLite 中创建一个新表,但变量名未被识别为 Java ......我该如何解决这个问题?

    String name1 = textViewPerson1.getText().toString();
    String name2 = textViewPerson2.getText().toString();
    String name3 = textViewPerson3.getText().toString();

    try{
        SQLiteDatabase database = this.openOrCreateDatabase("NewUsers",MODE_PRIVATE,null);
        database.execSQL("CREATE TABLE IF NOT EXISTS newUsers (name VARCHAR, hitCount INT(2))");
        database.execSQL("INSERT INTO newusers (name,age) VALUES (name1,17)");
        database.execSQL("INSERT INTO newusers (name,age) VALUES (name2, 16)");
    }catch (Exception e){
        e.printStackTrace();
    }

}

我建议您在 sql 语句中使用引号并为您的 varchar 指定值,例如:

database.execSQL("CREATE TABLE IF NOT EXISTS 'newUsers' ('name' VARCHAR(25), 'hitCount' INT(2))");

您应该在插入行中退出“字符串”上下文,如下所示:

database.execSQL("INSERT INTO 'newusers' (name,age) VALUES ('"+name1+"',17)");

显然存在更多像 StringBuilder 这样的清理选项,但这应该会有所帮助。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM