十一、OtherPersonService.java 业务类源码:
package com.example.service;
import java.util.ArrayList;
import java.util.List;
import com.example.domain.Person;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
public class OtherPersonService {
private DBOperateHelper dbOperateHelper;
public OtherPersonService(Context context) {
this.dbOperateHelper = new DBOperateHelper(context);
}
/**
* 保存记录
* @param person
*/
public void save(Person person){
//得到数据库实例,里面封装了数据库操作方法
SQLiteDatabase sqldb = dbOperateHelper.getWritableDatabase();
//sqldb.execSQL("insert into person(name,phone) values('"+person.getName()+"','"+person.getPhone()+"')");
//利用占位符可以避免注入,但是注意数组参与与占位符对应的字段要一一对应
//sqldb.execSQL("insert into person(name,phone) values(?,?)",new Object[]{person.getName(),person.getPhone()});
ContentValues values = new ContentValues();
values.put("name", person.getName());
values.put("phone", person.getPhone());
values.put("amount", person.getAmount());
//第一个参数是表名,第三个为字段值集合,第二个参数是空值字段,当第三个字段值集合为空时,系统会自动插入一条第二个参数为空的sql语句
//否则当第三个参数为空时,如果第二个参数也为空,那么插入表就会找不到插入的字段信息,会报错
sqldb.insert("person", "name", values );
//关闭数据库
sqldb.close();
}
/**
* 删除记录
* @param id
*/
public void delete(Integer id){
SQLiteDatabase sqldb = dbOperateHelper.getWritableDatabase();
//sqldb.execSQL("delete from person where personid=?",new Object[]{id});
//第一个参数是表名,第二个是where后面的条件用占位符表示,第三个对应占位符为参数值
sqldb.delete("person", "personid=?", new String[]{Integer.toString(id)});
sqldb.close();
}
/**
* 更新记录
* @param person
*/
public void update(Person person){
SQLiteDatabase sqldb = dbOperateHelper.getWritableDatabase();
//sqldb.execSQL("update person set name=?,phone=? where personid=?",new Object[]{person.getName(),person.getPhone(),person.getId()});
//第一个参数为表名,第二个是一个更新值集合,采用键值对的形式,每个更新的字段对应更新值
//第三个参数是where后面条件字段用占位符标识,第四个参数是对应where占位符的值
ContentValues values = new ContentValues();
values.put("name", person.getName());
values.put("phone", person.getPhone());
values.put("amount", person.getAmount());
sqldb.update("person", values , "personid=?", new String[]{person.getId().toString()});
sqldb.close();
}
/**
* 通过ID查询记录
* @param id
* @return
*/
public Person find(Integer id){
/**
* getWritableDatabase 与 getReadableDatabase 的区别:
* getReadableDatabase会先返回getWritableDatabase(可写),如果调用getWritableDatabase失败
* 则才会调用getReadableDatabase后续方法,使数据库只读
* 当写入的数据超过数据库大小则调用getWritableDatabase会失败
* 所以只读时则可以使用此方法,其它情况(只要不是超过数据库大小)也可以使用此方法
*/
SQLiteDatabase sqldb = dbOperateHelper.getReadableDatabase();
//Cursor cursor = sqldb.rawQuery("select * from person where personid=?", new String[]{String.valueOf(id)});
//第一个参数是表名;第二个参数是查询显示的字段,null时默认查询显示所有字段;
//第三个参数是where查询条件占位符;第四个是占位符对应的值;
//第五个参数是group by条件;第六个是having条件;第七个是order by条件
Cursor cursor = sqldb.query("person", null, "personid=?", new String[]{id.toString()}, null, null, null);
int personid;
String name;
String phone;
int amount;
Person person = null;
if(cursor.moveToFirst()){
personid = cursor.getInt(cursor.getColumnIndex("personid"));
name = cursor.getString(cursor.getColumnIndex("name"));
phone = cursor.getString(cursor.getColumnIndex("phone"));
amount = cursor.getInt(cursor.getColumnIndex("amount"));
person = new Person(personid,name,phone,amount);
}
cursor.close();
return person;
}
/**
* 返回指定长度记录,limit 3,5,适用于分页
* @param offset 起始
* @param maxResult 长度
* @return
*/
public List<Person> getScrollData(int offset,int maxResult){
SQLiteDatabase sqldb = dbOperateHelper.getReadableDatabase();
//Cursor cursor = sqldb.rawQuery("select * from person order by personid asc limit ?,?", new String[]{String.valueOf(offset),String.valueOf(maxResult)});
//第一个参数是表名;第二个参数是查询显示的字段,null时默认查询显示所有字段;
//第三个参数是where查询条件占位符;第四个是占位符对应的值;
//第五个参数是group by条件;第六个是having条件;第七个是order by条件
//第八个参数是limit ?,? 条件
Cursor cursor = sqldb.query("person", null, null, null, null, null, "personid",offset+","+maxResult);
int personid;
String name;
String phone;
int amount;
Person person = null;
List<Person> persons = new ArrayList<Person>();
while(cursor.moveToNext()){
personid = cursor.getInt(cursor.getColumnIndex("personid"));
name = cursor.getString(cursor.getColumnIndex("name"));
phone = cursor.getString(cursor.getColumnIndex("phone"));
amount = cursor.getInt(cursor.getColumnIndex("amount"));
person = new Person(personid,name,phone,amount);
persons.add(person);
}
cursor.close();
return persons;
}
/**
* 返回总记录数
* @return
*/
public long getCount(){
SQLiteDatabase sqldb = dbOperateHelper.getReadableDatabase();
//Cursor cursor = sqldb.rawQuery("select count(*) from person", null);
//第一个参数是表名;第二个参数是查询显示的字段,null时默认查询显示所有字段;
//第三个参数是where查询条件占位符;第四个是占位符对应的值;
//第五个参数是group by条件;第六个是having条件;第七个是order by条件
Cursor cursor = sqldb.query("person", new String[]{"count(*)"}, null, null, null, null, null);
//该查询语句值返回一条语句
cursor.moveToFirst();
long result = cursor.getLong(0);
cursor.close();
return result;
}
}










