Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sqlite/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
ANDROID SQLITE-多次更新时出错_Android_Sqlite - Fatal编程技术网

ANDROID SQLITE-多次更新时出错

ANDROID SQLITE-多次更新时出错,android,sqlite,Android,Sqlite,我正在尝试更新sqlite数据库中的某些值。如果我更新了一个正确的列值,并且当我尝试更新多个没有主键的值时,我的活动将终止。如果能够知道此错误的原因,我将不胜感激 我的示例代码: 这段代码运行良好(这里我只更新了列) 这段代码很糟糕:(这里我试图更新多列) 用户数据对象在哪里?您可以设置调试点并调试应用程序,以检查是否有任何问题。尝试移动myDB.close();毕竟updateStringData(…);谢谢,在将myDB.close()移动到updateData()的底部之后,我的问题仍然存

我正在尝试更新sqlite数据库中的某些值。如果我更新了一个正确的列值,并且当我尝试更新多个没有主键的值时,我的活动将终止。如果能够知道此错误的原因,我将不胜感激

我的示例代码:

这段代码运行良好(这里我只更新了列)

这段代码很糟糕:(这里我试图更新多列)


用户数据对象在哪里?您可以设置调试点并调试应用程序,以检查是否有任何问题。

尝试移动myDB.close();毕竟updateStringData(…);谢谢,在将myDB.close()移动到updateData()的底部之后,我的问题仍然存在。您会遇到什么错误?有多少sql更新无法工作?您的日志中是否有异常?如果我只使用一个更新,但更多的更新会破坏我的活动,并且第一次更新会完美完成,我认为问题可能在于sql中的列类型。“mobileNo”字段是数字吗?如果是,您必须更新查询,而不使用引号。(这是,我正在从另一个类更改它的值。)。public class userData{public static String userName=“”;public static String FullName=“”;public static String Email=“”;public static String Address=“”;public static String MobileNo=“”;public static byte[]userPhoto=新字节[0];public static String voiceCode=“”;public static String password=“”;}在查询上设置一个调试点,并尝试在KmMuzahid处对其进行调试。
 private void updateData(){
             String fullName=  editText_fullName.getText().toString();
                            String emailAddress= editText_emailAddress.getText().toString();
                            String mobileNo=  editText_mobileNo.getText().toString();
                            String address= editText_address.getText().toString();
                            String voiceCode=button_tackeVoice.getText().toString();
                            String password=editText_password.getText().toString();
            final SQLiteDatabase myDB = openOrCreateDatabase(FeedReaderDbHelper.DATABASE_NAME, MODE_PRIVATE,
        null);
            updateStringData(myDB, FeedReaderDbHelper.FULL_NAME, fullName);


             }
    private void updateStringData(SQLiteDatabase myDB,String columnName,String data){
                    try {

                        String strSQL = "UPDATE user SET "+columnName+" ='"+data+"' WHERE userName = '"+ userData.userName+"'";

                        myDB.execSQL(strSQL);
                        myDB.close();

                    }catch (android.database.sqlite.SQLiteConstraintException ex) {

                    }
                }
private void updateData(){
     String fullName=  editText_fullName.getText().toString();
                    String emailAddress= editText_emailAddress.getText().toString();
                    String mobileNo=  editText_mobileNo.getText().toString();
                    String address= editText_address.getText().toString();
                    String voiceCode=button_tackeVoice.getText().toString();
                    String password=editText_password.getText().toString();
    final SQLiteDatabase myDB = openOrCreateDatabase(FeedReaderDbHelper.DATABASE_NAME, MODE_PRIVATE, null);
    updateStringData(myDB, FeedReaderDbHelper.FULL_NAME, fullName);
                        updateStringData(myDB,FeedReaderDbHelper.EMAIL_ADDRESS,emailAddress);
                        updateStringData(myDB,FeedReaderDbHelper.MOBILE_NO,mobileNo);
                        updateStringData(myDB,FeedReaderDbHelper.ADDRESS,address);
                        updateStringData(myDB,FeedReaderDbHelper.VOICE_CODE,voiceCode);
                        updateStringData(myDB,FeedReaderDbHelper.USER_PASSWORD,password);
    }
       private void updateStringData(SQLiteDatabase myDB,String columnName,String data){
            try {

                String strSQL = "UPDATE user SET "+columnName+" ='"+data+"' WHERE userName = '"+ userData.userName+"'";

                myDB.execSQL(strSQL);
                myDB.close();

            }catch (android.database.sqlite.SQLiteConstraintException ex) {

            }
        }