一:创建数据库

package com.itcode.mysqlite;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper; /**
* 继承SQLiteOpenHelper,创建数据库
* @author Administrator
*
*/
public class MySQLiteOpenHelper extends SQLiteOpenHelper{ //一:声明构造函数
/**
* @param context 当前应用的环境,用来确定数据库目录
* @param name 数据库文件的名字
* @param factory 游标工厂,用来创建结果集对象
* @param version 数据库版本 从1开始
*/
public MySQLiteOpenHelper(Context context) {
super(context, "itcode.db", null, 1);
} //二:重写onCreate方法 数据库被创建时调用
public void onCreate(SQLiteDatabase db) {
System.out.println("MySQLiteOpenHelper-->onCreate 被调用!");
//1.创建数据库
db.execSQL("create table account(_id INTEGER PRIMARY KEY AUTOINCREMENT,name VARCHAR(20),balance INTEGER)");
// db.execSQL("CREATE TABLE account(_id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20))"); // 执行一条SQL语句 }
//三:重写onUpgreade方法,数据库时调用
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// System.out.println("MySQLiteOpenHelper-->onUpgrade 被调用");
// db.execSQL("alter table account ADD balance integer");
// db.execSQL("ALTER TABLE account ADD balance INTEGER"); } }

二:对数据库进行CRUD操作

package com.itcode.mysqlite;

import java.util.ArrayList;
import java.util.List; import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase; public class AccountDao {
//一:创建AccountDao时依据当前context创建数据库
private MySQLiteOpenHelper mySQLiteOpenHelper;
public AccountDao(Context context){
mySQLiteOpenHelper = new MySQLiteOpenHelper(context);
}
//二:增:传进来一个Account,将此对象加入数据库
public int add(Account a){
//1.获取相应的(可写的)数据库
SQLiteDatabase writableDatabase = mySQLiteOpenHelper.getWritableDatabase();
//2.执行语句
writableDatabase.execSQL("insert into account(name,balance) values(?,?)", new Object[]{a.getName(),a.getBalance()});
//3.获取插入的数据集:
Cursor rawQuery = writableDatabase.rawQuery("select _id from account order by _id desc limit 1", null);
rawQuery.moveToNext();
int id = rawQuery.getInt(rawQuery.getColumnIndex("_id"));
//4.关闭数据库
return id;
}
//三:删:根据id删除数据库中相应的数据项
public void delete(int id){
//1.获取相应的(可写的)数据库
SQLiteDatabase writableDatabase = mySQLiteOpenHelper.getWritableDatabase();
//2.执行删除语句
writableDatabase.execSQL("Delete from account where _id = ?",new Object[]{id});
//3.关闭数据库
writableDatabase.close();
}
//四:改:传进来一个Account,根据Account的对象的id修改name 和balance
public void update(Account a){
//1.获取相应的(可写的)数据库
SQLiteDatabase writableDatabase = mySQLiteOpenHelper.getWritableDatabase();
//2.执行更新语句
writableDatabase.execSQL("update account set name=?,balance = ? where _id = ?",new Object[]{a.getName(),a.getBalance(),a.getId()});
//3.关闭数据库
writableDatabase.close();
}
//五:查:根据id查询数据库
public Account query(int id){
//1.获取相应的(可读的)数据库
SQLiteDatabase readableDatabase = mySQLiteOpenHelper.getReadableDatabase();
//2.执行更新语句
Cursor rawQuery = readableDatabase.rawQuery("select * from account where _id=?", new String[]{String.valueOf(id)});
//3.将查询到的数据赋值给Account对象
Account a = null;
while(rawQuery.moveToNext()){
Integer balance = Integer.valueOf(rawQuery.getString(rawQuery.getColumnIndex("balance")));
String name = rawQuery.getString(rawQuery.getColumnIndex("name"));
a = new Account(id,name,balance);
}
//3.关闭结果集与数据库
rawQuery.close();
readableDatabase.close();
return a;
}
//六:查询所有,将查询到的所有数据放在list集合中返回
public List<Account> queryAll(){
List<Account> list = new ArrayList<Account>();
Account a = null;
//1.获取相应的(可读的)数据库
SQLiteDatabase readableDatabase = mySQLiteOpenHelper.getReadableDatabase();
Cursor rawQuery = readableDatabase.rawQuery("Select * from account",null);
while(rawQuery.moveToNext()){
Integer id = Integer.valueOf(rawQuery.getString(rawQuery.getColumnIndex("_id")));
String name = rawQuery.getString(rawQuery.getColumnIndex("name"));
Integer balance = Integer.valueOf(rawQuery.getString(rawQuery.getColumnIndex("balance")));
a = new Account(id,name,balance);
list.add(a);
}
//3.关闭资源
rawQuery.close();
readableDatabase.close();
return list;
}
//七:分页查询:传入要查询第几页,每页显示几条数据,将查询到的数据放在list集合中返回
public List<Account> queryPage(int pageNum,int pageSize){
List<Account> list = new ArrayList<Account>();
Account a = null;
String index = String.valueOf((pageNum-1)*pageSize);
String count = String.valueOf(pageSize);
//1.获取相应的(可读的)数据库
SQLiteDatabase readableDatabase = mySQLiteOpenHelper.getReadableDatabase();
//2.执行相应的查询语句
Cursor rawQuery = readableDatabase.rawQuery("select * from account limit ?,?", new String[]{index,count});
while(rawQuery.moveToNext()){
Integer id = Integer.valueOf(rawQuery.getString(rawQuery.getColumnIndex("_id")));
String name = rawQuery.getString(rawQuery.getColumnIndex("name"));
Integer balance = Integer.valueOf(rawQuery.getString(rawQuery.getColumnIndex("balance")));
a = new Account(id,name,balance);
list.add(a);
}
//3.关闭相应的资源
rawQuery.close();
readableDatabase.close();
return list;
}
//八:查询总记录条数
public int queryCount(){
//1.获取相应的(可读的)数据库
SQLiteDatabase readableDatabase = mySQLiteOpenHelper.getReadableDatabase();
//2.执行相应的语句
Cursor rawQuery = readableDatabase.rawQuery("select count(*) from account", null);
rawQuery.moveToNext();//不加此句可否?不能去掉!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
int count = rawQuery.getInt(0);
//3.关闭资源
rawQuery.close();
readableDatabase.close();
return count;
}
//九:事物管理 从一个Account对象向另一个Account对象汇款,传入参数,fromid,toId,moneySize
public void remit(int fromId,int toId,int moneySize){
SQLiteDatabase writableDatabase = null;
try {
//1.获取相应的(可写的)数据库
writableDatabase = mySQLiteOpenHelper.getWritableDatabase();
//2.开启事物
writableDatabase.beginTransaction();
//3.执行相应的语句
writableDatabase.execSQL("update account set balance=balance-? where _id = ?", new Object[]{moneySize,fromId});
writableDatabase.execSQL("update account set balance=balance+? where _id = ?",new Object[]{moneySize,toId});
//4.设置成功标记
writableDatabase.setTransactionSuccessful();
//5.关闭资源
writableDatabase.close();
} catch (Exception e) {
//6.结束事务,会把最后一次成功标记之前的事务提交
writableDatabase.endTransaction();
e.printStackTrace();
} }
}

三:对CRUD的方法的测试:

package com.itcode.mysqlite;

import java.util.List;
import java.util.Random; import android.database.sqlite.SQLiteDatabase;
import android.test.AndroidTestCase; public class SQLiteTest extends AndroidTestCase{
//1.测试创建数据库的方法
public void testCreateDB(){
//1.创建数据库
MySQLiteOpenHelper helper = new MySQLiteOpenHelper(getContext());
//2.得到相应的数据库
SQLiteDatabase db = helper.getWritableDatabase();
db.execSQL("INSERT INTO account(_id,name, balance) VALUES(1,'fuck', 10000)"); } //2.测试添加数据的方法
public void testAdd(){
AccountDao dao = new AccountDao(getContext());// Context android.test.AndroidTestCase.getContext()
for(int i=1;i<100;i++){
dao.add(new Account("Test" + i,new Random().nextInt(10000)));
}
}
//3.测试删除数据的方法
public void testDelete(){
AccountDao dao = new AccountDao(getContext());
for(int i=100;i<200;i++){
dao.delete(i);
}
}
//4.测试修改数据的方法
public void testUpdate(){
AccountDao dao = new AccountDao(getContext());
Account a = new Account(1,"fuck you!!!~",999);
dao.update(a);
}
//5.测试查询数据的方法,根据id查询数据库
public void testQuery(){
AccountDao dao = new AccountDao(getContext());
System.out.println(dao.query(1));
System.out.println(dao.query(3));
System.out.println(dao.query(4));
}
//6.测试查询所有的方法
public void testQueryAll(){
AccountDao dao = new AccountDao(getContext());
List<Account> list =null;
list = dao.queryAll();
for (Account account : list) {
System.out.println(account);
}
}
//7.测试分布查询的方法
public void testQueryPage(){
AccountDao dao = new AccountDao(getContext());
List<Account> list = null;
list = dao.queryPage(2, 10);
for (Account account : list) {
System.out.println(account);
}
}
//8.测试查询总记录条数的方法
public void testQueryCount(){
AccountDao dao = new AccountDao(getContext());
int count = dao.queryCount();
System.out.println(count);
}
}

Android下的SQLite数据库的相关操作及AndroidTestCase测试的更多相关文章

  1. Android下利用SQLite数据库实现增删改查

    1: 首先介绍如何利用adb查看数据库 1: adb shell 2: cd /data/data/包名/databases 3:  sqlite3 数据库 4   接下来就可以进行数据库的sql语法 ...

  2. Android下用Sqlite数据库存储数据

    第一步:  写个类 ,继承 SQLiteOpenHelper public class MyDatabaseOpenHelper extends SQLiteOpenHelper { } 第二步:   ...

  3. linux下安装mysql数据库与相关操作

    如下命令都是用root身份安装,或者在命令前加上sudo 采用yum安装方式安装 yum install mysql #安装mysql客户端 yum install mysql-server #安装m ...

  4. Android 开发中 SQLite 数据库的使用

    SQLite 介绍 SQLite 一个非常流行的嵌入式数据库,它支持 SQL 语言,并且只利用很少的内存就有很好的性能.此外它还是开源的,任何人都可以使用它.许多开源项目((Mozilla, PHP, ...

  5. Android版本升级同时Sqlite数据库的升级及之前数据的保留

    http://www.cnblogs.com/wang340/archive/2013/05/06/3063135.html http://www.eoeandroid.com/forum.php?m ...

  6. PHP对MySQL数据库的相关操作

    一.Apache服务器的安装 <1>安装版(计算机相关专业所用软件---百度云链接下载)-直接install<2>非安装版(https://www.apachehaus.com ...

  7. Android存储之SQLite数据库

    Android存储之SQLite数据库数据库 创建数据库 package --; import android.content.Context; import android.database.sql ...

  8. Android基础总结+SQlite数据库【申明:来源于网络】

    Android基础总结+SQlite数据库[申明:来源于网络] 基础总结篇之一:Activity生命周期:http://blog.csdn.net/liuhe688/article/details/6 ...

  9. python操作mysql数据库的相关操作实例

    python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...

随机推荐

  1. js深入研究之自定义混合Mixin函数

    <script type="text/javascript"> /* 增加函数 */ function augment(receivingClass, givingCl ...

  2. Linux企业级项目实践之网络爬虫(12)——处理HTTP应答头

    Web服务器的HTTP应答一般由以下几项构成:一个状态行,一个或多个应答头,一个空行,内容文档.设置HTTP应答头往往和设置状态行中的状态代码结合起来.例如,有好几个表示"文档位置已经改变& ...

  3. Linux企业级项目实践之网络爬虫(5)——处理配置文件

    配置文件在Linux下使用得非常普遍,但是Linux下没有统一个配置文件标准. 我们把配置文件的规则制定如下: 1.把"#"视作注释开始 2.所有的配置项都都是以键值对的形式出现 ...

  4. PHP基础设计模式——工厂模式

    <?php//文件名:Factory namespace IMooc; class Factory { //工程模式 static function creatDatabase() { $db ...

  5. 又一编辑神器-百度编辑器-Ueditor

    (Lionden<hsdlionden@gmail.com> 转载说明) 前段时间发表过一篇关于“KindEditor在JSP中使用”的博文.这几天在沈阳东软进行JavaWeb方面的实习工 ...

  6. WPF - XAML如何引入名字空间

    WPF 的XAML引入名字空间的概念,经常容易让人混淆.如何引入名字空间,并且在XAML中调用其中的类,下面给一个简单的介绍. 比如我们有一个Hepler类. namespace Wheat.PIMS ...

  7. BootStrap学习之先导篇——响应式网页

    Bootstrap学习之前,要知道响应式网页的原理. 1.什么是响应式网页? 一个页面,可以根据浏览设备的不同,以及特性的不同,而自动改变布局.大小等.使得在不同的设备上上都可以呈现优秀的界面. 优点 ...

  8. JavaScript 精髓整理篇之一(对象篇)postby:http://zhutty.cnblogs.com

    废话篇头: 由于工作关系,所以写博文的时间有那么点~~,其实是输入法太懒了,都是输入法的错~~ 这一系列的博客将总结所有关于JavaScript语言的精髓,适合0基础到大师级别人物阅读. <Ja ...

  9. VMware vSphere 5.5的12个更新亮点(3)

    端口镜像 有时有必要捕捉网络中的数据包来追踪问题.最新版本的vSphere包括一个增强版的开源数据包分析器tcpdump和一些镜像端口的选项以捕捉各种场所的流量.您可以捕获虚拟网卡,虚拟交换机,以及主 ...

  10. [Cycle.js] Introducing run() and driver functions

    Currently the code looks like : // Logic (functional) function main() { return { DOM: Rx.Observable. ...