簡體   English   中英

android數據庫(SQLite)連接

[英]android database (SQLite) connection

我正在嘗試創建一個Android應用程序,該應用程序可以使用他選擇的名稱存儲用戶位置(手機信號塔代碼),例如,手機信號塔代碼為405673,我想將其存儲為“家庭”位置。 因此,基本上我的程序包含以下模塊

  1. 獲取用戶塔式代碼。
  2. 創建一個數據庫。
  3. 從用戶那里獲取位置名稱的輸入字符串。
  4. 將這些值存儲在數據庫中。
  5. 在需要時顯示這些值。

模塊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如下

日志貓

有趣的是,我刪除了數據庫命令以查看我的代碼是否正常工作,由此得出的結論是我在數據庫連接行中犯了一個錯誤。

現在,我的查詢是

  1. 為什么我的數據庫連接出現空值異常錯誤,我該如何解決?
  2. 我使用以下代碼將值插入表中,

    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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM