实验报告

课程名称

基于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;@Overrideprotected 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() {@Overridepublic boolean onItemLongClick(AdapterView<?> arg0, View view, int arg2,long arg3) {// TODO Auto-generated method stubTextView 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() {@Overridepublic void onClick(View arg0) {// TODO Auto-generated method stubdb.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() {@Overridepublic 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() {@Overridepublic void onClick(View arg0) {// TODO Auto-generated method stubIntent 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");
}@Overridepublic 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的数据库名称不一致造成的。所以,在实验的时候要仔细。

实验评语

 

实验成绩

 

指导教师签名:                                               年   月   日

转载于:https://www.cnblogs.com/qing0715/p/5487645.html

实验8 SQLite数据库操作相关推荐

  1. SQLite数据库操作实践

    SQLite数据库操作实践 SQLite存储类型 null       - 空值  integer - 有符号整数,自增列定义 id integer primary key autoincrement ...

  2. 数据存储之 SQLite 数据库操作(三)

    上一讲中我们讲到了SQLite数据库的操作方法 [数据存储之SQLite数据库操作(二)],我们主要是以SQL语句对数据库进行增删改查,这一讲我们来学习一下 Android 建议的对数据库的操作方法 ...

  3. 数据存储之 SQLite 数据库操作(二)

    上一讲我们讲解了SQLite数据库的创建[数据存储之 SQLite 数据库操作(一)],还有更新的操作,这一讲我们来讲解一下数据库的增删改查,这边的程序是对上一个程序进行修改,建议结合上一讲内容进行学 ...

  4. Qt下Sqlite数据库操作

    Sqlite数据库作为Qt项目开发中经常使用的一个轻量级的数据库,可以说是兼容性相对比较好的数据库之一(Sqlite就像Qt的亲儿子,如同微软兼容Access数据库一样).关于Sqlite和Qt的千丝 ...

  5. C# SQLite 数据库操作语句与文件视图管理器

    //sqlite数据库视图管理器 SQLiteSpy是一款专业的SQLite数据库管理,主要用于读取sqlite数据库,建立新的SQL查询,视图,复制和删除表.编辑单元格,以及查看索引,触发器和排序规 ...

  6. java sqlite 操作_Java SQLite 数据库操作

    Java SQLite 数据库操作 1.[代码][Java]代码 package UI; import java.sql.Connection; import java.sql.DriverManag ...

  7. Android sqlite数据库操作通用框架AHibernate(一)-CRUD示例和使用步骤

    AHibernate简介 一句话描述,使用AHibernate框架进行sqlite数据库操作您将从重复性劳动中解脱出来. (一)支持功能: 1.自动建表,支持属性来自继承类:可根据注解自动完成建表,并 ...

  8. SQLite数据库操作+事务处理

    SQLite数据库操作 SQLite数据库介绍 Android系统中集成的轻量级的数据库 特点: 轻量级 是以单个文件的形式进行存取 跨平台 支持多个操作系统 零配置 无需安装, 直接使用 嵌入式 内 ...

  9. SQLite数据库操作

    安卓中创建数据库的步骤: 1.写一个类MyOpenHelper继承SQLiteOpenHelper类 2.覆写其中的OnCreate(SQLiteDatabase db)和onUpgrade(SQLi ...

最新文章

  1. python利器怎么用-UliPad 初体验----python 开发利器
  2. HOWTO:安装包卸载时如何保留部分文件不被卸载
  3. JS 对象(Object)和字符串(String)互转
  4. 获取某个地址的utxo的三种方法
  5. 为 Nginx 添加模块
  6. python 1秒启动一个下载服务器
  7. 安卓接收耳机按键控制音频播放
  8. 多进程|多线程的不同应用场景:Python还是C
  9. 基于 GMDSS 的电子海图定位仿真研究
  10. Proxy和Reflect
  11. 高效程序员秘籍(5):让EyeDefender提醒你注意休息,保护视力
  12. 用python画中国象棋棋盘
  13. 读书百客:《嘲鲁儒》赏析
  14. linux系统mtd移植,文件系统 之 移植mtd-utils工具包
  15. aptx与ldac音质区别_蓝牙协议LDAC和aptx的区别?
  16. 齐鲁工业大学计算机科学与技术学院院长,齐鲁工业大学计算机科学与技术学院导师教师师资介绍简介-翟翌...
  17. EXCEL插入、数据灰色不能使用的解决办法之一
  18. undefined symbol
  19. 一只蝴蝶挥了挥翅膀,于是有了AI读心术
  20. 云栖大会·南京峰会落下帷幕,阿里云都干了些什么?

热门文章

  1. OpenCV3学习(8.3)模板匹配函数matchTemplate详解
  2. 7-10 找最小的字符串 (15 分)
  3. 7-133 谷歌的招聘 (20 分)
  4. php url标准化,seo优化教程:链接url标准化操作?
  5. android 获取gpio电平值_使用GPIO实现SPI协议操作OLED
  6. oracle pl sql developer 教程,plsql developer怎么使用 plsql developer图文使用教程
  7. python读取多个文件夹_如何从python中的文件夹中读取多个NetCDF文件
  8. transform: translate()
  9. ESRI ArcGIS 9.0系列软件报价(转)
  10. HDU 1231.最大连续子序列-dp+位置标记