zoukankan      html  css  js  c++  java
  • 实验八:SQLite数据库操作

    实验报告

    课程名称

    基于Android平台移动互联网开发

    实验日期

    2016年5月6日

    实验项目名称

    SQLite数据库操作

    实验地点

    S30010

    实验类型

    □验证型    √设计型    □综合型

    学  时

    一、实验目的及要求(本实验所涉及并要求掌握的知识点)

    1. 设计一个个人通讯录,掌握Android平台下的数据库开发,该个人通讯录主要包括联系人列表和联系人详细信息等界面。
    2. 程序主界面是通讯录的目录显示手机上联系人的名称。点击联系人的姓名可以显示联系人的详细信息。单击图标按钮可以添加联系人和删除联系人。

    二、实验环境(本实验所使用的硬件设备和相关软件)

    (1)PC机

    (2)操作系统:Windows XP

    (3)软件: Eclipse, JDK1.6,Android SDK,ADT

    三、实验内容及步骤

    (1)  确定数据库的数据结构。

    (2)  新建工程,修改布局文件,定义字符串资源。

    (3)  开发布局文件activity_main.xml用于显示联系人列表。

    (4)  layout目录下新建一个detail.xml,用于显示联系人详细信息。

    (5)  开发数据库辅助类MyOpenHelper类

    (6)  DetailActivity端开发实现数据库增加、删除、修改记录等操作

    (7)  新建Activity名为DetailActivity.java,实现联系人详细信息显示功能。

    四、实验结果(本实验源程序清单及运行结果或实验结论、实验设计图)

    代码:

    MainActivity类代码:

    package com.example.txl;
    
    import java.util.ArrayList;
    import java.util.HashMap;
    
    import android.app.Activity;
    import android.content.Intent;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    import android.os.Bundle;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.AdapterView;
    import android.widget.Button;
    import android.widget.ListView;
    import android.widget.SimpleAdapter;
    import android.widget.AdapterView.OnItemClickListener;
    
    public class DeleteActivity extends Activity {
        Button btnback;
        Intent it = new Intent();
        ListView listview;
        UserSQL usersql;
        SQLiteDatabase userdatabases;
        ArrayList<HashMap<String, Object>> userlist;
        String[] name = new String[100];
        Cursor cursor;
        SimpleAdapter sa;
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.delete);
            btnback = (Button) findViewById(R.id.back);
            listview = (ListView) findViewById(R.id.listView2);
            usersql = new UserSQL(DeleteActivity.this, "user.db", null, 1);
            userdatabases = usersql.getReadableDatabase();
            userlist = new ArrayList<HashMap<String, Object>>();
            cursor = userdatabases.rawQuery("select * from userTable", null);
            cursor.moveToFirst();
            
            if (cursor.getCount() > 0) {
                for (int i = 0; i < cursor.getCount(); i++) {
                    HashMap<String, Object> hashmap = new HashMap<String, Object>();
                    hashmap.put("name",
                            cursor.getString(cursor.getColumnIndex("name")));
                    name[i] = cursor.getString(cursor.getColumnIndex("name"));
                    hashmap.put("phone",
                            "[" + cursor.getString(cursor.getColumnIndex("phone"))
                                    + "]");
                    userlist.add(hashmap);
                    if (i < cursor.getCount()) {
                        cursor.moveToNext();
                    }
                }
                sa = new SimpleAdapter(DeleteActivity.this, userlist,
                        R.layout.list, new String[] { "name", "phone" }, new int[] {
                                R.id.namelist, R.id.phonelist });
                listview.setAdapter(sa);
            }
            listview.setOnItemClickListener(new OnItemClickListener() {
    
                @Override
                public void onItemClick(AdapterView<?> parent, View view,
                        int position, long id) {
                    // TODO Auto-generated method stub
                    
                    userdatabases.delete("userTable", "name=?",new String[] { name[position] });
                    list();
                }
            });
            btnback.setOnClickListener(new OnClickListener() {
                
                @Override
                public void onClick(View v) {
                    // TODO Auto-generated method stub
                    it.setClass(DeleteActivity.this, MainActivity.class);
                    startActivity(it);
                    finish();
                }
            });
    
        }
        public void list(){
            userlist = new ArrayList<HashMap<String, Object>>();
            cursor = userdatabases.rawQuery("select * from userTable", null);
            cursor.moveToFirst();
            
                for (int i = 0; i < cursor.getCount(); i++) {
                    HashMap<String, Object> hashmap = new HashMap<String, Object>();
                    hashmap.put("name",
                            cursor.getString(cursor.getColumnIndex("name")));
                    name[i] = cursor.getString(cursor.getColumnIndex("name"));
                    hashmap.put("phone",
                            "[" + cursor.getString(cursor.getColumnIndex("phone"))
                                    + "]");
                    userlist.add(hashmap);
                    if (i < cursor.getCount()) {
                        cursor.moveToNext();
                    }
                }
                sa = new SimpleAdapter(DeleteActivity.this, userlist,
                        R.layout.list, new String[] { "name", "phone" }, new int[] {
                                R.id.namelist, R.id.phonelist });
                listview.setAdapter(sa);
            
        }
    }
    

      

    五、实验总结(对本实验结果进行分析,实验心得体会及改进意见)

     经过本次的实验,发现很多问题,对数据库进行增、删、查、改的操作不了解,通过参考资料和老师上课讲解梳理了部分知识难点,艰难完成。还需多练编写android程序。

    实验评语

     

    实验成绩

     

    指导教师签名:              年   月   日

               

  • 相关阅读:
    Canny边缘检测高低阈值问题
    EffectiveC++ Item25测试
    下载videolectures.net里的视频的方法
    01章 象数易理篇之一
    论文格式问题
    反序列化笔记
    什么是动爻
    EffectiveC++ Item25说的东东
    优化功能
    论文修改意见
  • 原文地址:https://www.cnblogs.com/yewenzhao/p/5488079.html
Copyright © 2011-2022 走看看