sqlite数据库操作详细介绍 增删改查,游标
本文来源于www.ifyao.com禁止转载!www.ifyao.com
- package com.example.engine;
- import android.content.Context;
- import android.database.sqlite.SQLiteDatabase;
- import android.database.sqlite.SQLiteDatabase.CursorFactory;
- import android.database.sqlite.SQLiteOpenHelper;
- public class DBOpenHelper extends SQLiteOpenHelper {
- private final static String DB_NAME = "NFCAssistant.db";// 数据库名称
- private final static int DB_VERSION = 2;// 版本
- private final static String DB_USER_TABLE = "tbl_users";// 用户表
- private final static String DB_BatchEpment_TABLE = "tbl_batch";// 批量信息
- private final static String DB_LargeEpment_TABLE = "tbl_large";// 大型设备
- private final static String DB_LOG_TABLE = "tbl_log";// 日志
- public DBOpenHelper(Context context) {
- super(context, DB_NAME, null, DB_VERSION);
- }
- @Override
- public void onCreate(SQLiteDatabase db) {
- // TODO Auto-generated method stub
- // 用户表 角色1管理员2超级管理员
- String createTable = "CREATE TABLE " + DB_USER_TABLE + " ("
- + "Id integer PRIMARY KEY AUTOINCREMENT UNIQUE,"
- + "UserName varchar (10) NOT NULL UNIQUE,"
- + "PassWord varchar (49) NOT NULL,"
- + "Role varchar (10) DEFAULT 1" + ");";
- // 批量信息表
- String createTblBatchEpment = "CREATE TABLE " + DB_BatchEpment_TABLE
- + " (" + "Id integer PRIMARY KEY AUTOINCREMENT UNIQUE, "
- + "DeviceId integer NOT NULL UNIQUE,"
- + "Codes varchar (100) NOT NULL,"
- + "DeviceName varchar NOT NULL ," + "Price integer NOT NULL,"
- + "Custodian varchar NOT NULL," + "End_user varchar NOT NULL,"
- + "Time datatime NOT NULL" + ");";
- // 大型设备表
- String createTblLargeEpment = "CREATE TABLE " + DB_LargeEpment_TABLE
- + " (" + "Id integer PRIMARY KEY AUTOINCREMENT UNIQUE, "
- + "DeviceId integer NOT NULL UNIQUE,"
- + "DeviceName varchar NOT NULL ,"
- + "Codes varchar (100) NOT NULL," + "Price integer NOT NULL,"
- + "Custodian varchar NOT NULL," + "End_user varchar NOT NULL,"
- + "Time datatime NOT NULL," + "Location varchar NOT NULL"
- + ");";
- // 日志表
- String createTblLog = "CREATE TABLE " + DB_LOG_TABLE + " ("
- + "Id integer PRIMARY KEY AUTOINCREMENT UNIQUE, "
- + "UserName varchar NOT NULL ," + "DeviceId integer NOT NULL,"
- + "Time datatime NOT NULL" + ");";
- db.execSQL(createTable);
- db.execSQL(createTblBatchEpment);
- db.execSQL(createTblLargeEpment);
- db.execSQL(createTblLog);
- }
- @Override
- public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
- // TODO Auto-generated method stub
- db.execSQL("DROP TABLE IF EXISTS " + DB_USER_TABLE);
- db.execSQL("DROP TABLE IF EXISTS " + DB_BatchEpment_TABLE);
- db.execSQL("DROP TABLE IF EXISTS " + DB_LargeEpment_TABLE);
- db.execSQL("DROP TABLE IF EXISTS " + DB_LOG_TABLE);
- onCreate(db);
- }
- }
数据库操作帮助类
DBhelper继承sqliteDBhelper
实现父类的两个方法
Oncreate方法当创建数据库的时候执行
更新方法,当数据库版本更新时执行
- package com.example.engine;
- import com.example.bean.BatchEpment;
- import android.content.Context;
- import android.database.sqlite.SQLiteDatabase;
- /**
- * 操作数据库事物
- *
- * @author ming
- *
- */
- public class DBService {
- private DBOpenHelper dbHelper;
- /**
- * 构造器,得到DBopenHelpper的操作实例
- *
- * @param context
- */
- public DBService(Context context) {
- this.dbHelper = new DBOpenHelper(context);
- }
- /**
- * 将Batch批量数据excel数据保存到数据库
- *
- * @param batch
- */
- public void saveExcelBatch(BatchEpment batch) {
- SQLiteDatabase db = dbHelper.getWritableDatabase();
- db.execSQL(
- "insert into tbl_batch (DeviceId,Codes,DeviceName,Price,Custodian,End_user,Time) values(?,?,?,?,?,?,?)",
- new Object[] { batch.getDeviceId(), batch.getCodes(),
- batch.getDeviceName(), batch.getPrice(),
- batch.getCustodian(), batch.getEnd_user(),
- batch.getTime() });
- };
- }
数据库增删改查业务类,
saveExcelBatch方法将数据插入数据库中
- package com.example.test;
- import com.example.bean.BatchEpment;
- import com.example.engine.DBOpenHelper;
- import com.example.engine.DBService;
- import android.test.AndroidTestCase;
- public class ExcelTest extends AndroidTestCase {
- public void get() throws Exception {
- BatchEpment batch = new BatchEpment();
- batch.setDeviceId("111");
- batch.setCodes("ss");
- batch.setDeviceName("计算机");
- batch.setPrice("2000");
- batch.setCustodian("刘欢");
- batch.setEnd_user("罗琼");
- batch.setTime("20111115");
- DBService dbService = new DBService(getContext());
- dbService.saveExcelBatch(batch);
- }
- }
写一个测试类传入数据,调用业务类的方法插入数据
- package com.example.bean;
- /**
- * 批量设备实体类
- *
- * @author ming
- *
- */
- public class BatchEpment {
- String Id;// 自动编号
- String DeviceId;// 设备编号
- String Codes;// 分类号
- String DeviceName;// 设备名称
- String Price;// 价格
- String Custodian;// 保管人
- String End_user;// 使用单位
- String Time;// 时间
- public BatchEpment() {
- };
- public BatchEpment(String id, String deviceId, String codes,
- String deviceName, String price, String custodian, String end_user,
- String time) {
- super();
- Id = id;
- DeviceId = deviceId;
- Codes = codes;
- DeviceName = deviceName;
- Price = price;
- Custodian = custodian;
- End_user = end_user;
- Time = time;
- }
- public String getId() {
- return Id;
- }
- public void setId(String id) {
- this.Id = id;
- }
- public String getDeviceId() {
- return DeviceId;
- }
- public void setDeviceId(String deviceId) {
- this.DeviceId = deviceId;
- }
- public String getCodes() {
- return Codes;
- }
- public void setCodes(String codes) {
- this.Codes = codes;
- }
- public String getDeviceName() {
- return DeviceName;
- }
- public void setDeviceName(String deviceName) {
- this.DeviceName = deviceName;
- }
- public String getPrice() {
- return Price;
- }
- public void setPrice(String price) {
- this.Price = price;
- }
- public String getCustodian() {
- return Custodian;
- }
- public void setCustodian(String custodian) {
- this.Custodian = custodian;
- }
- public String getEnd_user() {
- return End_user;
- }
- public void setEnd_user(String end_user) {
- this.End_user = end_user;
- }
- public String getTime() {
- return Time;
- }
- public void setTime(String time) {
- this.Time = time;
- }
- }
实体类 另外一个实例:values(?,?)?是占位符,后边数组中的是实际的值 db.rawQuery返回的是一个游标对象 cursor.movetofirst将游标移到第一条记录返回值是个Boolean值 得到由表里边的值 cursor.getInt(对应字段的行标,通过表的对用字段); 最后将游标关闭。要是查询的是多条记录的话,就要迭代查询 cursor,moveTOnext 最后将数据存到Arraylist里边 getcount方法是得到记录的行数
android系统提供的四种操作数据的方法:insert(),delete(),updata(),query()详细介绍看下方图片截图。
将前面提供的用SQL写的例子变成系统方法 插入和删除
查询
分页
sqlite数据库操作详细介绍 增删改查,游标的更多相关文章
- Mysql数据库操作复习,增删改查
Mysql数据库 Apache(服务员) php(大厨) mysql(冰柜) Mysql是瑞典的mysqlAB公司开发的一款中小型关系型数据库管理系统. MysqlAB公司在2008年被S ...
- iOS- Swift:使用FMDB进行数据库操作(线程安全:增删改查)
1.前言 GitHub上2000多颗星的FMDB数据库框架想来大家都很熟悉, 今天用Swift对其进行了一个完成的数据存储读流程 写完之后用博客分享之,与大家一起交流, 希望对需要的朋友提供些帮助 ...
- python操作三大主流数据库(8)python操作mongodb数据库②python使用pymongo操作mongodb的增删改查
python操作mongodb数据库②python使用pymongo操作mongodb的增删改查 文档http://api.mongodb.com/python/current/api/index.h ...
- 利用SQLite在android上实现增删改查
利用SQLite在android上实现增删改查 方法: 一.直接利用database.execSQL()方法输入完整sql语句进行操作 这种方法适用于复杂的sql语句,比如多表查询等等 这里适合于增删 ...
- MySQL数据库之表的增删改查
目录 MySQL数据库之表的增删改查 1 引言 2 创建表 3 删除表 4 修改表 5 查看表 6 复制表 MySQL数据库之表的增删改查 1 引言 1.MySQL数据库中,数据库database就是 ...
- 使用JDBC分别利用Statement和PreparedStatement来对MySQL数据库进行简单的增删改查以及SQL注入的原理
一.MySQL数据库的下载及安装 https://www.mysql.com/ 点击DOWNLOADS,拉到页面底部,找到MySQL Community(GPL)Downloads,点击 选择下图中的 ...
- C#操作Excel数据增删改查(转)
C#操作Excel数据增删改查. 首先创建ExcelDB.xlsx文件,并添加两张工作表. 工作表1: UserInfo表,字段:UserId.UserName.Age.Address.CreateT ...
- C#操作Excel数据增删改查示例
Excel数据增删改查我们可以使用c#进行操作,首先创建ExcelDB.xlsx文件,并添加两张工作表,接下按照下面的操作步骤即可 C#操作Excel数据增删改查. 首先创建ExcelDB.xlsx文 ...
- SpringBoot操作MongoDB实现增删改查
本篇博客主讲如何使用SpringBoot操作MongoDB. SpringBoot操作MongoDB实现增删改查 (1)pom.xml引入依赖 <dependency> <group ...
随机推荐
- [GIT] warning: LF will be replaced by CRLF问题解决方法
原文链接[http://michael-roshen.iteye.com/blog/1328142] 开发环境: 操作系统: windows xp ruby 1.9.2 rails 3.1.3 git ...
- 分享QQ第三方登陆SDK
主要是考虑到QQ的PHP SDK写的真是太烂了,纯属是普及API知识,而不是到手就可以部署的类库..反正自己都写了一个了,就拿出来分享下.. 什么也不多说,直接上代码. Qq_sdk.php < ...
- Python新手学习基础之条件语句——if/else语句
if/else语句 条件语句实际在前面的文章里我们已经使用过几次了,在这里我们需要再次隆重的来介绍一下它,条件语句是通过对一条或多条语句判断的返回结果(True或False)来选择执行下一步命令的,比 ...
- Swift数据类型之整型和浮点型-备
Swift提供8.16.32.64位形式的有符号及无符号整数.这些整数类型遵循C语言的命名规约,我归纳了Swift中的整型: 整型示例: print("UInt8 range: \(UInt ...
- Android扩展 - 拍照篇(Camera)
1.调用系统摄像头 1.声明常量和变量 2.按钮点击事件,打开系统摄像头 3.重写onActivityResult事件接收拍照返回 4.生成文件名返回路径 5.保存图片 private static ...
- 面试题 43 n 个骰子的点数
; void printfProbability(int number) { ) return; ]; p[] = ]; p[] = ]; memset(p[], , )); memset(p[], ...
- Qt跨线程信号和槽的连接(默认方式是直连和队列的折中)
Qt支持三种类型的信号-槽连接:1,直接连接,当signal发射时,slot立即调用.此slot在发射signal的那个线程中被执行(不一定是接收对象生存的那个线程)2,队列连接,当控制权回到对象属于 ...
- 微软开源PowerShell并支持Linux和OS X
[微软在开源的道路上加速度了] 从一开始的各种对抗,各种通吃,到现在开始做服务,包罗万象.果然,换了主力,大有不同. 微软今天还宣布开源其.NET框架,令.NET Core能在Linux和OS X上运 ...
- Linux企业级项目实践之网络爬虫(25)——管理源代码之SVN
软件项目开发中,一般会用到源代码管理工具SVN.版本控制是管理数据变更的一种技术.对于程序员来说,它已经成为不可或缺的工具,因为他们经常修改软件代码,产生部分的变更,然后第二天再取消所有的变更.想象有 ...
- Delphi TcxTreeListColumn 的 ImageComboBox 用法
1.设置图片如下: 设置默认值: if Trim(FQuery.fieldByName('cPersonCategory').AsString) = '' then begin CNode.Value ...
要是查询的是多条记录的话,就要迭代查询 cursor,moveTOnext 最后将数据存到Arraylist里边 getcount方法是得到记录的行数
分页