安卓视频开发 mysql_在Android应用中使用SQLite数据库(传智播客视频笔记)
在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数据库(传智播客视频笔记)相关推荐
- 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\ ...
- 《2013传智播客视频》-wmv,avi,mp4.目录
\!2013-03-14俄罗斯方块\视频\01.复习.avi; \!2013-03-14俄罗斯方块\视频\02 复习.avi; \!2013-03-14俄罗斯方块\视频\03 形状旋转.avi; \! ...
- 在Android应用中使用Pull解析XML文件(传智播客视频笔记)
Service.java源码: package com.sinaapp.ssun.service; import java.io.InputStream; import java.io.OutputS ...
- Java中System类(传智播客毕老师视频讲解)
System:类中的方法和属性都是静态的. out:标准输出,默认是控制台. in:标准输入,默认是键盘. 描述系统一些信息. 获取系统属性信息:Properties getProperties(); ...
- Java中时间获取(传智播客毕老师视频讲解)
1.Date类 Date类中大多方法已经过时,且其打印的时间看不懂,可以调用DateFormat接口中的实现子类SimpleDateFormat进行格式调整: 代码如下: import java.ut ...
- Java中静态导入(传智播客毕老师视频讲解)
StaticImport 静态导入. 当类名重名时,需要指定具体的包名. 当方法重名是,指定具备所属的对象或者类. import java.util.*; import static java.ut ...
- 传智播客视频39期 36期 达内2016年前端开发视频
链接:https://pan.baidu.com/s/1CBAPHuVvrak56eK9RBtsjw 提取码:29vm 复制这段内容后打开百度网盘手机App,操作更方便哦
- DBUtils学习记录(传智播客视频)
为了简化JDBC开发,采用Apache组织的一个工具类DBUtils. DBUtils三个核心功能: a.QueryRunner中提供对sql语句操作的API b.ResultSetHandler接口 ...
- 传智播客视频学习 ---- 字符串含义( C 语言中)
C 语言中字符串的含义: C语言的字符串是以 '\0' 结尾的字符串 C语言中没有字符串的类型,是用字符数组来模拟字符串的 字符串的内存分配可以是 堆上 栈上 全局区上 字符串数组 其实就是一个指针, ...
最新文章
- 示波器到底选择多大的带宽合适
- 给Ocelot做一个Docker 镜像
- Linux 进程间通讯详解五
- word无法打开请去应用商店_word文档打不开的4种解决方法
- 计算机导论的重点,计算机导论重点题目精华版
- android view 镜像,Android 实现镜像效果
- 【每日SQL打卡】​​​​​​​​​​​​​​​DAY 5丨员工奖金【难度简单】
- java基础第九天_多线程、自动拆装箱
- Firefox上打开的标签页太多怎么办?
- python代码怎么变成软件_python程序变成软件的实操方法
- 【工具推荐】之桌面软件
- Java题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
- Python实现音频文件格式转化
- python读取raw数据文件_pythonrawkit如何从原始文件读取元数据值?
- animation之二,使用xml控制animat…
- 使用Travis CI进行在线build
- android recyclerView上item的EditextView焦点乱跑和数据混乱
- PreTranslateMessage(MSG* pMsg)专题
- 树模型知识点(1)——决策树
- 【使用python和flask建个人博客】给个人博客增加了清单分类及计时功能,可以很方便的做时间记录,目标是为了能够跟柳比歇夫学习