2016-05-26 104 views
0

我不知道爲什麼,但是當我登錄到我的應用程序不會創建SQLite數據庫SQLite不插入值

的價值觀,這是我的代碼:

public class SQLiteHandler extends SQLiteOpenHelper { 

    private static final String TAG = SQLiteHandler.class.getSimpleName(); 

    // All Static variables 
    // Database Version 
    private static final int DATABASE_VERSION = 1; 

    // Database Name 
    private static final String DATABASE_NAME = "android_api"; 

    // Login table name 
    private static final String TABLE_USERS = "users"; 

    // Login Table Columns names 
    private static final String KEY_ID = "id"; 
    private static final String KEY_NAME = "nome"; 
    private static final String KEY_EMAIL = "email"; 
    private static final String KEY_UID = "uid"; 
    private static final String KEY_DATA_NASCIMENTO = "data_nascimento"; 
    private static final String KEY_DATA_CRIADO = "user_datacriado"; 

    public SQLiteHandler(Context context) { 
     super(context, DATABASE_NAME, null, DATABASE_VERSION); 
    } 

    // Creating Tables 
    @Override 
    public void onCreate(SQLiteDatabase db) { 
     String CREATE_LOGIN_TABLE = "CREATE TABLE " + TABLE_USERS + "(" 
       + KEY_ID + " INTEGER PRIMARY KEY," + KEY_NAME + " TEXT," 
       + KEY_EMAIL + " TEXT UNIQUE," + KEY_UID + " TEXT," 
       + KEY_DATA_CRIADO + " TEXT" + ")"; 
     db.execSQL(CREATE_LOGIN_TABLE); 

     Log.d(TAG, "Database tables created"); 
    } 

    // Upgrading database 
    @Override 
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 
     // Drop older table if existed 
     db.execSQL("DROP TABLE IF EXISTS " + TABLE_USERS); 

     // Create tables again 
     onCreate(db); 
    } 

    /** 
    * Storing user details in database 
    * */ 
    public void addUser(String nome, String email, String uid, String data_nascimento, String user_datacriado) { 
     SQLiteDatabase db = this.getWritableDatabase(); 

     ContentValues values = new ContentValues(); 
     values.put(KEY_NAME, nome); // Name 
     values.put(KEY_EMAIL, email); // Email 
     values.put(KEY_UID, uid); // Email 
     values.put(KEY_DATA_NASCIMENTO, data_nascimento); // Created At 
     values.put(KEY_DATA_CRIADO, user_datacriado); // Created At 

     // Inserting Row 
     long id = db.insert(TABLE_USERS, null, values); 
     db.close(); // Closing database connection 

     Log.d(TAG, "New user inserted into sqlite: " + id); 
    } 

    /** 
    * Getting user data from database 
    * */ 
    public HashMap<String, String> getUserDetails() { 
     HashMap<String, String> user = new HashMap<String, String>(); 
     String selectQuery = "SELECT * FROM " + TABLE_USERS; 

     SQLiteDatabase db = this.getReadableDatabase(); 
     Cursor cursor = db.rawQuery(selectQuery, null); 
     // Move to first row 
     cursor.moveToFirst(); 
     if (cursor.getCount() > 0) { 
      user.put("nome", cursor.getString(1)); 
      user.put("email", cursor.getString(2)); 
      user.put("uid", cursor.getString(3)); 
      user.put("created_at", cursor.getString(4)); 
     } 
     cursor.close(); 
     db.close(); 
     // return user 
     Log.d(TAG, "Fetching user from Sqlite: " + user.toString()); 

     return user; 
    } 

    /** 
    * Re crate database Delete all tables and create them again 
    * */ 
    public void deleteUsers() { 
     SQLiteDatabase db = this.getWritableDatabase(); 
     // Delete All Rows 
     db.delete(TABLE_USERS, null, null); 
     db.close(); 

     Log.d(TAG, "Deleted all user info from sqlite"); 
    } 
} 

這是在登錄片段:

@Override 
      public void onResponse(String response) { 
       Log.d(TAG, "Login Response: " + response.toString()); 
       hideDialog(); 

       try { 
        JSONObject jObj = new JSONObject(response); 
        boolean error = jObj.getBoolean("error"); 

        // Check for error node in json 
        if (!error) { 
         // user successfully logged in 
         // Create login session 
         session.setLogin(true); 

         // Now store the user in SQLite 
         String uid = jObj.getString("uid"); 

         JSONObject user = jObj.getJSONObject("user"); 
         String name = user.getString("nome"); 
         String email = user.getString("email"); 
         String data_nascimento = user.getString("data_nascimento"); 
         String user_datacriado = user.getString("user_datacriado"); 

         // Inserting row in users table 
         db.addUser(name, email, uid, data_nascimento, user_datacriado); 
         // Launch main activity 
         //Intent intent = new Intent(LoginActivity.this, 
           //MainActivity.class); 
         //startActivity(intent); 
         //finish(); 

         // Launch login activity 
         Intent intent = new Intent(
           getActivity(), 
           MainActivity.class); 
         startActivity(intent); 
        } else { 
         // Error in login. Get the error message 
         String errorMsg = jObj.getString("error_msg"); 
         Toast.makeText(getContext(), 
           errorMsg, Toast.LENGTH_LONG).show(); 
        } 
       } catch (JSONException e) { 
        // JSON error 
        e.printStackTrace(); 
        Toast.makeText(getContext(), "Json error: " + e.getMessage(), Toast.LENGTH_LONG).show(); 
       } 

      } 
     }, new Response.ErrorListener() { 
... 

儘管調試,adduser(...)方法:

long id = db.insert(TABLE_USERS, null, values); 

id總是-1我不知道爲什麼。

+1

在'KEY_DATA_NASCIMENTO'名稱的表中沒有可用的列,那麼爲什麼要使用'values.put(KEY_DATA_NASCIMENTO,data_nascimento);'line? –

+0

我不確定檢查這個KEY_ID是你插入它的主鍵嗎? – Raghavendra

+1

使用'insertOrThrow()'獲取有用的錯誤消息。 –

回答

1

一個問題是您的CREATE TABLE缺少您試圖插入值的data_nascimento列的SQL。

添加後,您可以卸載您的應用程序來重新創建數據庫。

+0

非常感謝。昨天我鎖定了它,我知道我會忘記它:) – PedroBarbosa