在Android应用中使用SQLite数据库

应用生成的数据库文件保存为/data/data/应用包名/databases/name.db,生成的文件可用SQLite Expert打开

(name是自定义的,例如,我的应用是保存在:/data/data/com.sinaapp.sql/databases/ssun.db中)

SQLiteActivity.java源码:

package com.sinaapp.sql;

import com.sinaapp.sql.R;

import android.app.Activity;

import android.os.Bundle;

public class SQLiteActivity extends Activity {

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

}

}

Pseron.java源码:

package com.sinaapp.domain;

public class Person {

private String name;

private Integer id;

private String phone;

private Integer amount;

public Person() {}

@Override

public String toString() {

return "Person [name=" + name + ", id=" + id + ", phone=" + phone

+ ", amount=" + amount + "]";

}

public Person(String name, Integer id, String phone, Integer amount) {

this.name = name;

this.id = id;

this.phone = phone;

this.amount = amount;

}

public Person(String name, String phone, Integer amount) {

this.name = name;

this.phone = phone;

this.amount = amount;

}

public Integer getAmount() {

return amount;

}

public void setAmount(Integer amount) {

this.amount = amount;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public String getPhone() {

return phone;

}

public void setPhone(String phone) {

this.phone = phone;

}

}

DBOpenHelper.java源码:

package com.sinaapp.service;

import android.content.Context;

import android.database.sqlite.SQLiteDatabase;

import android.database.sqlite.SQLiteOpenHelper;

public class DBOpenHelper extends SQLiteOpenHelper {

public DBOpenHelper(Context context) {

super(context, "ssun.db", null, 3);//数据库版本号改变,将会执行onUpgrade方法

}

@Override

public void onCreate(SQLiteDatabase db) {//第一次使用时执行的方法

// TODO Auto-generated method stub

db.execSQL("create table person(id integer primary key autoincrement,name varchar(20),phone varchar(20))");

}

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

// TODO Auto-generated method stub

db.execSQL("alter table person add amount int(10)");

}

}

PersonService.java源码:

package com.sinaapp.service;

import java.util.ArrayList;

import java.util.List;

import android.content.Context;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

import com.sinaapp.domain.Person;

public class PersonService {

private DBOpenHelper helper;

public PersonService(Context context){

this.helper = new DBOpenHelper(context);

}

public void payment(){

SQLiteDatabase db = helper.getWritableDatabase();

try{

db.beginTransaction();

db.execSQL("update person set amount = amount - 10 where id = 3");

db.execSQL("update person set amount = amount + 10 where id = 4");

db.setTransactionSuccessful();

}finally{

db.endTransaction();

}

}

/**

* 添加记录

* @param person

*/

public void add(Person person){

SQLiteDatabase db = helper.getWritableDatabase();

db.execSQL("insert into person(name,phone,amount) values(?,?,?) ",

new Object[]{person.getName(),person.getPhone(),person.getAmount()});

}

/**

* 删除记录

* @param integer 将要删除的记录的ID号

*/

public void delete(Integer integer){

SQLiteDatabase db = helper.getWritableDatabase();

db.execSQL("delete from person where id = ?",new Object[]{integer});

}

/**

* 更新记录

* @param person 更新的记录

*/

public void update(Person person){

SQLiteDatabase db = helper.getWritableDatabase();

db.execSQL("update person set name=?, phone=?, amount=? where id = ?",

new Object[]{person.getName(),person.getPhone(),person.getAmount(),person.getId()});

}

/**

* 查找记录

* @param integer

* @return

*/

public Person find(Integer integer){

Person person = null;

SQLiteDatabase db = helper.getWritableDatabase();

Cursor cursor = db.rawQuery("select * from person where id = ?",

new String[]{integer.toString()});

if(cursor.moveToFirst()){

int id = cursor.getInt(cursor.getColumnIndex("id"));

String name = cursor.getString(cursor.getColumnIndex("name"));

String phone = cursor.getString(cursor.getColumnIndex("phone"));

int amount = cursor.getInt(cursor.getColumnIndex("amount"));

person = new Person(name,id,phone,amount);

}

return person;

}

/**

* 分页显示记录

* @param start 开始记录号

* @param length 记录长度

* @return

*/

public List getPersons(Integer start, Integer length){

List persons = new ArrayList();

Person person = null;

SQLiteDatabase db = helper.getWritableDatabase();

Cursor cursor = db.rawQuery("select * from person order by id limit ?, ?",

new String[]{start.toString(),length.toString()});

while(cursor.moveToNext()){

int id = cursor.getInt(cursor.getColumnIndex("id"));

String name = cursor.getString(cursor.getColumnIndex("name"));

String phone = cursor.getString(cursor.getColumnIndex("phone"));

int amount = cursor.getInt(cursor.getColumnIndex("amount"));

person = new Person(name,id,phone,amount);

persons.add(person);

person = null;

}

cursor.close();

return persons;

}

/**

* 得到记录数

* @return

*/

public Integer getCounts(){

SQLiteDatabase db = helper.getWritableDatabase();

Cursor cursor = db.rawQuery("select count(*) from person",null);

cursor.moveToFirst();

Integer counts = cursor.getInt(0);

return counts;

}

}

单元测试TestService.java源码:

package com.sinaapp.test;

import java.util.List;

import android.test.AndroidTestCase;

import android.util.Log;

import com.sinaapp.domain.Person;

import com.sinaapp.service.DBOpenHelper;

import com.sinaapp.service.PersonService;

public class TestService extends AndroidTestCase {

public void testCreateDB() {

DBOpenHelper helper = new DBOpenHelper(this.getContext());

helper.getWritableDatabase();

}

public void testAdd(){

PersonService service = new PersonService(this.getContext());

service.add(new Person("luolin","12345",100));

}

public void testUpdate(){

PersonService service = new PersonService(this.getContext());

service.update(new Person("zhang",4,"2222222",200));

}

public void testFind(){

PersonService service = new PersonService(this.getContext());

Person person = service.find(1);

Log.i("TestService", person.toString());

}

public void testDel(){

PersonService service = new PersonService(this.getContext());

service.delete(2);

}

public void testGetCounts(){

PersonService service = new PersonService(this.getContext());

Integer i = service.getCounts();

Log.i("TestService", i.toString());

}

public void testGetPersons(){

PersonService service = new PersonService(this.getContext());

List persons = service.getPersons(0, 4);

for(Person p : persons){

Log.i("TestService", p.toString());

}

}

public void testPayment(){

PersonService service = new PersonService(this.getContext());

service.payment();

}

}

AndroidManifest.xml

package="com.sinaapp.sql"

android:versionCode="1"

android:versionName="1.0" >

android:icon="@drawable/ic_launcher"

android:label="@string/app_name" >

android:name=".SQLiteActivity"

android:label="@string/app_name" >

android:targetPackage="com.sinaapp.sql" />

安卓视频开发 mysql_在Android应用中使用SQLite数据库(传智播客视频笔记)相关推荐

  1. 2013传智播客视频--.ppt,.pptx,.doc,.docx.目录

    \!2013-04-15 JQ03-JQ事件动画\4.1版JS+JQ PPT\00JsDom编程01_邹华栋.docx; \!2013-04-15 JQ03-JQ事件动画\4.1版JS+JQ PPT\ ...

  2. 《2013传智播客视频》-wmv,avi,mp4.目录

    \!2013-03-14俄罗斯方块\视频\01.复习.avi; \!2013-03-14俄罗斯方块\视频\02 复习.avi; \!2013-03-14俄罗斯方块\视频\03 形状旋转.avi; \! ...

  3. 在Android应用中使用Pull解析XML文件(传智播客视频笔记)

    Service.java源码: package com.sinaapp.ssun.service; import java.io.InputStream; import java.io.OutputS ...

  4. Java中System类(传智播客毕老师视频讲解)

    System:类中的方法和属性都是静态的. out:标准输出,默认是控制台. in:标准输入,默认是键盘. 描述系统一些信息. 获取系统属性信息:Properties getProperties(); ...

  5. Java中时间获取(传智播客毕老师视频讲解)

    1.Date类 Date类中大多方法已经过时,且其打印的时间看不懂,可以调用DateFormat接口中的实现子类SimpleDateFormat进行格式调整: 代码如下: import java.ut ...

  6. Java中静态导入(传智播客毕老师视频讲解)

    StaticImport  静态导入. 当类名重名时,需要指定具体的包名. 当方法重名是,指定具备所属的对象或者类. import java.util.*; import static java.ut ...

  7. 传智播客视频39期 36期 达内2016年前端开发视频

    链接:https://pan.baidu.com/s/1CBAPHuVvrak56eK9RBtsjw  提取码:29vm  复制这段内容后打开百度网盘手机App,操作更方便哦

  8. DBUtils学习记录(传智播客视频)

    为了简化JDBC开发,采用Apache组织的一个工具类DBUtils. DBUtils三个核心功能: a.QueryRunner中提供对sql语句操作的API b.ResultSetHandler接口 ...

  9. 传智播客视频学习 ---- 字符串含义( C 语言中)

    C 语言中字符串的含义: C语言的字符串是以 '\0' 结尾的字符串 C语言中没有字符串的类型,是用字符数组来模拟字符串的 字符串的内存分配可以是 堆上 栈上 全局区上 字符串数组 其实就是一个指针, ...

最新文章

  1. 示波器到底选择多大的带宽合适
  2. 给Ocelot做一个Docker 镜像
  3. Linux 进程间通讯详解五
  4. word无法打开请去应用商店_word文档打不开的4种解决方法
  5. 计算机导论的重点,计算机导论重点题目精华版
  6. android view 镜像,Android 实现镜像效果
  7. 【每日SQL打卡】​​​​​​​​​​​​​​​DAY 5丨员工奖金【难度简单】
  8. java基础第九天_多线程、自动拆装箱
  9. Firefox上打开的标签页太多怎么办?
  10. python代码怎么变成软件_python程序变成软件的实操方法
  11. 【工具推荐】之桌面软件
  12. Java题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
  13. Python实现音频文件格式转化
  14. python读取raw数据文件_pythonrawkit如何从原始文件读取元数据值?
  15. animation之二,使用xml控制animat…
  16. 使用Travis CI进行在线build
  17. android recyclerView上item的EditextView焦点乱跑和数据混乱
  18. PreTranslateMessage(MSG* pMsg)专题
  19. 树模型知识点(1)——决策树
  20. 【使用python和flask建个人博客】给个人博客增加了清单分类及计时功能,可以很方便的做时间记录,目标是为了能够跟柳比歇夫学习

热门文章

  1. python银行自动取款机系统详写
  2. Matlab底层算法实现图像水平镜像
  3. Hive in exists 区别
  4. 计算机的益处和坏处 英语作文,网络的好处和坏处英语作文带翻译
  5. 达州职业技术学院计算机专业,达州计算机职业技术学院2020年招生计划
  6. CSP 2022 复赛游记
  7. 电脑风扇声音大怎么办
  8. Python学习之四大名著人物出场次数Python代码
  9. modelsim打开和生成VCD文件的方法
  10. 【HTML-5】小米耳机产品模块