1

sqlite電話番号とそれぞれのアドレスをAndroidのデータベースに保存する必要がある小さなプロジェクトに取り組んでいます。MyMainActivityには、ユーザーが 2 つのオプションを持つレイアウトがあります。1. データベースに新しい値を追加できます (電話番号と住所) 2. 電話番号を入力して住所を検索できます。

これは私の MainActivity です:

public class MainActivity extends Activity {


    private static final String TABLE_CONTACTS = "contacts";
    private static final int DATABASE_VERSION = 1;

    // Database Name
    private static final String DATABASE_NAME = "contactsManager";
    // Contacts Table Columns names
    private static final String KEY_ID = "id";
    private static final String KEY_ADDRESS = "name";
    private static final String KEY_PH_NO = "phone_number";

    SQLiteDatabase db;

    TextView numberTextview,addressTextView,fetchedAddressTextView;
    Button buttonSave,buttonSearch;
    EditText numberEditText,addressEditText,searchEditText;




    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        numberTextview=(TextView)findViewById(R.id.textView1);
        numberEditText=(EditText)findViewById(R.id.editText1);
        addressTextView=(TextView)findViewById(R.id.textView2);
        addressEditText=(EditText)findViewById(R.id.editText2);
        buttonSave=(Button)findViewById(R.id.button1);
        searchEditText=(EditText)findViewById(R.id.editText3);
        buttonSearch=(Button)findViewById(R.id.button2);
        fetchedAddressTextView=(TextView)findViewById(R.id.textView3);

        try {
            String CREATE_CONTACTS_TABLE = "CREATE TABLE IF NOT EXISTS " + TABLE_CONTACTS + "("
                    + KEY_ID + " INTEGER PRIMARY KEY," + KEY_ADDRESS + " TEXT,"
                    + KEY_PH_NO + " TEXT" + ")";
            db.execSQL(CREATE_CONTACTS_TABLE);
            Toast.makeText(MainActivity.this, "table created ", Toast.LENGTH_LONG).show();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        buttonSave.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub

                String address=addressEditText.getText().toString();
                long number = Integer.parseInt(numberEditText.getText().toString());

                try {
                    ContentValues values = new ContentValues();
                    values.put(KEY_ADDRESS, address); // Contact Address
                    values.put(KEY_PH_NO, number); // Contact Phone

                    // Inserting Row
                    db.insert(TABLE_CONTACTS, null, values);
                    db.close();
                } catch (Exception e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }


            }
        });

        buttonSearch.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                long phone_number=Integer.parseInt(searchEditText.getText().toString());

                try {
                    Cursor c=db.query(TABLE_CONTACTS, new String[]{
                            KEY_ADDRESS
                    },
                    KEY_PH_NO + "=" + phone_number,
                    null,
                    null,
                    null,
                    null);

                    if (c != null) {
                        c.moveToFirst();
                    }
                    fetchedAddressTextView.setText(c.toString());
                } catch (Exception e) {

                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }

            }




        });
    }


    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

}

Logcat トレース:

03-28 11:45:12.562: E/AndroidRuntime(4079): FATAL EXCEPTION: main
03-28 11:45:12.562: E/AndroidRuntime(4079): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.fivetofive/com.example.fivetofive.MainActivity}: java.lang.NullPointerException
03-28 11:45:12.562: E/AndroidRuntime(4079):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2122)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at android.app.ActivityThread.access$600(ActivityThread.java:140)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1228)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at android.os.Handler.dispatchMessage(Handler.java:99)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at android.os.Looper.loop(Looper.java:137)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at android.app.ActivityThread.main(ActivityThread.java:4895)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at java.lang.reflect.Method.invokeNative(Native Method)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at java.lang.reflect.Method.invoke(Method.java:511)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:994)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:761)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at dalvik.system.NativeStart.main(Native Method)
03-28 11:45:12.562: E/AndroidRuntime(4079): Caused by: java.lang.NullPointerException
03-28 11:45:12.562: E/AndroidRuntime(4079):     at com.example.fivetofive.MainActivity.onCreate(MainActivity.java:59)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at android.app.Activity.performCreate(Activity.java:5163)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094)
03-28 11:45:12.562: E/AndroidRuntime(4079):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2061)
03-28 11:45:12.562: E/AndroidRuntime(4079):     ... 11 more

アプリケーションも起動しません。実行するとクラッシュします。sqliteAndroidでの作業はこれが初めてです。ですから、ばかげた間違いを許し、指摘してください。

前もって感謝します。

UPDATE 注意してください:私は、DataBaseHandler拡張する別のクラスに行くことで、今のところ私の問題を解決しましたSQLiteOpenHelper。ここでエラーが発生した理由はまだわかりません。今は時間がないので、答えが得られたら後で戻ってきます。この質問に出くわす人のために、DataBaseHandlerクラスを作ることは大いに役立つと言いたいだけです.

4

3 に答える 3

2

そして、あなたはしなければなりませんextends SQLiteOpenHelper {

以下の行でdbオブジェクトを初期化してください

db = new SQLiteDatabase(); 

そして、この行をマニフェストに追加しましたか

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

このチュートリアルを実行してください

http://www.androidhive.info/2011/11/android-sqlite-database-tutorial/

http://www.vogella.com/articles/AndroidSQLite/article.html

于 2013-03-28T06:34:28.743 に答える
1

使用する前にデータベースを開く必要があります。try{} の上に 2 行以下を追加してから試してみて、どうなるか教えてください。

db = new SQLiteDatabase(); // pass context or activity its upon your SQLiteDatabase() class
db.open();

私はそれがあなたを助けるかもしれないと思う..

于 2013-03-28T06:31:35.903 に答える
0

これから値を取得することを確認してください。

String address=addressEditText.getText().toString();
long number = Integer.parseInt(numberEditText.getText().toString());

はいの場合は、次の行を変更します。

ContentValues values = new ContentValues();
                    values.put(KEY_ADDRESS, address); // Contact Address
                    values.put(KEY_PH_NO, number); // Contact Phone

これに

db.open();
ContentValues values = new ContentValues();
values.put(KEY_ADDRESS, ""+address); // Contact Address
values.put(KEY_PH_NO, ""+number); // Contact Phone

クエリKEY_PH_NOではTEXT

String CREATE_CONTACTS_TABLE = "CREATE TABLE IF NOT EXISTS " + TABLE_CONTACTS + "("
                    + KEY_ID + " INTEGER PRIMARY KEY," + KEY_ADDRESS + " TEXT,"
                    + KEY_PH_NO + " TEXT" + ")";
于 2013-03-28T06:30:29.413 に答える