My安卓知识2--使用listview绑定sqlite中的数据
我想在我的安卓项目中实现一个这样的功能,读取sqlite数据库中的数据并显示到某个页面的listview控件中。
首先,我建立了一个Service类,来实现对数据库的各种操作,然后在这个类中添加对数据库操作的增删改查方法。具体代码如下:
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import com.example.cardemo1.Username;
import com.example.cardemo1.db.DBHelper;
public class CarService {
private DBHelper dbHelper;
public CarService(Context context){
dbHelper=new DBHelper(context);
}
//添加车辆信息
public boolean register(Car car,String num){
SQLiteDatabase sdb = dbHelper.getReadableDatabase();
String str = "select carnumber from car where carnumber = ?";
Cursor cursor = sdb.rawQuery(str, new String[]{num});
if(cursor.moveToFirst() != true){
String sql ="insert into car(_id,carbrand,carsign,carmodel,carnumber,enginenum,bodylevel,mileage,gasoline,engineperfor,transperfor,carlight) values(?,?,?,?,?,?,?,?,?,?,?,?)";
Object obj[]={car.get_id(),car.getCarbrand(),car.getCarsign(),car.getCarmodel(),car.getCarnumber(),car.getEnginenum(),
car.getBodylevel(),car.getMileage(),car.getGasoline(),car.getEngineperfor(),car.getTransperfor(),car.getCarlight()};
sdb.execSQL(sql,obj);
return true;
}else{
return false;
}
}
//查询车辆信息,返回类型是ArrayList
public ArrayList select(String _id){
ArrayList<HashMap<String, String>> list = new ArrayList<HashMap<String, String>>();
SQLiteDatabase sdb = dbHelper.getReadableDatabase();
String sql="select * from car where _id=?";
Cursor cursor = sdb.rawQuery(sql, new String[]{_id});
while(cursor.moveToNext()){
HashMap<String, String> map= new HashMap<String, String>();
map.put("carbrand",cursor.getString(1));
map.put("carsign",cursor.getString(2));
map.put("carmodel",cursor.getString(3));
map.put("carnumber",cursor.getString(4));
map.put("enginenum",cursor.getString(5));
map.put("bodylevel",cursor.getString(6));
map.put("mileage",cursor.getString(7));
map.put("gasoline",cursor.getString(8));
map.put("engineperfor", cursor.getString(9));
map.put("transperfor", cursor.getString(10));
map.put("carlight", cursor.getString(11));
list.add(map);
}
return list;
}
//查询车牌号,返回类型是数组
public String[] select_carnum(String _id){
String[] carnum = new String[20];
String carnumber;
int index;
SQLiteDatabase sdb = dbHelper.getReadableDatabase();
String sql="select carnumber from car where _id=?";
Cursor cursor = sdb.rawQuery(sql, new String[]{_id});
int i = 0;
while(cursor.moveToNext()){
index = cursor.getColumnIndex("carnumber");
carnum[i] = cursor.getString(index);
i++;
}
return carnum;
}
//更新车辆信息
public boolean update(Car car,String num){
SQLiteDatabase sdb = dbHelper.getReadableDatabase();
String str ="select carnumber from car where carnumber = ?";
Cursor cursor = sdb.rawQuery(str, new String[]{num});
if(cursor.moveToFirst() == true){
String sql="update car set carbrand=?,carsign=?,carmodel=?,enginenum=?,bodylevel=?,mileage=?,gasoline=?,engineperfor=?,transperfor=?,carlight=? where _id = ?" ;
Object obj[]={car.getCarbrand(),car.getCarsign(),car.getCarmodel(),car.getEnginenum(),
car.getBodylevel(),car.getMileage(),car.getGasoline(),car.getEngineperfor(),car.getTransperfor(),car.getCarlight(),car.get_id()};
sdb.execSQL(sql,obj);
return true;
}else
{
String sql="update car set carbrand=?,carsign=?,carmodel=?,carnumber=?,enginenum=?,bodylevel=?,mileage=?,gasoline=?,engineperfor=?,transperfor=?,carlight=? where _id = ?" ;
Object obj[]={car.getCarbrand(),car.getCarsign(),car.getCarmodel(),car.getCarnumber(),car.getEnginenum(),
car.getBodylevel(),car.getMileage(),car.getGasoline(),car.getEngineperfor(),car.getTransperfor(),car.getCarlight(),car.get_id()};
sdb.execSQL(sql,obj);
return true;
}
}
其中加粗的是我要提取并和listview绑定的数据。然后我在activity类中是这么写的:
Username uname = (Username) getApplicationContext();
String name = uname.getUsername();
CarService service = new CarService(CarSeeActivity.this);
//调用Service中的select方法 来获取数据库中的数据
service.select(name);
//实例化listview空间
ListView lv = (ListView) findViewById(R.id.lv);
//创建adapter
SimpleAdapter adapter = new SimpleAdapter(CarSeeActivity.this, service.select(name), R.layout.item, new String[]{"carbrand","carsign","carmodel","carnumber","enginenum","bodylevel","mileage","gasoline","engineperfor","transperfor","carlight"},
new int[]{R.id.car_carbrand,R.id.car_carsign,R.id.car_carmodel,R.id.car_carnumber,R.id.car_enginenum,R.id.car_bodylevel,R.id.car_mileage,R.id.car_gasoline,R.id.car_engineperfor,R.id.car_transperfor,R.id.car_light});
//将listview和adapter绑定
lv.setAdapter(adapter);
//设置点击事件
lv.setOnItemClickListener(new ItemClickListener());
前两句是获取用户名的,为了在数据库中进行查找,和本节知识没有太大联系,只要知道是获取用户名就可以。
public class ItemClickListener implements OnItemClickListener{
@Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long id) {
// TODO Auto-generated method stub
ListView listview = (ListView)parent;
HashMap<String, String> data = (HashMap<String, String>)listview.getItemAtPosition(position);
String carid = data.get("carnumber");
Toast.makeText(getApplicationContext(), "车牌号为"+carid+"的车辆信息", 1).show();
}
My安卓知识2--使用listview绑定sqlite中的数据的更多相关文章
- vs 2015 rdlc报表绑定datagridview中的数据
这几天一直想要实现rdlc报表绑定datagridview中的数据,始终在虚拟表向rdlc报表绑定这一步上出错.今天从下午4点到七点四十一直在尝试.最终还是实现了,最然并不知所以然,这个问题还是以后在 ...
- C#跨进程读取listview控件中的数据
http://www.cnblogs.com/Charltsing/p/slv32.html 欢迎交流:QQ564955427 读取标准的32位listview控件中的数据,网上已经有很多代码了.今天 ...
- 安卓Android控件ListView获取item中EditText值
可以明确,现在没有直接方法可以获得ListView中每一行EditText的值. 解决方案:重写BaseAdapter,然后自行获取ListView中每行输入的EditText值. 大概算法:重写Ba ...
- Android中查看SQLite中字段数据的两种方式
方式一:ADB Pull 通过adb pull导出*.db文件到PC的文件夹中,通过可视化工具 SQLiteExpertPers 进行查看.编辑: adb pull /data/data/com.jo ...
- python从sqlite中提取数据到excel
import sqlite3 as sqlite from xlwt import * import sys def sqlite_get_col_names(cur, select_sql): cu ...
- springmvc中select可以绑定enum中所有数据的方法
public enum States { AK("AK"), AL("AL"), AR("AR"), AZ("AZ"), ...
- 王立平--查看SQLite中的数据信息
Eclipse菜单Window - Open Perspective - DDMS进入DDMS视图. 然后File Explorer View中依次展开路径/data/data/package_nam ...
- list中会直接绑定HashMap中的数据
import java.util.ArrayList;import java.util.HashMap;import java.util.List; public class HashMapSync ...
- ListView显示Sqlite的数据
在安卓中,ListView和Sqlite都是十分常用的.这次我们来结合这个两个知识点写一个Demo. 功能:吧SQLite中的数据用ListView显示出来. 先看截图吧 首先是数据库 然后是运行截图 ...
随机推荐
- buildroot使用详解
为什么要使用buildroot? (文件系统搭建,强烈建议直接用buildroot,官网[http://buildroot.uclibc.org/]上有使用教程非常详细)文件系统通常要包含很多第三方软 ...
- for..in遍历,枚举器
#pragma mark ------------for循环遍历集合中的元素------ //创建一个数组,包含5个字符串对象,倒序取出数组中的所有元素,并存储到另一可变数组中 NSArray *ar ...
- 自己写的 限制文本框TEdit中只能输入数字
procedure TForm4.Edit1KeyPress(Sender: TObject; var Key: Char); begin , #]) then begin Key := #; end ...
- 第一二九天上课 PHP 自制简单开发模板
构建基础架构 在项目文件夹(自定义)下创建 (1)核心目录:WQ (2)模板目录:MoBan (3)编译目录:BianYi (4)创建配置文件: config.ini.php <?php //获 ...
- make[2]: *** No rule to make target `/root/.pyenv/versions/anaconda3-2.4.0/lib/libpython3.5m.so', needed by `evaluation.so'. Stop.
当出现No rule to make target ,肯定是Makefile有问题. 有的makefile是脚本生成的,你得看脚本的配置文件对不对. 我的是这个脚本生成的.发现是Pythondir的配 ...
- logistic公式形式的由来,从广义线性回归说起
普通线性回归的形式为:(之所以这么写是因为的线性才是线性的所指) 线性回归模型有一下以下几个特征: 1. 2.x,y 通常取值连续 3.y的分布为正态分布或接近正态. 广义线性模型进行了如下推广: 1 ...
- 如何定位死循环或高CPU使用率(linux)
如何定位死循环或高CPU使用率(linux) 确定是CPU过高 使用top观察是否存在CPU使用率过高现象 找出线程 对CPU使用率过高的进程的所有线程进行排序 ps H -e -o pid,tid ...
- MongoDB安装启动服务
这里主要是针对解决出现的问题. 1.MongoDB 下载地址http://www.mongodb.org/downloads 下载之后可以自定义安装路径,我安装在了D盘下. 然后在环境变量中添加: M ...
- eclipse maven插件问题:error occurred while automatically activating bundle org.eclipse.m2e.core.ui (525)
①所有应用Close Project ②重启eclipse ③所有应用Open Project 出自:http://blog.csdn.net/qr719169236/article/details ...
- node npm 安装模块 淘宝镜像
npm --registry https://registry.npm.taobao.org info underscore