您的位置:首页 > 数据库

实验八: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程序。

实验评语

实验成绩

指导教师签名: 年 月 日

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: