java - 值没有插入到 SQLite 数据库

标签 java android sqlite

我使用 two edittexts 创建了一个用于测试的应用程序( Emailpassword )和 2 个按钮( submitviewdata )。我正在调试这个应用程序,它工作正常。

我想通过再添加一个 Edittext 来更新此应用程序( Name ) 并升级 SQLite DatabaseonUpgrade()方法。代码如下所示。

public class DatabaseHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME="upgrade";
private static final int DATABASE_VERSION=2;

//details table details
public static final String TABLE_NAME_Details="details";
public static final String USERNAME="USERNAME";
public static final String PASSWORD="PASSWORD";
public static final String Name="Name"; //newly added column in version 2


public static final String TABLE_NAME_Details_temp="temp";
public static final String USERNAME_temp="USERNAME";
public static final String PASSWORD_temp="PASSWORD";
public static final String Name_temp="Name";

//create table statements for version 2
public static final String Create_Table_Details = "CREATE TABLE "
+ TABLE_NAME_Details + " (" + USERNAME + " TEXT PRIMARY KEY,"
+ PASSWORD + " TEXT ,"
+ Name + " TEXT"
+")";

/*   creation for version 1
private static final String Create_Table_Details = "CREATE TABLE " + 
TABLE_NAME_Details + "("
+ USERNAME + " TEXT PRIMARY KEY,"
+ PASSWORD + " TEXT"
+ ")";*/
//Alter table statements FOR onUpgrade()
//private static final String ALTER_Details = "ALTER TABLE " + 
TABLE_NAME_Details + " ADD COLUMN" + Name + " TEXT";
public DatabaseHelper(Context context)
{
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
try{
db.execSQL(Create_Table_Details);
Log.d("database","installed successfully");
}catch (Exception e)
{
e.printStackTrace();
Log.e("/test","Exception due to"+e.toString());
}
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) 
{

String TEMP_CREATE_CONTACTS_TABLE = "CREATE TABLE " + 
TABLE_NAME_Details_temp + "("
+ USERNAME_temp + " TEXT," + PASSWORD_temp + " TEXT )";
db.execSQL(TEMP_CREATE_CONTACTS_TABLE);

db.execSQL("INSERT INTO " + TABLE_NAME_Details_temp + " SELECT " +  
USERNAME + ", "
+  PASSWORD + " FROM " + TABLE_NAME_Details);

db.execSQL("DROP TABLE "+ TABLE_NAME_Details);

String CREATE_CONTACTS_TABLE = "CREATE TABLE " + TABLE_NAME_Details + "("
+ USERNAME + " TEXT," + PASSWORD + " TEXT," + Name + " TEXT )";
db.execSQL(CREATE_CONTACTS_TABLE);
db.execSQL("INSERT INTO " + TABLE_NAME_Details + " SELECT " +  
USERNAME_temp + ", "
+  PASSWORD_temp + ", " +  Name_temp + ", " + null + " FROM " + 
TABLE_NAME_Details_temp);
db.execSQL("DROP TABLE " + TABLE_NAME_Details);
}

public boolean insertData(String username, String password,String name)
{
try{
SQLiteDatabase db = this.getWritableDatabase();
ContentValues contentValues=new ContentValues();
contentValues.put(USERNAME,username);
contentValues.put(PASSWORD,password);
contentValues.put(Name,name);
long result=db.insertOrThrow(TABLE_NAME_Details, null, contentValues);
if(result==-1)
return false;
else
return true;
}catch(Exception e)
{
e.printStackTrace();
Log.e("/test","Exception due to"+e.toString());
return false;
}
}
//update value
public boolean updatePassword(String LoggedUsername)
{
SQLiteDatabase db = null;
try {
db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(PASSWORD, "test");
if (db.isOpen()) {
db.update(TABLE_NAME_Details, values, USERNAME + "='" + 
LoggedUsername+"'",null);
return true;
}
else
return false;
} catch (Exception e) {
Log.d("eEmp/DBUpdateUser ", e.toString());
return false;
}
}
//getting data from database
public Cursor getAllData()
{
SQLiteDatabase db = this.getWritableDatabase();
Cursor res = db.rawQuery("select * from "+TABLE_NAME_Details,null);
return res;
}
}

我安装了第一个版本并且工作正常,然后卸载了。

卸载后,安装第二版本并存储数据。它也工作正常。

当我尝试在 Debug模式下使用第二版本更新第一个版本时,应用程序更新成功,并且在第一个版本中输入的数据可见。当我尝试将数据存储在第二个版本中时,数据没有插入到 sqlite 数据库中。为什么?

调试时,调用了插入方法,但这里 if(result==-1)我得到 -1 而不是 1。因此,数据控制来自该方法,并且数据没有插入到数据库中。

例如:在第一个版本中:我输入用户名:stackoverflow和密码stackoverflow 。 我将应用程序更新到第二版本并更新成功。现在我输入用户名:hello密码:hello名称:hello然后单击提交按钮。

之后如果我点击viewdata按钮:显示用户名:stackoverflow密码 stackoverflow名称:空。但不显示第二版本中插入的数据。

如有任何帮助,我们将不胜感激。请帮助我找到正确的解决方案。

谢谢。

最佳答案

试试这个..

      // Upgrading database
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

        String TEMP_CREATE_CONTACTS_TABLE = "CREATE TABLE " + TEMP_TABLE_CONTACTS + "("
                + KEY_ID + " INTEGER PRIMARY KEY," + KEY_NAME + " TEXT," + KEY_ADDRESS + " TEXT)";
        db.execSQL(TEMP_CREATE_CONTACTS_TABLE);

        // Create an temporaty table that can store data of older version

        db.execSQL("INSERT INTO " + TEMP_TABLE_CONTACTS + " SELECT " +  KEY_ID + ", "
                +  KEY_NAME + ", " +  KEY_ADDRESS + " FROM " + TABLE_CONTACTS);

// Insert data into temporary table from existing older version database (that doesn't contains ADDRESS2 //column)

        db.execSQL("DROP TABLE "+ TABLE_CONTACTS);
// Remove older version database table

        String CREATE_CONTACTS_TABLE = "CREATE TABLE " + TABLE_CONTACTS + "("
                + KEY_ID + " INTEGER PRIMARY KEY," + KEY_NAME + " TEXT," + KEY_ADDRESS + " TEXT," + KEY_ADDRESS2 + " TEXT )";
        db.execSQL(CREATE_CONTACTS_TABLE);

// Create new table with ADDRESS2 column
        db.execSQL("INSERT INTO " + TABLE_CONTACTS + " SELECT " +  KEY_ID + ", "
                +  KEY_NAME + ", " +  KEY_ADDRESS + ", " + null + " FROM " + TEMP_TABLE_CONTACTS);
// Insert data ffrom temporary table that doesn't have ADDRESS2 column so left it that column name as null.     
        db.execSQL("DROP TABLE " + TEMP_TABLE_CONTACTS);
    }

关于java - 值没有插入到 SQLite 数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47898999/

相关文章:

Java OSX MessageDigest.getInstance ("MD5") 挂起

java - 使用 Java 下载 UTF-16 JSON 字符串

c# - ORMLite 下的 SQLite 不允许在事务完成后执行任何操作

android - 警报对话框 + Intent

ios - SQLITE 数据库与 iOS 和 ICloud

sql - 指向多个表之一的外键约束

java - java中的Scanner如何向hasNext()返回true?

java - 通过 Eclipse 调试 Jline2 应用程序

java - 使用 (Java) AudioInputStream 打开 wav 文件时出现问题

java - 记住在单选 AlertDialog 中选择的内容