实验8 SQLite数据库操作
实验报告
|
课程名称 |
实验8 SQLite数据库操作 |
实验日期 |
2016.5.6 |
||
|
实验项目名称 |
多媒体应用开发 |
实验地点 |
S30010 |
||
|
实验类型 |
□验证型 √设计型 □综合型 |
学 时 |
|||
|
一、实验目的及要求(本实验所涉及并要求掌握的知识点) |
|||||
|
设计一个个人通讯录,掌握Android平台下的数据库开发,该个人通讯录主要包括联系人列表和联系人详细信息等界面。程序主界面是通讯录的目录显示手机上联系人的名称。点击联系人的姓名可以显示联系人的详细信息。在按了MEMU键之后会弹出菜单栏。单击菜单栏上的按钮可以添加联系人和删除联系人 |
|||||
|
二、实验环境(本实验所使用的硬件设备和相关软件) |
|||||
|
(1)PC机 (2)操作系统:Windows XP (3)软件: Eclipse, JDK1.6,Android SDK,ADT |
|||||
|
三、实验内容及步骤 |
|||||
|
(1)确定数据库的数据结构。 (2)定义字符串资源string.xml (3)开发布局文件activity_main.xml用于显示联系人列表。 (4)layout目录下新建一个tvdetail.xml,用于显示联系人详细信息. |
|||||
|
四、实验结果(本实验源程序清单及运行结果或实验结论、实验设计图) |
|||||
|
代码: MainActivity代码: public class MainActivity extends Activity { private ListView lv; protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); lv=(ListView)findViewById(R.id.lv); lv.setAdapter(new ArrayAdapter<String>(MainActivity.this, android.R.layout.simple_list_item_single_choice)); lv.setChoiceMode(ListView.CHOICE_MODE_SINGLE); final ArrayList<HashMap<String, Object>> listItem=new ArrayList<HashMap<String,Object>>(); for (int i = 0; i < 3; i++) { HashMap<String, Object> map=new HashMap<String, Object>(); map.put("DetailName", R.id.editText1); map.put("DetailMobile", R.id.editText2); listItem.add(map); } SimpleAdapter simpleAdapter=new SimpleAdapter(MainActivity.this, listItem, R.layout.item, new String[]{"DetailName","DetailMobile"} , new int[]{R.id.editText1,R.id.editText2}); lv.setAdapter(simpleAdapter); //为ListView绑定适配器 lv.setOnItemClickListener(new OnItemClickListener() { public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,long arg3) { Intent intent=new Intent(); intent.setClass(MainActivity.this, DetailActivity.class); startActivity(intent); finish(); } }); } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.main, menu); return super.onCreateOptionsMenu(menu); } public boolean onOptionsItemSelected(MenuItem item){ item.setChecked(true); switch (item.getItemId()) { case R.id.menu1: item.setChecked(true); Intent intent=new Intent(); intent.setClass(MainActivity.this, DetailActivity.class); startActivity(intent); MainActivity.this.finish(); break; case R.id.menu2: item.setChecked(true); break; default: break; } return super.onOptionsItemSelected(item); } } DetailActivity代码: public class DetailActivity extends Activity{ private EditText name; private EditText mobil; private EditText email; private EditText address; private EditText company; private MyOpenHelper helper; private Button savebtn; protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.tvdetail); name=(EditText)findViewById(R.id.editText1); mobil=(EditText)findViewById(R.id.editText2); email=(EditText)findViewById(R.id.editText3); address=(EditText)findViewById(R.id.editText4); company=(EditText)findViewById(R.id.editText5); savebtn=(Button)findViewById(R.id.button1); savebtn.setOnClickListener(new OnClickListener() { public void onClick(View arg0) { helper=new MyOpenHelper(DetailActivity.this, "contacts.db",null, 1); SQLiteDatabase db = helper.getReadableDatabase(); //获得可读的数据库 ContentValues values = new ContentValues(); String name2=name.getTag().toString(); String mobile2=mobil.getTag().toString(); String email2=email.getTag().toString(); String addr2=address.getTag().toString(); String comp2=company.getTag().toString(); if (name2.equals("")||mobile2.equals("")||email2.equals("")||addr2.equals("") ){ Toast.makeText(DetailActivity.this, "请输入联系人信息",Toast.LENGTH_LONG).show();} else { Cursor cursor=db.rawQuery("select * from contacts where name=? ",new String[]{name2}); if (cursor.getCount()<=0) { values.put("name",name.getText().toString()); values.put("mobile",mobil.getText().toString()); values.put("email", email.getText().toString()); values.put("address",address.getText().toString()); db.insert("contacts", null, values); values.clear(); Toast.makeText(DetailActivity.this, "保存成功",Toast.LENGTH_LONG).show(); }else { Toast.makeText(DetailActivity.this, "已存在该联系人",Toast.LENGTH_LONG).show();} } } }); } protected void onDestroy() { super.onDestroy();} } MyOpenHelper代码: public class MyOpenHelper extends SQLiteOpenHelper{ public static final String CREATE__CONTACTS="create table contacts(id integer primary key autoincrement,name,mobile,email,address)"; private Context myContext; public MyOpenHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); myContext=context; } @Override public void onCreate(SQLiteDatabase db) { db.execSQL(CREATE__CONTACTS); Toast.makeText(myContext, "成功", Toast.LENGTH_LONG).show(); } public void onUpgrade(SQLiteDatabase db, int arg1, int arg2) { // TODO Auto-generated method stub} } 运行结果:(截图)
|
|||||
|
五、实验总结(对本实验结果进行分析,实验心得体会及改进意见) |
|||||
|
本次试验并未能全部完成,Layout中的布局能实现,在增加联系人的功能中,方法和代码都基本理解并写出,但在运行时候出现崩溃现象,仍在进一步调试中。 |
|||||
|
实验评语 |
|
||||
|
实验成绩 |
|
指导教师签名: 年 月 日 |
|||
实验8 SQLite数据库操作的更多相关文章
- 【Android】实验8 SQLite数据库操作2016.5.12
实验8 SQLite数据库操作 [目的] 设计一个个人通讯录,掌握Android平台下的数据库开发,该个人通讯录主要包括联系人列表和联系人详细信息等界面. [要求] 程序主界面是通讯录的目录显示手机 ...
- 实验八 sqlite数据库操作
实验报告 课程名称 基于Android平台移动互联网开发 实验日期 2016年5月3日 实验项目名称 SQLite数据库操作 实验地点 S30010 实验类型 □验证型 √设计型 □综合型 ...
- 我的Android六章:Android中SQLite数据库操作
今天学习的内容是Android中的SQLite数据库操作,在讲解这个内容之前小编在前面有一篇博客也是讲解了SQLite数据库的操作,而那篇博客的讲解是讲述了 如何在Window中通过DOM来操作数据库 ...
- [python]用Python进行SQLite数据库操作
用Python进行SQLite数据库操作 1.导入Python SQLITE数据库模块 Python2.5之后,内置了SQLite3,成为了内置模块,这给我们省了安装的功夫,只需导入即可~ ]: u ...
- 安卓 SQLite数据库操作实例
前段时间写了个安卓平台下SQLite数据库操作的实例 ,一直没得时间总结 ,今天把它弄出来了. 在Android 运行时环境包含了完整的 SQLite. 首先介绍一下SQLite这个数据库: SQLi ...
- 在安卓开发中使用SQLite数据库操作实例
前段时间写了个安卓平台下SQLite数据库操作的实例 ,一直没得时间总结 ,今天把它弄出来了. 在Android 运行时环境包含了完整的 SQLite. 首先介绍一下SQLite这个数据库: SQLi ...
- iOS 中SQLite数据库操作
在iOS中实现SQLite数据库的操作:1.导入框架(libsqlite3.0.tbd) 2.导入头文件<sqlite3.h> 3.实现数据的增删改查 实现简单 SQLite数据库操作 的 ...
- sqlite数据库操作详细介绍 增删改查,游标
sqlite数据库操作详细介绍 增删改查,游标 本文来源于www.ifyao.com禁止转载!www.ifyao.com Source code package com.example ...
- windows phone 8.1开发SQlite数据库操作详解
原文出自:http://www.bcmeng.com/windows-phone-sqlite1/ 本文小梦将和大家分享WP8.1中SQlite数据库的基本操作:(最后有整个示例的源码)(希望能通过本 ...
随机推荐
- mysql中常用的控制流函数
MySQL有4个函数是用来进行条件操作的,这些函数可以实现SQL的条件逻辑,允许开发者将一些应用程序业务逻辑转换到数据库后台. MySQL控制流函数: CASE WHEN[test1] THEN [r ...
- Java 动态生成复杂 Word
Java 动态生成复杂 Word 阅读目录 1. 制作 Word 模版,将你需要动态生成的字段用${}替换.2. 将 Word文档保存为 xml .3. 引入项目. 项目中需要用 java 程序生成d ...
- Xcode 8
(一)Xcode8去掉多余LOG 1.打开我们的项目,进入EditScheme 2.我们在Environment Variables中添加OS_ACTIVITY_MODE=disable
- Overload和Override的区别
Overload:重载 |- 在一个类中定义的若干方法 |- 所有的方法名相同,但参数类型或个数不同 |- 只有参数有关,与返回类型无关 Override:覆写 |- 在继承的关系中 |- 子类定义了 ...
- UVA 11210 中国麻将
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- 获取div或者元素相对于屏幕坐上角的绝对位置
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- http websocket
套接字 http 协议 tcp/ip协议 服务器端口 网络协议 http://wenku.it168.com/d_001406013.shtml 跨源 AJAX 事件驱动 http://www.lin ...
- 过目不忘JS正则表达式
正则表达式,有木有人像我一样,学了好几遍却还是很懵圈,学的时候老明白了,学完了忘光了.好吧,其实还是练的不够,所谓温故而知新,可以为师矣,今天就随我来复习一下这傲娇的正则表达式吧. 为啥要有正则表达式 ...
- php : MVC 演示(使用单例工厂)
此例子是MVC的简单应用, 要达到的效果如下: 用户列表: 姓名 年龄 学历 兴趣 出生地 账号创建时间 操作 keen 20 高中 篮球,足球 广东 2016-11-08 10:00:31 删除 a ...
- (转)javascript 奇淫巧技44招
1.首次为变量赋值时务必使用var关键字 变量没有声明而直接赋值得话,默认会作为一个新的全局变量,要尽量避免使用全局变量. 2.使用===取代== ==和!=操作符会在需要的情况下自动转换数据类型.但 ...


