实验八:SQLite数据库操作
2016-05-13 07:52
447 查看
实验报告
课程名称 | 基于Android平台移动互联网开发 | 实验日期 | 2016年5月6日 | ||
实验项目名称 | SQLite数据库操作 | 实验地点 | S30010 | ||
实验类型 | □验证型 √设计型 □综合型 | 学 时 | |||
一、实验目的及要求(本实验所涉及并要求掌握的知识点) | |||||
设计一个个人通讯录,掌握Android平台下的数据库开发,该个人通讯录主要包括联系人列表和联系人详细信息等界面。 程序主界面是通讯录的目录显示手机上联系人的名称。点击联系人的姓名可以显示联系人的详细信息。单击图标按钮可以添加联系人和删除联系人。 | |||||
二、实验环境(本实验所使用的硬件设备和相关软件) | |||||
(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程序。 | |||||
实验评语 | |||||
实验成绩 | 指导教师签名: 年 月 日 | ||||
相关文章推荐
- win10 64位安装sql sevser 2000的方法
- 《转》Redis的启动停止脚本
- 实验8 SQLite数据库操作
- Mac OS下安装mysql及其简单使用
- oracle 三种复合类型变量分析
- 实验八:SQLite数据库操作
- win7上的python脚本无法连接运行在virtualbox上的mongodb
- Jmeter连接Mysql和Mysql编码问题
- 甲骨文与谷歌进入第二轮版权之争
- 实验8 SQLite数据库操作
- SQL server服务显示远程过程调用失败的解决方法
- 快速实现SQL Server数据库恢复备份
- Oracle用户连续登录失败次数限制如何取消
- 忘记MySQL的root密码该怎么办
- Mysql存储引擎MyISAM的常见问题(表损坏、无法访问、磁盘空间不足)
- VS2013连接MySQL5.6成功案例一枚
- Windows下mysql修改root密码的4种方法
- 实例解析MySQL中的存储过程及存储过程的调用方法
- win7下MySql 5.7安装配置方法图文教程
- mysql5.7.11 winx64安装配置方法图文教程