0

私はデータベースの練習のためにアンドロイドでアプリケーションをシンプルにしSqlite databaseました。私はそれについて非常に多くのリンクを通過したことを知らないので、しかしそれらのほとんどは複雑です。私は4つのアクティビティを作成しましButtonsた2番目のアクティビティ(AddActivity)の「編集」「表示」でEditTexts、入力した値をデータベースに保存するように3つ作りました。簡単な手順を教えてください。

MainActivity.java

package com.example.db;

import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Button add=(Button)findViewById(R.id.button1);
        Button edit=(Button)findViewById(R.id.button2);
        Button view=(Button)findViewById(R.id.button3);

        add.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View arg0) {
            // TODO Auto-generated method stub]
            Intent i=new Intent(MainActivity.this,AddActivity.class);
            startActivity(i);

        }
    });
    edit.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {
            // TODO Auto-generated method stub
            Intent i=new Intent(MainActivity.this,EditActivity.class);
            startActivity(i);

        }
    });

    view.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {
            // TODO Auto-generated method stub
            Intent i=new Intent(MainActivity.this,ViewActivity.class);
            startActivity(i);
        }
    });
    }

    }

AddActivity.java

 package com.example.db;

import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;

public class AddActivity extends Activity {
EditText name,addres,phon;
Button ad,cn;
@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_add);

        name = (EditText)findViewById(R.id.name);
        addres=(EditText)findViewById(R.id.address);
        phon = (EditText)findViewById(R.id.phone);

        ad =(Button)findViewById(R.id.add);
        cn=(Button)findViewById(R.id.cancel);
        final SQLiteDatabase db = openOrCreateDatabase("Mydb",MODE_PRIVATE, null);
        db.execSQL("create table if not exists simple(name varchar,address varchar,phone varchar");
        ad.setOnClickListener(new OnClickListener() {
            String n=name.getText().toString();
            String a=addres.getText().toString();
            String p= phon.getText().toString();
            @Override
            public void onClick(View v) {

                db.execSQL("insert into simple values('n','a','p')");
                Cursor c =db.rawQuery("select * from simple",null);
                c.moveToFirst();

            }
        });

        cn.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                Intent i =new Intent(AddActivity.this,MainActivity.class);
                startActivity(i);
            }
        });
    }
}

main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginLeft="100dp"
        android:layout_marginTop="92dp"
        android:text="Add" />

    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignRight="@+id/button1"
        android:layout_below="@+id/button1"
        android:layout_marginTop="28dp"
        android:text="Edit" />

    <Button
        android:id="@+id/button3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignRight="@+id/button2"
        android:layout_below="@+id/button2"
        android:layout_marginTop="37dp"
        android:text="View" />

</RelativeLayout>

Add.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".AddActivity" >

    <TextView
        android:id="@+id/textView3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_below="@+id/textView2"
        android:layout_marginTop="60dp"
        android:text="phone"
        android:textAppearance="?android:attr/textAppearanceMedium" />

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_above="@+id/textView3"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginLeft="17dp"
        android:layout_marginTop="14dp"
        android:text="Name"
        android:textAppearance="?android:attr/textAppearanceMedium" />

    <EditText
        android:id="@+id/name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBaseline="@+id/textView1"
        android:layout_alignBottom="@+id/textView1"
        android:layout_alignParentRight="true"
        android:ems="10" >

        <requestFocus />
    </EditText>

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_marginTop="80dp"
        android:layout_toLeftOf="@+id/editText2"
        android:text="Address"
        android:textAppearance="?android:attr/textAppearanceMedium" />

    <EditText
        android:id="@+id/address"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_alignTop="@+id/textView2"
        android:ems="10"
        android:inputType="textPostalAddress" />

    <EditText
        android:id="@+id/phone"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBottom="@+id/textView3"
        android:layout_alignParentRight="true"
        android:ems="10"
        android:inputType="phone" />

    <Button
        android:id="@+id/add"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/phone"
        android:layout_marginTop="62dp"
        android:layout_toRightOf="@+id/textView1"
        android:text="Add" />

    <Button
        android:id="@+id/cancel"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBottom="@+id/add"
        android:layout_marginLeft="36dp"
        android:layout_toRightOf="@+id/add"
        android:text="Cancel" />

</RelativeLayout>
4

2 に答える 2

0

データベースに単一の値のみを表示したい場合は、このようにしてtextViewを取得できます

TextView txtName;

上記の initialize() メソッドで初期化します。次に、単一の値を取得するメソッドを作成します

   // Getting single Name to textView
public void getContact(String id) {
    SQLiteDatabase db = mBaseSqlLiteHelper.getReadableDatabase();
    String select="Select name from NAMES Where _id ="+id;
    Cursor mCursor=db.rawQuery(select,null);
    if (mCursor!=null) {
        mCursor.moveToFirst();
        String name=mCursor.getString(0);
        txtName.setText(name);
    }
    db.close();
}

次に、いくつかのボタンをクリックしてこのメ​​ソッドを呼び出し、選択する行の ID を渡します。

于 2013-05-09T04:42:28.763 に答える