1

ユーザーの場所 (セル タワー コード) を任意の名前で保存できる Android アプリケーションを作成しようとしています。したがって、基本的に私のプログラムには次のモジュールが含まれています

  1. ユーザーのタワー コードを取得します。
  2. データベースを作成します。
  3. ユーザーから場所名の入力文字列を取得します。
  4. これらの値をデータベースに保存します。
  5. 要求されたときにこれらの値を表示します。

モジュール 1 と 2 は個別に完全に機能していましたが、それらを統合すると、致命的なメインとヌル ポインターの例外が発生します。

私のコードは以下の通りです

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. データベース接続で NULL ポイント例外エラーが発生するのはなぜですか? また、どうすれば解決できますか?
  2. 次のコードを使用して値をテーブルに挿入しました。

    cd.execSQL("CREATE TABLE IF NOT EXITSTS MLITable (CblocationCode INT(10), CblocationName VARCHAR);"); cd.execSQL("INSERT INTO MLITable VALUES (' ',' ');" +str +locname); ユーザー値をデータベースに渡す正しい方法ですか?

ありがとうございました。

4

1 に答える 1

0

CREATE ステートメントのつづりがEXISTS間違っています。

INSERT ステートメントは次のようになります。

cd.execSQL("INSERT INTO MLITable VALUES('" + str + "', '" + locname + "');");

openOrCreateDatabaseしかし、最も可能性の高い原因は、呼び出しが実行されていないため、 に何も割り当てられていないことだと思いますcd

于 2012-11-02T20:09:42.347 に答える