使用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();  
            
        }

时间: 2024-08-06 16:03:32

使用listview绑定sqlite中的数据的相关文章

vs 2015 rdlc报表绑定datagridview中的数据

这几天一直想要实现rdlc报表绑定datagridview中的数据,始终在虚拟表向rdlc报表绑定这一步上出错.今天从下午4点到七点四十一直在尝试.最终还是实现了,最然并不知所以然,这个问题还是以后在考虑吧,目前的项目要紧. 首先是  datagridview中的数据传到虚拟表中. for (int i = 0; i < dgvscan.Columns.Count - 1; i++) { dtout.Columns.Add(dgvscan.Columns[i].Name); } //添加行 fo

C#跨进程读取listview控件中的数据

http://www.cnblogs.com/Charltsing/p/slv32.html 欢迎交流:QQ564955427 读取标准的32位listview控件中的数据,网上已经有很多代码了.今天有空也做了个测试.读取TcpEye软件中的数据. 具体见程序附件.  下载(本程序可以自己修改主窗体类名和子窗体类名,抓取其他的软件数据.当然,窗体层次必须是2层,而且不能有多个同类名的子窗体,因为这只是个示例程序) *****************************************

王立平--查看SQLite中的数据信息

Eclipse菜单Window - Open Perspective - DDMS进入DDMS视图. 然后File Explorer View中依次展开路径/data/data/package_name/databases/. 将当中的db文件pull from device保存到电脑上, 再使用navicat.SQLiteSpy或其它软件打开查看 SQLiteSpy查看过程: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMzQyNTUyNw

ListView显示Sqlite的数据

在安卓中,ListView和Sqlite都是十分常用的.这次我们来结合这个两个知识点写一个Demo. 功能:吧SQLite中的数据用ListView显示出来. 先看截图吧 首先是数据库 然后是运行截图 接下来是讲解,运行程序后,先点击创建数据库的按钮,会创建出50条数据,然后点击查询,会将这50条数据查询并显示在ListView中. 直接看代码吧! 布局文件activity_main.xml <LinearLayout xmlns:android="http://schemas.andro

Android的Sqlite中DateTime类型数据的存取问题

关于讲sqlite中日期类型数据的存取网上有不少,但发现讲得这么细的非常少.更多的是用Date,不用做日期数据统计分析,对存取要求比较小的直接转换成long,即dateTime.getTime()存储.需要在界面上显示的时候就再将long型的日期数据转化为Date或DateTime类型.但是如果要做数据统计分析的话这样每条记录都要遍历转换会显得特别麻烦,数据量大的话时间消费是很大的. 我们知道Date类型数据在数据库中是yyyy-MM-dd形式存的,而Time是HH:mm形式存的.而DateTi

xamarin.android listview绑定数据及点击事件

前言 listview是用来显示数据列表的一个控件,今天给大家带来如何使用cursor进行数据绑定以及点击事件. 导读 1.如何创建一个listview 2.如何使用cursor进行绑定数据 3.listview的点击事件 正文 1.如何创建一个listview 这里我们自定义一个listview的视图,首先打开Main.axml,拖一个listview放进去. 右击Layout新建一个视图,名为UserListItemLayout.axml,拖两个textview进去,如图 这样我们就完成了一

Android 下分批加载数据以及listView使用过程中的优化

需求:在开发过程中,listview加载的数据如果比较大,这时为了提高用户体验感,我们应该事先分批加载以及下拉刷新功能 1.首先,数据访问层需要提供分批加载功能的接口, 代码如下: package com.zaizai.safty.db.dao; import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.database.

sqlite学习笔记9:C语言中使用sqlite之插入数据

前面创建了一张表,现在给他插入一些数据,插入数据跟创建表差不多,仅仅是SQL语言不一样而已,完整代码如下: #include <stdio.h> #include <stdlib.h> #include "sqlite/sqlite3.h" #define DB_NANE "sqlite/test.db" sqlite3 *db = NULL; char* sql = NULL; char *zErrMsg = NULL; int ret =

Android笔记(四十一) Android中的数据存储——SQLite(三)select

SQLite 通过query实现查询,它通过一系列参数来定义查询条件. 各参数说明: query()方法参数 对应sql部分 描述 table from table_name 表名称 colums select column1,column2 列名称数组 selection where column = value 条件子句,相当于where selectionArgs - 条件语句的参数数组 groupBy group by column 分组 having having column = v