添加测试工程:
数据库创建:
package com.example.yabushanandroid.service;
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 static String name = "mydb.db";// 数据库名
private static int version = 1;// 数据库版本
public DbOpenHelper(Context context) {
super(context, name, null, version);
}
@Override
public void onCreate(SQLiteDatabase db) {
// 变量的数据类型:整形数据,字符串类型,日期类型,二进制的数据类型
String sqlString = "create table person(id integer primary key autoincrenent,"
+ "name varchar(64),address varchar(64))";
db.execSQL(sqlString);
}
/**
* 数据库属性的新增、修改
*/
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// 当数据库版本升级时,即比 version值大时,不会执行onCreate方法,会执行此方法
String upsql = "alter table person add sec varchar(8)";
db.execSQL(upsql);
}
}
数据库接口操作:
package com.example.yabushanandroid.service;
import java.util.List;
import java.util.Map;
import android.R.string;
public interface dbService {
public boolean addPerson(Object[] params);
public boolean deletePerson(Object[] params);
public boolean updatePerson(Object[] params);
public Map<String,String> ViewPerson(String[] selectionArgs);
public List<Map<String, String>> listViewMaps(String[] selectionArgs);
}
数据库接口实现:
package com.example.yabushanandroid.service;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.R.string;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
public class dbServiceImpl implements dbService {
private DbOpenHelper helper=null;
public dbServiceImpl(Context context) {
helper = new DbOpenHelper(context);
}
@Override
public boolean addPerson(Object[] params) {
boolean flag=false;
SQLiteDatabase database=null;
try {
String sqlString="insert into person(name,address) values(?,?)";
database=helper.getWritableDatabase();//实现对数据库的操作
database.execSQL(sqlString, params);
flag=true;
} catch (Exception e) {
}finally{
if(database!=null){
database.close();
}
}
return flag;
}
@Override
public boolean deletePerson(Object[] params) {
boolean flag=false;
SQLiteDatabase database=null;
try {
String sql="delete from person where id=?";
database=helper.getWritableDatabase();
database.execSQL(sql,params);
flag=true;
} catch (Exception e) {
}finally{
database.close();
}
return flag;
}
@Override
public boolean updatePerson(Object[] params) {
boolean flag=false;
SQLiteDatabase database=null;
try {
String sql="update person set name = ?,address = ? where id=?";
database.execSQL(sql,params);
flag=true;
} catch (Exception e) {
}finally{
database.close();
}
return flag;
}
@Override
public Map<String, String> ViewPerson(String[] selectionArgs) {
Map<String, String> map=new HashMap<String, String>();
SQLiteDatabase database=null;
try {
String sqlString="select * from person where id = ? ";
database=helper.getReadableDatabase();
Cursor cursor=database.rawQuery(sqlString, selectionArgs);
//获取数据库的列的个数
int colums=cursor.getColumnCount();
while(cursor.moveToNext()){
for(int i=0;i<colums;i++){
String cols_name=cursor.getColumnName(i);
String cols_value=cursor.getString(cursor.getColumnIndex(cols_name));
if(cols_value==null){
cols_value="";
}
map.put(cols_name, cols_value);
}
}
} catch (Exception e) {
// TODO: handle exception
}finally{
if(database!=null){
database.close();
}
}
return map;
}
@Override
public List<Map<String, String>> listViewMaps(String[] selectionArgs) {
List<Map<String, String>> list=new ArrayList<Map<String,String>>();
String sqlString="select * from person ";
SQLiteDatabase database=null;
try {
database=helper.getReadableDatabase();
Cursor cursor=database.rawQuery(sqlString, selectionArgs);
int colums=cursor.getColumnCount();
while(cursor.moveToNext()){
Map<String, String> map=new HashMap<String, String>();
for(int i=0;i<colums;i++){
String cols_name=cursor.getColumnName(i);
String cols_value=cursor.getString(cursor.getColumnIndex(cols_name));
if(cols_value==null){
cols_value="";
}
map.put(cols_name, cols_value);
}
list.add(map);
}
} catch (Exception e) {
// TODO: handle exception
}finally{
if(database!=null){
database.close();
}
}
return null;
}
}
测试:
package com.example.yabushanandroid.service;
import java.util.List;
import java.util.Map;
import android.test.AndroidTestCase;
import android.util.Log;
public class dbTest extends AndroidTestCase{
public dbTest() {
// TODO Auto-generated constructor stub
}
public void createDb(){
DbOpenHelper dbOpenHelper=new DbOpenHelper(getContext());
//当调用 以下两个方法中的一个方法时,数据库才会创建
dbOpenHelper.getReadableDatabase();
//dbOpenHelper.getWritableDatabase();
}
/**
* 新增
*/
public void insertDB(){
dbService service=new dbServiceImpl(getContext());
Object[] params={"张三","背景"};
boolean flag=service.addPerson(params);
System.out.println(flag);
}
/**
* 删除
*/
public void deleteDB(){
dbService service=new dbServiceImpl(getContext());
Object[] params={1};
boolean flag=service.deletePerson(params);
System.out.println(">>>"+flag);
}
/**
* 修改
*/
public void updateDB(){
dbService service=new dbServiceImpl(getContext());
Object[] params={"王五","上海","1"};
service.updatePerson(params);
}
/**
* 单条查询
*/
public void ViewDB(){
dbService service=new dbServiceImpl(getContext());
String[] selectionArgs = {"1"};
Map<String, String> map = service.ViewPerson(selectionArgs);
Log.i("TEST", "--->>>"+map.toString());
}
/**
* 多条查询
*/
public void ListDB(){
dbService service=new dbServiceImpl(getContext());
List<Map<String, String>> list=service.listViewMaps(null);
Log.i("TEST", "--->>>"+list.toString());
}
}