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

    实验报告

    课程名称

    基于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的数据库名称不一致造成的。所以,在实验的时候要仔细。

    实验评语

     

    实验成绩

     

    指导教师签名:                                               年   月   日

  • 相关阅读:
    PHP获取指定分钟数的下一个整数倍
    phpspreadsheet
    澳大利亚 主要城市列表
    db2编目抽取
    openssl实现CA自签证书和颁发数字证书
    基于Docker的redis集群搭建
    Python测试DB2连通性
    在Vim中查看文件编码
    搭建redis集群
    Python(十)之GUI编程
  • 原文地址:https://www.cnblogs.com/qing0715/p/5487645.html
Copyright © 2011-2022 走看看