實驗8 SQLite資料庫操作

來源:互聯網
上載者:User

標籤:

實驗報告

課程名稱

基於Android平台移動互連網開發

實驗日期

    2016/5/6

實驗項目名稱

SQLite資料庫操作

實驗地點

綜合實驗室

實驗類型

□驗證型    √設計型    □綜合型

學  時

           2

一、實驗目的及要求(本實驗所涉及並要求掌握的知識點)

1. 設計一個個人通訊錄,掌握Android平台下的資料庫開發,該個人通訊錄主要包括連絡人清單和連絡人詳細資料等介面。

2. 程式主介面是通訊錄的目錄顯示手機上連絡人的名稱。點擊連絡人的姓名可以顯示連絡人的詳細資料。在按了MEMU鍵之後會快顯功能表欄。單擊功能表列上的按鈕可以新增連絡人...和刪除連絡人。

二、實驗環境(本實驗所使用的硬體裝置和相關軟體)

(1)PC機

(2)作業系統:Windows XP

(3)軟體: Eclipse, JDK1.6,Android SDK,ADT

三、實驗內容及步驟

1)確定資料庫的資料結構

2)在res/drawable-mdpi目錄下拷入程式要用的表徵圖

3)定義字串資源string.xml

4)開發布局檔案activity_main.xml用於顯示連絡人清單

5)layout目錄下建立一個detail.xml,用於顯示連絡人詳細資料

6)開發資料庫輔助類MyOpenHelper類,建立一個MyOpenHelper.java

7)接下來便進入MainActivity端的開發,實現資料庫增加、刪除、修改記錄等操作

8)建立一個Activity名字叫DetailActivity.java,實現連絡人詳細資料顯示功能

四、實驗結果(本實驗來源程式清單及運行結果或實驗結論、實驗設計圖)

代碼:

MainActivity部分代碼:

 

public class MainActivity extends Activity {    ListView list,lv;    MyOpenHelper dbHelper;    SQLiteDatabase db;    String s;    Button delbtn,addbtn;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        lv=(ListView)findViewById(R.id.listView1);        addbtn=(Button)findViewById(R.id.button1);        delbtn=(Button)findViewById(R.id.button2);        dbHelper=new MyOpenHelper(MainActivity.this,"personal_contacts.db",null,1);        db=dbHelper.getReadableDatabase();        ///查詢資料庫        Cursor cursor = db.rawQuery("select * from contacts", null);        Log.i("sssssssss", "111111");        inflateList(cursor);                        //長按顯示詳細資料        lv.setOnItemLongClickListener(new OnItemLongClickListener() {            @Override            public boolean onItemLongClick(AdapterView<?> arg0, View view, int arg2,                    long arg3) {                // TODO Auto-generated method stub                TextView textView = (TextView)findViewById(R.id.textView1);                s=textView.getText().toString();                Intent intent = new Intent(MainActivity.this,DetailActivity.class);                Bundle bundle=new Bundle();                bundle.putString("name", s);                intent.putExtras(bundle);                startActivity(intent);                finish();                return false;            }                    });        delbtn.setOnClickListener(new OnClickListener() {                        @Override            public void onClick(View arg0) {                // TODO Auto-generated method stub                db.delete("contacts", "name=?", new String[]{s});                Toast.makeText(MainActivity.this, "刪除成功", Toast.LENGTH_LONG).show();                Cursor cursor=db.rawQuery("select * from contacts", null);                inflateList(cursor);            }        });        lv.setOnItemClickListener(new OnItemClickListener() {            @Override            public void onItemClick(AdapterView<?> arg0, View view, int arg2,                    long arg3) {                // TODO Auto-generated method stub                view.setBackgroundColor(Color.BLUE);                TextView textView = (TextView)findViewById(R.id.textView1);                s=textView.getText().toString();            }        });        addbtn.setOnClickListener(new OnClickListener() {                        @Override            public void onClick(View arg0) {                // TODO Auto-generated method stub                Intent i=new Intent();                i.setClass(MainActivity.this, DetailActivity.class);                startActivity(i);                finish();            }        });    }private void inflateList(Cursor cursor){    Log.i("aaaaa", "111111");    int count=cursor.getCount();    String[] name=new String[count];    String[] mobile=new String[count];    int a=0;    while(cursor.moveToNext()){        name[a]=cursor.getString(cursor.getColumnIndex("name"));        mobile[a]=cursor.getString(cursor.getColumnIndex("mobile"));        a++;    }ArrayList<HashMap<String, Object>> listItem = new ArrayList<HashMap<String,Object>>();Log.i("sssssssss", "2222222");for(int i=0;i<count;i++){    Log.i("qqqqqqqqq", "111111");    HashMap<String,Object> map = new HashMap<String, Object>();        map.put("ItemText1", name[i]);    map.put("ItemText2", mobile[i]);    listItem.add(map);    }            SimpleAdapter listItemAdater = new SimpleAdapter(MainActivity.this,listItem,R.layout.item,            new String[]{"ItemText1","ItemText2"}, new int[]{R.id.textView1,R.id.textView2});    Log.i("jjjjjjjjjjjjjjjj", "111111");    lv.setAdapter(listItemAdater);    Log.i("zzzzzz", "111111");}    @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;    }}

 

運行結果:()

 

五、實驗總結(對本實驗結果進行分析,實驗心得體會及改進意見)

    這次實驗感覺挺難的,雖然一開始就有了大致的邏輯思路;在過程中一運行程式就崩潰,後來檢查了很久才發現是因為沒實現findViewById這個方法,沒有辦法編譯到相關的代碼,解決了這個問題之後,在建立連絡人儲存的時候程式崩潰了,經檢查發現有兩個資料庫,這是因為MyOpenHelper.java的資料庫名稱跟MainActivity.java的資料庫名稱不一致造成的。所以,在實驗的時候要仔細。

實驗評語

 

實驗成績

 

指導教師簽名:                                               年   月   日

實驗8 SQLite資料庫操作

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.