所以基本上代码工作正常,直到我点击我评论“//这没有工作!!!”。然后没有任何内容输入数据库。任何人都知道为什么我可以为“StringCategory_Table”输入它们而不是其他的那些?
public class SetupOfSQLite{
private DBHelper myHelper;
private final Context myContext;
private SQLiteDatabase myDatabase;
private static final String DATABASE_NAME = "restaurantDatabase";
private static final int DATABASE_VERSION = 1;
private static final String COLUMN_RESTAURANT = "RestaurantName";
private static final String COLUMN_CATEGORIES= "CategoryName";
public static String currentRestaurant = null;
public static String deletingRestaurant= null;
public static final String American_Table ="Restaurant_List_American";
public static final String Asian_Table = "Restaurant_List_Asian";
public static final String BarPub_Table = "Restaurant_List_BarPub";
public static final String Breakfast_Table ="Restaurant_List_Breakfast";
public static final String FastFood_Table ="Restaurant_List_FastFood";
public static final String Healthy_Table = "Restaurant_List_Healthy";
public static final String Mexican_Table ="Restaurant_List_Mexican";
public static final String SeaFood_Table = "Restaurant_List_SeaFood";
public static final String Italian_Table = "Restaurant_List_Italian";
public static final String Deserts_Table = "Restaurant_List_Desert";
public static final String StringCategory_Table = "Categories_of_Restaurants";
static ContentValues contValues = new ContentValues();
private static class DBHelper extends SQLiteOpenHelper {
public DBHelper (Context ctx){
super (ctx, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("CREATE TABLE " + American_Table + " (" + _ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_RESTAURANT + " TEXT NOT NULL);");
db.execSQL("CREATE TABLE " + Asian_Table + " (" + _ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_RESTAURANT + " TEXT NOT NULL);");
db.execSQL("CREATE TABLE " + BarPub_Table + " (" + _ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_RESTAURANT + " TEXT NOT NULL);");
db.execSQL("CREATE TABLE " + Breakfast_Table + " (" + _ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_RESTAURANT + " TEXT NOT NULL);");
db.execSQL("CREATE TABLE " + Deserts_Table + " (" + _ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_RESTAURANT + " TEXT NOT NULL);");
db.execSQL("CREATE TABLE " + FastFood_Table + " (" + _ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_RESTAURANT + " TEXT NOT NULL);");
db.execSQL("CREATE TABLE " + Healthy_Table + " (" + _ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_RESTAURANT + " TEXT NOT NULL);");
db.execSQL("CREATE TABLE " + Italian_Table + " (" + _ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_RESTAURANT + " TEXT NOT NULL);");
db.execSQL("CREATE TABLE " + Mexican_Table + " (" + _ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_RESTAURANT + " TEXT NOT NULL);");
db.execSQL("CREATE TABLE " + SeaFood_Table + " (" + _ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_RESTAURANT + " TEXT NOT NULL);");
// The table below is for keeping the categories persistent
db.execSQL("CREATE TABLE " + StringCategory_Table + " (" + _ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_CATEGORIES + " TEXT NOT NULL);");
// The table below is for suggestions
// now I'll create some entries for default categories
contValues.put(COLUMN_CATEGORIES, "American");
db.insert(StringCategory_Table, COLUMN_CATEGORIES, contValues);
contValues.put(COLUMN_CATEGORIES, "Asian");
db.insert(StringCategory_Table, COLUMN_CATEGORIES, contValues);
contValues.put(COLUMN_CATEGORIES, "Bar or Pub");
db.insert(StringCategory_Table, COLUMN_CATEGORIES, contValues);
contValues.put(COLUMN_CATEGORIES, "Breakfast");
db.insert(StringCategory_Table, COLUMN_CATEGORIES, contValues);
contValues.put(COLUMN_CATEGORIES, "Deserts");
db.insert(StringCategory_Table, COLUMN_CATEGORIES, contValues);
contValues.put(COLUMN_CATEGORIES, "FastFood");
db.insert(StringCategory_Table, COLUMN_CATEGORIES, contValues);
contValues.put(COLUMN_CATEGORIES, "Healthy"); // this represents "Healthy" category
db.insert(StringCategory_Table, COLUMN_CATEGORIES, contValues);
contValues.put(COLUMN_CATEGORIES, "Italian");
db.insert(StringCategory_Table, COLUMN_CATEGORIES, contValues);
contValues.put(COLUMN_CATEGORIES, "Mexican");
db.insert(StringCategory_Table, COLUMN_CATEGORIES, contValues);
contValues.put(COLUMN_CATEGORIES, "SeaFood");
db.insert(StringCategory_Table, COLUMN_CATEGORIES, contValues);
// now ill add in some restaurants for the first time the user installs the app
//THIS DOESNT WORK!!!
contValues.put(COLUMN_RESTAURANT, "Olive Guarden");
db.insert(Italian_Table, COLUMN_RESTAURANT, contValues);
contValues.put(COLUMN_RESTAURANT, "Red Lobster");
db.insert(SeaFood_Table, COLUMN_RESTAURANT, contValues);
contValues.put(COLUMN_RESTAURANT, "Outback");
db.insert(American_Table, COLUMN_RESTAURANT, contValues);
contValues.put(COLUMN_RESTAURANT, "Dunkin' Donuts");
db.insert(Breakfast_Table, COLUMN_RESTAURANT, contValues);
contValues.put(COLUMN_RESTAURANT, "Taco Bell");
db.insert(Mexican_Table, COLUMN_RESTAURANT, contValues);
contValues.put(COLUMN_RESTAURANT, "Burger King");
db.insert(FastFood_Table, COLUMN_RESTAURANT, contValues); //1st entry for fast food
contValues.put(COLUMN_RESTAURANT, "McDonald's");
db.insert(FastFood_Table, COLUMN_RESTAURANT, contValues); // 2 entries for fast food
contValues.put(COLUMN_RESTAURANT, "Cold Stone");
db.insert(Deserts_Table, COLUMN_RESTAURANT, contValues);
contValues.put(COLUMN_RESTAURANT, "Panda");
db.insert(Asian_Table, COLUMN_RESTAURANT, contValues);
contValues.put(COLUMN_RESTAURANT, "Subway");
db.insert(Healthy_Table, COLUMN_RESTAURANT, contValues);
}
答案 0 :(得分:3)
我认为您的contValues
变量具有过时的列信息,这对于餐馆表没有意义。请尝试以下方法:
contValues.clear();
contValues.put(COLUMN_RESTAURANT, "Olive Guarden");