Android数据存储——SQLite数据库(模板)
本篇整合Android使用数据库,要保存一个实体类的样本。
首先看一下数据库语句:
ORM:关系对象映射
添加数据:
ContentValues values = new ContentValues();
values.put("name", "小丽");
values.put("phone", "110");
mDB.insert("student",//表名
null, //规避插入语句的错误
values );//插入的值
删除数据:
mDB.delete("student", //表名
"name =?",//条件语句
new String[]{"小丽"});//条件语句的占位符
改动数据:
ContentValues values = new ContentValues();
values.put("phone", "10086");
mDB.update("student",//表名
values, //要改动的值
"name =?",//条件语句
new String[]{"小丽"});
查询数据:
Cursor cursor = mDB.query("student",//表名
null,//查询的字段
null,//条件语句
null,//条件语句的占位符
null,//分组语句
null,//分组条件
null);//排序
boolean toFirst = cursor.moveToFirst();
while(toFirst){
String name = cursor.getString(cursor.getColumnIndex("name"));
String phone = cursor.getString(cursor.getColumnIndex("phone"));
MyData myData = new MyData(name, phone);
dataList.add(myData);
toFirst = cursor.moveToNext();
}
以下是数据库创建及使用步骤
1、方法调用
private DBMang_Order dbMang_Order; dbMang_Order=DBMang_Order.getInstance(getApplicationContext());
//查询
ArrayList<OrderUncheck> uncheckList = dbMang_Order.query();
//删除
dbMang_Order.delete(orderNo);
//添加
dbMang_Order.insert(new OrderUncheck(orderNo, account, action));
//改动
dbMang_Order.update(new OrderUncheck(orderNo, account, action));
2、首先创建要存储的实体类
public class OrderUncheck {
String orderNo;
double account;
int action;
public String getOrderNo() {
return orderNo;
}
public void setOrderNo(String orderNo) {
this.orderNo = orderNo;
}
public double getAccount() {
return account;
}
public void setAccount(double account) {
this.account = account;
}
public int getAction() {
return action;
}
public void setAction(int action) {
this.action = action;
}
public OrderUncheck(String orderNo, double account, int action) {
super();
this.orderNo = orderNo;
this.account = account;
this.action = action;
}
}
3、创建数据库
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class MySQL_Order extends SQLiteOpenHelper {
private static final String name = "count"; //数据库名称
private static final int version = 1; //数据库版本号
//第三个參数CursorFactory指定在运行查询时获得一个游标实例的工厂类,设置为null,代表使用系统默认的工厂类
public MySQL_Order(Context context) {
super(context, name, null, version);
}
@Override
public void onCreate(SQLiteDatabase db) {
String sql="CREATE TABLE neworder (_id INTEGER PRIMARY KEY AUTOINCREMENT,orderNo VARCHAR(200),account VARCHAR(19100),action VARCHAR(200))";
db.execSQL(sql);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
}
}
4、代码中被调用的方法在这个类:增删改查
public class DBMang_Order {
private static DBMang_Order mDbManager=new DBMang_Order();
private static SQLiteDatabase mDb;
private static Context context;
private DBMang_Order() {
}
public static synchronized DBMang_Order getInstance(Context context){
DBMang_Order.context = context;
if(mDb==null){
MySQL_Order mySQL = new MySQL_Order(context);
mDb = mySQL.getWritableDatabase();
}
return mDbManager;
}
interface NewTable{
String TABLE_NAME="neworder";
String TABLE_COLUMN_orderNo="orderNo";
String TABLE_COLUMN_account="account";
String TABLE_COLUMN_action="action";
}
//增
public void insert(OrderUncheck info){
ContentValues values=new ContentValues();
values.put(NewTable.TABLE_COLUMN_orderNo, info.getOrderNo());
values.put(NewTable.TABLE_COLUMN_account, info.getAccount());
values.put(NewTable.TABLE_COLUMN_action, info.getAction());
Log.w("mDb.insert", ""+info);
Log.w("mDb.insert",""+ values);
mDb.insert(NewTable.TABLE_NAME, null, values);
}
//删
public void delete(String orderNo) {
Log.w("delete", orderNo);
mDb.delete(NewTable.TABLE_NAME, NewTable.TABLE_COLUMN_orderNo+"=?", new String[]{orderNo});
}
//改
public void update(OrderUncheck info){
ContentValues values = new ContentValues();
values.put(NewTable.TABLE_COLUMN_account, info.getAccount());
mDb.update(NewTable.TABLE_NAME, values, NewTable.TABLE_COLUMN_orderNo+"=? and "+NewTable.TABLE_COLUMN_orderNo+"=?
", new String[]{String.valueOf(info.getOrderNo()),""+info.getAccount()});
}
//查
public ArrayList<OrderUncheck> query(){
Cursor cursor = mDb.query(NewTable.TABLE_NAME, null, null, null, null, null, null);
ArrayList<OrderUncheck> list=new ArrayList<OrderUncheck>();
boolean toFirst = cursor.moveToFirst();
while (toFirst) {
String orderNo = cursor.getString(cursor.getColumnIndex(NewTable.TABLE_COLUMN_orderNo));
String account = cursor.getString(cursor.getColumnIndex(NewTable.TABLE_COLUMN_account));
String action = cursor.getString(cursor.getColumnIndex(NewTable.TABLE_COLUMN_account));
double accountd = Double.parseDouble(account);
int actiond=Integer.parseInt(action);
OrderUncheck order = new OrderUncheck(orderNo, accountd,actiond);
list.add(order);
toFirst=cursor.moveToNext();
}
cursor.close();
return list;
}
}
很多其它交流可加Android技术讨论群:71262831
版权声明:本文博主原创文章,博客,未经同意不得转载。
Android数据存储——SQLite数据库(模板)的更多相关文章
- 【Android 应用开发】Android 数据存储 之 SQLite数据库详解
. 作者 :万境绝尘 转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/19028665 . SQLiteDataBase示例程序下 ...
- Android 数据存储 之 SQLite数据库详解
. 作者 :万境绝尘 转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/19028665 . SQLiteDataBase示例程序下 ...
- Android数据存储之SQLite数据库
Android数据存储 之SQLite数据库简介 SQLite的相关知识,并结合Java实现对SQLite数据库的操作. SQLite是D.Richard Hipp用C语言编写的开源嵌入式数据库引擎. ...
- Android数据存储之SQLCipher数据库加密
前言: 最近研究了Android Sqlite数据库(文章地址:Android数据存储之Sqlite的介绍及使用)以及ContentProvider程序间数据共享(Android探索之ContentP ...
- Android版本升级同时Sqlite数据库的升级及之前数据的保留
http://www.cnblogs.com/wang340/archive/2013/05/06/3063135.html http://www.eoeandroid.com/forum.php?m ...
- Android - 数据存储 -在SQL数据库中保存数据
对于重复的或结构化的数据,保存到数据库中是很好的选择,比如联系人信息.这里假设你对SQL数据库大体上了解然后帮助你学习Android上的SQLite数据库.在Android数据库上需要用到的API可以 ...
- Android数据存储:SQLite
Android数据存储之SQLite SQLite:Android提供的一个标准的数据库,支持SQL语句.用来处理数据量较大的数据.△ SQLite特征:1.轻量性2.独立性3.隔离性4.跨平台性5. ...
- Android 数据存储03之SQLite
SQLite数据存储 Android 集成了 SQLite 数据库.它存储在 /data/data/< 项目文件夹 >/databases/ 下.Android 开发中使用 SQLite ...
- Android数据存储之SQLite
SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,占用资源非常少,只有几百KB内存.支持Windows/Linux ...
随机推荐
- Java常用代码段 - 未完待续
记录一些自己写项目常用的代码段. 格式化常用日期格式 Date date = new Date(System.currentTimeMillis()); DateFormat d3 = DateFor ...
- android百度地图打包混淆 用不了No such file or directory (2) com.baidu.mapapi.BMapManager.init(Unknown Source)
调用了百度地图地图开发包是baidumapapi_v2_1_1.jar,定位SDK版本是locSDK_3.3.jar 调试的时候能运行!可是打包签名后就运行不了! baidu google 了好久! ...
- Github Atom
码代码新神器-Github Atom 周末闲着没事,逛论坛发现了一个新的编辑器,由github发布的Atom编辑器.瞬间被吸引了,所以就去尝试着折腾了一下,后来发现这个编辑器确实很不错,他的特点就 ...
- HTML中Id和Name的区别
源地址:http://www.cnblogs.com/laodai/articles/2244215.html 在html中:name指的是用户名称,ID指的是用户注册是系统自动分配给用户的一个序列号 ...
- js中获取jsp中的参数
碰到一个问题需要再js中根据jsp中request的参数判断执行那段代码 第一种写法: if('${method}'=="add"){js代码段1}else{js代码段2} 第二种 ...
- 使用AjaxFileUpload.js实现文件异步上�
ajax是无法提交文件的,所以在上传图片并预览的时候,我们常常使用Ifame的方法实现看似异步的效果.可是这样总不是非常方便的,AjaxFilleUpload.js对上面的方法进行了一个包装,使得我们 ...
- [Android学习笔记]PopupWindow的使用
什么时候使用PopupWindow? 当业务需求的交互形式需要在当前页弹出一个简单可选项UI与用户进行交互时,可使用PopupWindow完成此功能开发 Android Dev API Doc Pop ...
- 4.2、Libgdx每个模块概述
(原版的:http://www.libgdx.cn/topic/34/4-2-libgdx%E5%90%84%E4%B8%AA%E6%A8%A1%E5%9D%97%E6%A6%82%E8%A7%88) ...
- c++重载ostream的实现
#include <iostream> using namespace std; class Point{ public: Point(int _x = 0, int _y = 0, in ...
- 每天一点儿java-button
<pre name="code" class="java">import java.awt.*; import java.awt.event.*; ...