接近语法错误(代码 1)插入 Android SQLite
near synatx error (code 1) insert Android SQLite
我正在创建一个通讯录应用程序,用户可以在其中输入姓名、电子邮件地址和电话号码。我希望将此数据保存在数据库中,但我似乎无法使用插入方法:
我得到的错误是:
android.database.sqlite.SQLiteException: near "Number": syntax error (code 1): , while compiling: INSERT INTO CONTACTSTABLE(Phone Number,Email Address,Name) VALUES (?,?,?)
这里是我放置数据库的地方:
public class DatabaseAdapter{
MySQLiteHelper dbhelper;
public DatabaseAdapter(Context context){
dbhelper=new MySQLiteHelper(context);
}
public long insertData(String name, String phone, String email){
SQLiteDatabase db=dbhelper.getWritableDatabase();
ContentValues contentValues=new ContentValues();
contentValues.put(dbhelper.NAME, name);
contentValues.put(dbhelper.NUMBER, phone);
contentValues.put(dbhelper.EMAIL, email);
long id=db.insert(MySQLiteHelper.TABLE_NAME, null, contentValues);
return id;
}
static class MySQLiteHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "contacts.db";
private static final String TABLE_NAME = "CONTACTSTABLE";
private static final String UID = "_id";
private static final String NAME = "Name";
private static final String EMAIL = "Email Address";
private static final String NUMBER = "Phone Number";
private static final int DATABASE_VERSION = 1;
private static final String DATABASE_CREATE = "CREATE TABLE "
+ TABLE_NAME + " ( " + UID
+ " INTEGER PRIMARY KEY AUTOINCREMENT, " + NAME
+ " TEXT, " + NUMBER
+ " TEXT, " + EMAIL
+ " TEXT" + " ) ";
public MySQLiteHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase database) {
database.execSQL(DATABASE_CREATE);
}
//onupgrade calls database needs to be upgraded. use to drop tables, called when you update data version
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
Log.w(MySQLiteHelper.class.getName(),
"Upgrading database from version " + oldVersion + " to "
+ newVersion + ", which will destroy all old data");
db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
onCreate(db);
}}}
这是我的 MainActivity,我在其中调用了 "insertData" 方法(为了简单起见,我去掉了很多其他东西):
public class MainActivity extends ActionBarActivity implements View.OnClickListener {
EditText name;
EditText number;
EditText email;
Button submit;
DatabaseAdapter dbHelper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
name=(EditText) findViewById(R.id.name);
number=(EditText) findViewById(R.id.number);
email=(EditText) findViewById(R.id.email);
submit=(Button) findViewById(R.id.button);
dbHelper=new DatabaseAdapter(this);
submit.setOnClickListener(this);
}
@Override
public void onClick(View v) {
if (isEmpty(name) || isEmpty(number) || isEmpty(email))
preview.setText("Please fill out all of the boxes before submitting");
else {
String n=name.getText().toString();
String p=number.getText().toString();
String e=email.getText().toString();
Contact c = new Contact(n,p,e);
ContactArray.contacts.add(c);
dbHelper.insertData(n,p,e);
}}
从您的列名中删除所有 space,然后重试并告诉我们是否还有其他编译错误。
您可以使用 _
代替 space,例如 Phone_number
.
我正在创建一个通讯录应用程序,用户可以在其中输入姓名、电子邮件地址和电话号码。我希望将此数据保存在数据库中,但我似乎无法使用插入方法: 我得到的错误是:
android.database.sqlite.SQLiteException: near "Number": syntax error (code 1): , while compiling: INSERT INTO CONTACTSTABLE(Phone Number,Email Address,Name) VALUES (?,?,?)
这里是我放置数据库的地方:
public class DatabaseAdapter{
MySQLiteHelper dbhelper;
public DatabaseAdapter(Context context){
dbhelper=new MySQLiteHelper(context);
}
public long insertData(String name, String phone, String email){
SQLiteDatabase db=dbhelper.getWritableDatabase();
ContentValues contentValues=new ContentValues();
contentValues.put(dbhelper.NAME, name);
contentValues.put(dbhelper.NUMBER, phone);
contentValues.put(dbhelper.EMAIL, email);
long id=db.insert(MySQLiteHelper.TABLE_NAME, null, contentValues);
return id;
}
static class MySQLiteHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "contacts.db";
private static final String TABLE_NAME = "CONTACTSTABLE";
private static final String UID = "_id";
private static final String NAME = "Name";
private static final String EMAIL = "Email Address";
private static final String NUMBER = "Phone Number";
private static final int DATABASE_VERSION = 1;
private static final String DATABASE_CREATE = "CREATE TABLE "
+ TABLE_NAME + " ( " + UID
+ " INTEGER PRIMARY KEY AUTOINCREMENT, " + NAME
+ " TEXT, " + NUMBER
+ " TEXT, " + EMAIL
+ " TEXT" + " ) ";
public MySQLiteHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase database) {
database.execSQL(DATABASE_CREATE);
}
//onupgrade calls database needs to be upgraded. use to drop tables, called when you update data version
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
Log.w(MySQLiteHelper.class.getName(),
"Upgrading database from version " + oldVersion + " to "
+ newVersion + ", which will destroy all old data");
db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
onCreate(db);
}}}
这是我的 MainActivity,我在其中调用了 "insertData" 方法(为了简单起见,我去掉了很多其他东西):
public class MainActivity extends ActionBarActivity implements View.OnClickListener {
EditText name;
EditText number;
EditText email;
Button submit;
DatabaseAdapter dbHelper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
name=(EditText) findViewById(R.id.name);
number=(EditText) findViewById(R.id.number);
email=(EditText) findViewById(R.id.email);
submit=(Button) findViewById(R.id.button);
dbHelper=new DatabaseAdapter(this);
submit.setOnClickListener(this);
}
@Override
public void onClick(View v) {
if (isEmpty(name) || isEmpty(number) || isEmpty(email))
preview.setText("Please fill out all of the boxes before submitting");
else {
String n=name.getText().toString();
String p=number.getText().toString();
String e=email.getText().toString();
Contact c = new Contact(n,p,e);
ContactArray.contacts.add(c);
dbHelper.insertData(n,p,e);
}}
从您的列名中删除所有 space,然后重试并告诉我们是否还有其他编译错误。
您可以使用 _
代替 space,例如 Phone_number
.