实验报告

课程名称

基于Android平台移动互联网开发

实验日期

2016年5月3日

实验项目名称

SQLite数据库操作

实验地点

S30010

实验类型

□验证型    √设计型    □综合型

学  时

2

一、实验目的及要求(本实验所涉及并要求掌握的知识点)

1.目的:设计一个个人通讯录,掌握Android平台下的数据库开发,该个人通讯录主要包括联系人列表和联系人详细信息等界面。

2.要求:程序主界面是通讯录的目录显示手机上联系人的名称。点击联系人的姓名可以显示联系人的详细信息。在按了MEMU键之后会弹出菜单栏。单击菜单栏上的按钮可以添加联系人和删除联系人

二、实验环境(本实验所使用的硬件设备和相关软件)

(1)PC机

(2)操作系统:Windows XP

(3)软件: Eclipse, JDK1.6,Android SDK,ADT

三、实验内容及步骤

1)在res/drawable-mdpi目录下拷入程序要用的图标

2)定义字符串资源string.xml

3)开发布局文件activity_main.xml用于显示联系人列表。

4)layout目录下新建一个detail.xml,用于显示联系人详细信息

5)接下来便进入MainActivity端的开发,实现数据库增加、删除、修改记录等操作

四、实验结果(本实验源程序清单及运行结果或实验结论、实验设计图)

代码:

mainActivity.java的代码:

package com.example.sql;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

import android.os.Bundle;

import android.printservice.PrintService;

import android.app.Activity;

import android.content.Intent;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

import android.graphics.Color;

import android.util.Log;

import android.view.Menu;

import android.view.View;

import android.view.View.OnClickListener;

import android.view.View.OnCreateContextMenuListener;

import android.widget.AdapterView;

import android.widget.AdapterView.OnItemClickListener;

import android.widget.AdapterView.OnItemLongClickListener;

import android.widget.Button;

import android.widget.ListView;

import android.widget.SimpleAdapter;

import android.widget.TextView;

import android.widget.Toast;

public class MainActivity extends Activity {

Button add,delete;

ListView list;

MyOpenHelper dbhelper;

SQLiteDatabase db;

String s;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

Log.i("kdsjflkasjdklfas", "daskfjaklsjfdklsaf");

add=(Button)findViewById(R.id.button1);

delete=(Button)findViewById(R.id.button2);

list=(ListView)findViewById(R.id.listView1);

Log.i("kdsjflkasjdklfas", "daskfjaklsjfdklsaf");

dbhelper=new MyOpenHelper(MainActivity.this, "personal_contacts.db",null,1);

db=dbhelper.getReadableDatabase();

Cursor c=db.rawQuery("select * from contacts", null);

inflateList(c);

list.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)view.findViewById(R.id.textView1);

s = textview.getText().toString();

}

});

list.setOnItemLongClickListener(new OnItemLongClickListener() {

@Override

public boolean onItemLongClick(AdapterView<?> arg0, View view,

int arg2, long arg3) {

// TODO Auto-generated method stub

view.setBackgroundColor(Color.BLUE);

//                TextView textview=(TextView)view.findViewById(R.id.textView1);

//                s = textview.getText().toString();

Intent intent1=new Intent(MainActivity.this,result.class);

startActivity(intent1);

finish();

return false;

}

});

add.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View arg0) {

// TODO Auto-generated method stub

Intent intent=new Intent(MainActivity.this,result.class);

startActivity(intent);

finish();

}

});

delete.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 c=db.rawQuery("select * from contacts", null);

inflateList(c);

}

});

list.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)view.findViewById(R.id.textView1);

s = textview.getText().toString();

}

});

}

private void inflateList(Cursor c) {

// TODO Auto-generated method stub

int count=c.getCount();

String[] name=new String[count];

int b=0;

while(c.moveToNext()){

name[b]=c.getString(c.getColumnIndex("name"));

b++;

}

ArrayList<HashMap<String, Object>> listitem=new ArrayList<HashMap<String,Object>>();

for(int i=0;i<count;i++){

HashMap<String,Object> map=new HashMap<String, Object>();

map.put("ItemTitle", "name[i]");

Log.i("jakfaksjflaksjfl", "skajfklajslkfj");

listitem.add(map);

SimpleAdapter m=new SimpleAdapter(MainActivity.this, listitem, R.layout.item, new String[]{"ItemTitle"}, new int[]{R.id.ItemTitle});

list.setAdapter(m);

@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;

}

}

运行结果:(截图)

  1. sql项目效果图:

五、实验总结(对本实验结果进行分析,实验心得体会及改进意见)

对于这次的实验,我感觉有点难度,因为思路不是很清晰,所以实验并没有成功,虽然可以成功的添加数据,但是并不能让数据显示在listView上,不过虽然失败了,但是还是有所收获,我会继续寻找解决的方法。

实验评语

 

实验成绩

 

指导教师签名:              年   月   日

           

实验八 sqlite数据库操作的更多相关文章

  1. 实验8 SQLite数据库操作

    实验报告 课程名称 实验8  SQLite数据库操作 实验日期 2016.5.6 实验项目名称 多媒体应用开发 实验地点 S30010 实验类型 □验证型    √设计型    □综合型 学  时 一 ...

  2. 【Android】实验8 SQLite数据库操作2016.5.12

    实验8  SQLite数据库操作 [目的] 设计一个个人通讯录,掌握Android平台下的数据库开发,该个人通讯录主要包括联系人列表和联系人详细信息等界面. [要求] 程序主界面是通讯录的目录显示手机 ...

  3. C# SQLite 数据库操作

    C# SQLite 数据库操作学习 运行环境:Window7 64bit,.NetFramework4.61,C# 7.0 参考: SQLite 官网 SQL As Understood By SQL ...

  4. 我的Android六章:Android中SQLite数据库操作

    今天学习的内容是Android中的SQLite数据库操作,在讲解这个内容之前小编在前面有一篇博客也是讲解了SQLite数据库的操作,而那篇博客的讲解是讲述了 如何在Window中通过DOM来操作数据库 ...

  5. [python]用Python进行SQLite数据库操作

    用Python进行SQLite数据库操作 1.导入Python SQLITE数据库模块 Python2.5之后,内置了SQLite3,成为了内置模块,这给我们省了安装的功夫,只需导入即可~  ]: u ...

  6. 安卓 SQLite数据库操作实例

    前段时间写了个安卓平台下SQLite数据库操作的实例 ,一直没得时间总结 ,今天把它弄出来了. 在Android 运行时环境包含了完整的 SQLite. 首先介绍一下SQLite这个数据库: SQLi ...

  7. 在安卓开发中使用SQLite数据库操作实例

    前段时间写了个安卓平台下SQLite数据库操作的实例 ,一直没得时间总结 ,今天把它弄出来了. 在Android 运行时环境包含了完整的 SQLite. 首先介绍一下SQLite这个数据库: SQLi ...

  8. iOS 中SQLite数据库操作

    在iOS中实现SQLite数据库的操作:1.导入框架(libsqlite3.0.tbd) 2.导入头文件<sqlite3.h> 3.实现数据的增删改查 实现简单 SQLite数据库操作 的 ...

  9. sqlite数据库操作详细介绍 增删改查,游标

    sqlite数据库操作详细介绍 增删改查,游标     本文来源于www.ifyao.com禁止转载!www.ifyao.com Source code     package com.example ...

随机推荐

  1. IOC容器MEF在MVC中的使用

    最近想把自己的网站框架用IOC改造下,经过对比,我初步选择autofac,虽然MEF不需要配置,但性能不行,autofac虽然需要自己写自动化注入,但性能非常好. 先分析下各大IOC框架的性能,分两类 ...

  2. nodejs javascript微信开发

    1.当从第三方软件需要分享到微信的时候 需要给授权处理才能获得微信信息 比如 nickname 等昵称图像等 从第三方登陆跳转到微信分享页需要 shareurl = http://open.weixi ...

  3. While reading XXX pngcrush caught libpng error: N

    错误一:   While reading /XXX/XXX/XXX/img1.png pngcrush caught libpng error:   Not a PNG filCould not fi ...

  4. JDBC开发模式

    一]代码模块———Demo.java public class Demo { private static Connection connection; private static Statemen ...

  5. C#中使用命名管道进行进程通信的实例

    原文:C#中使用命名管道进行进程通信的实例 1 新建解决方案NamedPipeExample 在解决方案下面新建两个项目:Client和Server,两者的输出类型均为"Windows 应用 ...

  6. java web: eclipse & maven & jetty & struts2 & mysql = 简单登录页面

    第一次接触java web开发,花费了一天半的时间,写了个简单的登录页面,以此文为记. 开发工具 Eclipse Luna Release (4.4.0) 已集成maven,maven目前的体会就是管 ...

  7. c语言结构体1之定义

    这是在复习阶段随便小结的一些东西 别喷哦 结构体定义的三种方式 注意事项: 1结构体括号后面有分号 2#define得放在程序上面 3成员名可以和结构体名相同 4结构体类型不能直接访问成员,也不能赋值 ...

  8. editplus批量删除html代码空行

    在editplus替换菜单功能里,“查找”功能里输入: ^[ \t]*\n 替换为空,然后“全部替换”即可. 替换时,要选择“正则表达式”选项, 详细:http://www.dedecms8.com/ ...

  9. C++中的重载、覆盖、隐藏

    前几天面试时被问及C++中的覆盖.隐藏,概念基本答不上来,只答了怎么用指针实现多态,也还有遗漏.最终不欢而散.回来后在网上查找学习了一番,做了这个总结.其中部分文字借用了别人的博客,望不要见怪.引用的 ...

  10. User Defined Runtime Attributes

    设置View borderWidth/cornerRadius/borderColor 为了兼容CALayer 的KVC ,你得给CALayer增加一个分类 CALayer+BorderColor.h ...