Итак, у меня возникла проблема с созданием дополнительной таблицы, изначально я создал таблицу с названием Contacts, которая отлично работала.Таблица не создается SQLite
Затем я интегрировал дополнительную таблицу в мой метод onCreate в моем DBHandler, который должен быть создан, это когда я начал получать проблемы.
Прежде всего logcat просто отказался бы даже сообщить об ошибке, почему он не работал, и я удалил программу с моего avd, чтобы начать с новой новой папки базы данных, если это была проблема, и теперь он выдал синтаксическую ошибку рядом с моими табличными сообщениями, я также изменил свой DBVersion no.
Вот мой DBHandler, я считаю, что проблема возникает внутри метода onCreate, с помощью таблицы Create messages.
private static final int DATABASE_VERSION = 2;
private static final String COLUMN_ID = "id";
private static final String DATABASE_NAME = "forensicsproject";
//====================================================
private static final String TABLE_CONTACTS = "contacts";
private static final String CONTACTS_COLUMN_NAME = "name";
private static final String CONTACTS_COLUMN_PHONENUMBER = "phone_number";
//====================================================
private static final String TABLE_MESSAGES = "messages";
private static final String MESSAGES_COLUMN_PERSON = "person";
private static final String MESSAGES_COLUMN_BODY = "body";
private static final String MESSAGES_COLUMN_ADDRESS = "address";
private static final String MESSAGES_COLUMN_TYPE = "type";
//private static final MESSAGES_COLUMN_DATE = "date"; //TODO
public DBHandler(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
String CREATE_CONTACTS_TABLE = "CREATE TABLE " + TABLE_CONTACTS + "("
+ COLUMN_ID + " INTEGER PRIMARY KEY," + CONTACTS_COLUMN_NAME + " TEXT,"
+ CONTACTS_COLUMN_PHONENUMBER + " TEXT" + ")";
db.execSQL(CREATE_CONTACTS_TABLE);
Log.e("CONTACT", "CREATED");
String CREATE_MESSAGES_TABLE = "CREATE TABLE" + TABLE_MESSAGES + "("
+ COLUMN_ID + " INTEGER PIMRARY KEY," + MESSAGES_COLUMN_PERSON + " TEXT,"
+ MESSAGES_COLUMN_BODY + " TEXT," + MESSAGES_COLUMN_ADDRESS + " TEXT,"
+ MESSAGES_COLUMN_TYPE + " TEXT" + ")";
db.execSQL(CREATE_MESSAGES_TABLE);
Log.e("MESSAGES", "CREATED");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXISTS " + TABLE_CONTACTS + TABLE_MESSAGES);
onCreate(db);
}
public void addContact(Contact contact) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(CONTACTS_COLUMN_NAME, contact.getName());
values.put(CONTACTS_COLUMN_PHONENUMBER, contact.getPhoneNumber());
db.insert(TABLE_CONTACTS, null, values);
Log.e("CONTACTS", "INSERTED");
db.close();
}
public void getMessages(Messages messages) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(MESSAGES_COLUMN_PERSON, messages.getPerson());
values.put(MESSAGES_COLUMN_BODY, messages.getBody());
values.put(MESSAGES_COLUMN_ADDRESS, messages.getAddress());
values.put(MESSAGES_COLUMN_TYPE, messages.getType());
db.insert(TABLE_MESSAGES, null, values);
Log.e("MESSAGES", "INSERTED");
db.close();
}
}
показать свой логарифт, пожалуйста – Jordan
Привет, пожалуйста, проверьте это [ссылка] (http://www.androhub.com/android-sqlite-database/). –
'Строка CREATE_MESSAGES_TABLE = "CREATE TABLE" + TABLE_MESSAGES + "(" + column_id + "ЦЕЛОЕ PIMRARY КЛЮЧ" + MESSAGES_COLUMN_PERSON + "Текст" + MESSAGES_COLUMN_BODY + "Текст" + MESSAGES_COLUMN_ADDRESS + "Текст" + MESSAGES_COLUMN_TYPE + "ТЕКСТ" + ")"; "Полагаю, вы имели в виду ** ПЕРВИЧНЫЙ **. –