因为我是 android 编程的新手,所以我正在创建一个表并用 edittext 中的文本命名它。我该怎么做。搜索问题但没有得到任何答案。我的应用程序需要在运行时创建许多表。我正在使用 SQLiteOpenHelper 类所以请帮我做。我已经创建了一个函数来创建表,并且在 onCreate()/onUpgrade 函数中什么也没写。
public void createClass(String table){
shuddhHelper = new DbHelper(shuddhContext);
SQLiteDatabase db = shuddhHelper.getWritableDatabase();
db.execSQL("CREATE TABLE " + table + " (" +
STUDENT_NAME + " TEXT NOT NULL, " +
ROLL_NO + " TEXT PRIMARY KEY, " +
STUDENT_PHONE + " INTEGER NOT NULL, " +
PARENT_PHONE + " INTEGER NOT NULL);"
);
}
并在 onClickListener 中调用这样的函数
className = "" + spinner.getSelectedItem().toString() + " "
+ sessionStart.getText().toString() + " - "
+ sessionEnd.getText().toString();
AMData classtable = new AMData(AddScreen.this);
classtable.open();
classtable.createClass(className);
classtable.close();
Intent myIntent = new Intent(AddScreen.this, NewStudent.class);
myIntent.putExtra("className", className);
startActivity(myIntent);
并在此处打开和关闭功能:
public AMData open() {
shuddhHelper = new DbHelper(shuddhContext);
shuddhDataBase = shuddhHelper.getWritableDatabase();
return this;
}
public void close(){
shuddhHelper.close();
}
最佳答案
您的表名错误,因为它包含空格。
尝试以下操作:
className = "" + spinner.getSelectedItem().toString() + "_"
+ sessionStart.getText().toString() + "-"
+ sessionEnd.getText().toString();
顺便说一句:如果您必须连接多个字符串,最好使用 StringBuilder。它使用更少的内存空间和计算时间。
String class = new StringBuilder().append(spinner.getSelectedItem().toString())
.append("_")
.append(sessionStart.getText().toString())
.append("-")
.append(sessionEnd.getText().toString())
.toString();
关于android - 在sqlite中运行时创建数据库表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22755478/