[英]android database (SQLite) connection
我正在嘗試創建一個Android應用程序,該應用程序可以使用他選擇的名稱存儲用戶位置(手機信號塔代碼),例如,手機信號塔代碼為405673,我想將其存儲為“家庭”位置。 因此,基本上我的程序包含以下模塊
模塊1和2分別可以完美地工作,但是當我將它們集成時,我得到了致命的main和空指針異常。
我的代碼如下
package my.project.mil;
import android.content.Context;
import android.content.Intent;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
public class Cbdata extends MainActivity {
public String str;
public void onReceive(Context context, Intent intent) {
//---get the CB message passed in---
Bundle bundle = intent.getExtras();
SmsCbMessage[] msgs = null;
str = "";
if (bundle != null) {
//---retrieve the SMS message received---
Object[] pdus = (Object[]) bundle.get("pdus");
msgs = new SmsCbMessage[pdus.length];
for (int i=0; i<msgs.length; i++) {
msgs[i] = SmsCbMessage.createFromPdu((byte[])pdus[i]);
str += "CB " + msgs[i].getGeographicalScope() + msgs[i].getMessageCode() + msgs[i].getMessageIdentifier() + msgs[i].getUpdateNumber();
str += " :";
str += msgs[i].getMessageBody().toString();
str += "\n";
}}
}
SQLiteDatabase cd = openOrCreateDatabase("mydata", MODE_WORLD_READABLE, null);
Button submit;
Button viewdb;
EditText name;
@Override
public void onCreate(Bundle savedInstanceState)
{
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.seventh);
viewdb = (Button) findViewById(R.id.viewdb);
submit = (Button) findViewById(R.id.submit);
name = (EditText) findViewById(R.id.name);
submit.setOnClickListener(new View.OnClickListener()
{
public void onClick(View arg0) {
String locname = name.getText().toString();
if (locname.length()>0)
{
cd.execSQL("CREATE TABLE IF NOT EXITSTS MLITable (CblocationCode INT(10), CblocationName VARCHAR);");
cd.execSQL("INSERT INTO MLITable VALUES (' ',' ');" +str +locname);
Toast.makeText(getBaseContext(), "value successfully entered.", Toast.LENGTH_LONG).show();
}
else
{
Toast.makeText(getBaseContext(), "Please enter the location name, for example 'Home'.", Toast.LENGTH_LONG).show();
}
}
});
cd.close();
viewdb.setOnClickListener(new View.OnClickListener()
{
public void onClick(View arg0) {
// TODO Auto-generated method stub
// here comes the code for viewing the database
}
});
}
}
我的logcat如下
有趣的是,我刪除了數據庫命令以查看我的代碼是否正常工作,由此得出的結論是我在數據庫連接行中犯了一個錯誤。
現在,我的查詢是
我使用以下代碼將值插入表中,
cd.execSQL(“如果未退出MLITable,則創建表(CblocationCode INT(10),CblocationName VARCHAR);”); cd.execSQL(“ INSERT INTO MLITable VALUES('','');” + str + locname); 這是將用戶值傳遞到數據庫的正確方法嗎?
謝謝。
CREATE語句的EXISTS
拼寫錯誤。
INSERT語句應顯示為
cd.execSQL("INSERT INTO MLITable VALUES('" + str + "', '" + locname + "');");
但我認為最可能的原因是openOrCreateDatabase
調用尚未運行,因此cd
沒有分配任何內容。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.