Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/202.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:INSERT detailMessage null_Android_Sqlite - Fatal编程技术网

Android SQLite:INSERT detailMessage null

Android SQLite:INSERT detailMessage null,android,sqlite,Android,Sqlite,我尝试从db\u INSERT.java插入数据,并在MyDB.java中通过方法进行处理 public void append(String n,int p) { String str = "INSERT INTO " + TABLE_NAME + " (" + NAME + "," + PRICE + ") VALUES (" + n +"," + p + ")"; db.execSQL(str); } 在调试模式下,n和p从db\u insert

我尝试从
db\u INSERT.java
插入数据,并在
MyDB.java
中通过方法进行处理

public void append(String n,int p) { 
      String str = "INSERT INTO " + TABLE_NAME + " (" + NAME + "," + PRICE + ") VALUES (" + n +"," + p + ")";
        db.execSQL(str);      
}
在调试模式下,
n
p
db\u insert.java
获取数据

public void append(String n,int p) { 
      String str = "INSERT INTO " + TABLE_NAME + " (" + NAME + "," + PRICE + ") VALUES (" + n +"," + p + ")";
        db.execSQL(str);      
}
到目前为止,一切都很好。但是当进程
db.execSQL(str)时,应用程序将崩溃

有人知道为什么吗

logcat

    02-07 00:16:48.467: I/Process(979): Sending signal. PID: 979 SIG: 9 02-07 00:17:17.827:

 E/MyDBlog(1109): click insert_OKs 02-07 00:17:17.827: D/AndroidRuntime(1109): Shutting 


down VM 02-07 00:17:17.827: W/dalvikvm(1109): threadid=1: thread exiting with uncaught 

exception (group=0x2aac8578) 02-07 00:17:17.827: E/AndroidRuntime(1109): FATAL EXCEPTION: 

main 02-07 00:17:17.827: E/AndroidRuntime(1109): java.lang.NullPointerException 02-07 

00:17:17.827: E/AndroidRuntime(1109): at com.example.mydb.MyDB.append(MyDB.java:39) 02-07 

00:17:17.827: E/AndroidRuntime(1109): at com.example.mydb.db_insert$1.onClick(db_insert.java:66) 02-07 00:17:17.827: 

E/AndroidRuntime(1109): at android.view.View.performClick(View.java:2552) 02-07 

00:17:17.827: E/AndroidRuntime(1109): at android.view.View$PerformClick.run(View.java:9229) 

02-07 00:17:17.827: E/AndroidRuntime(1109): at android.os.Handler.handleCallback(Handler.java:587) 02-07 00:17:17.827: 

E/AndroidRuntime(1109): at android.os.Handler.dispatchMessage(Handler.java:92) 02-07 

00:17:17.827: E/AndroidRuntime(1109): at android.os.Looper.loop(Looper.java:130) 02-07 

00:17:17.827: E/AndroidRuntime(1109): at android.app.ActivityThread.main(ActivityThread.java:3701) 02-07 00:17:17.827: E/AndroidRuntime(1109): at java.lang.reflect.Method.invokeNative(Native Method) 02-07 00:17:17.827: E/AndroidRuntime(1109): at java.lang.reflect.Method.invoke(Method.java:507) 02-07 00:17:17.827: E/AndroidRuntime(1109): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:866) 02-07 

00:17:17.827: E/AndroidRuntime(1109): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:624) 02-07 00:17:17.827: 

E/AndroidRuntime(1109): at dalvik.system.NativeStart.main(Native Method)

我的应用程序首先使用open()打开数据库

MyDB.java

public SQLiteDatabase db=null; 
private Context mCtx = null;
public MyDB(Context ctx){  
    this.mCtx = ctx;      
}
public void open() throws SQLException { // 開啟已經存在的資料庫  
    db = mCtx.openOrCreateDatabase(DATABASE_NAME, 0, null);
        try {       
          db.execSQL(CREATE_TABLE);// 建立資料表 
      }catch (Exception e) {    
      } 
  }

使用db.insert方法并将值存储到ContentaValues对象中

请参阅SQLITE数据库示例

private static final String INSERT = "insert into contact(name,number) values(?,?)";
public DataHelper(Context context)
    {
        this.context=context;
        openhelper=new OpenHelper(context);
        this.db=openhelper.getWritableDatabase();
        this.insertStmt1 = this.db.compileStatement(INSERT);

    }

public boolean insert(String name, String number)
    {
    openhelper=new OpenHelper(context);
    db=openhelper.getWritableDatabase();

    String person=name;


    String values1=number;

    this.insertStmt1.bindString(1, person);
    this.insertStmt1.bindString(2, number);

    this.insertStmt1.executeInsert();

   Toast.makeText(context, "Value inserted", 10000).show();
    openhelper.Close_DB(db); 
    return true;
    }
这是一个将值插入数据库的示例,请根据您的需要进行修改。:)