package com.example.db.dao;
import java.util.ArrayList;
import java.util.List;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import com.example.db.PersonSQLiteOpenHelper;
import com.example.db.domain.Person;
public class PersonDao {
//获取dbhelper实例
private PersonSQLiteOpenHelper helper;
// 在构造方法里面完成 helper的初始化
public PersonDao(Context context)
{
helper = new PersonSQLiteOpenHelper(context);
}
/**
* 添加一条记录 ,拿到数据库的第一时间需要把数据库关闭掉
* @param name 姓名
* @param number 电话
*/
public void add(String name,String number){
SQLiteDatabase db = helper.getWritableDatabase();
String sql ="这里是添加的sql语句 values(?,?) ";
//bindArgs 则是一个数组 放添加的值
Object[] bindArgs ={name,number};
db.execSQL(sql, bindArgs);
db.close();
}
/**
* 通过调用系统api 添加一条记录 ,拿到数据库的第一时间需要把数据库关闭掉
* @param name 姓名
* @param number 电话
*/
public long adds(String name,String number){
SQLiteDatabase db = helper.getWritableDatabase();
/**
* table 表名
* nullColumnHack 是否允许数据为空
* values ConteatValues map 集合
*/
ContentValues values = new ContentValues();
values.put("name", name);
values.put("number", number);
long id = db.insert("sys_user", null, values);
db.close();
return id;
}
/**
* 根据用户名查找信息。查询用getReadableDatabase() 通过 rawQuery()去查询 返回 Cursor 游标
* @param name 姓名
* @return true 存在 false 不存在
*/
public boolean find(String name){
SQLiteDatabase db = helper.getReadableDatabase();
String sql ="这里是查询的sql语句 name=? ";
//bindArgs 则是一个数组 放添加的值
String[] selectionArgs ={name};
Cursor cursor = db.rawQuery(sql, selectionArgs);
// cursor.moveToNext() 让结果集移动下一行如果移动成功 说明return true,不成功就return false
boolean result = cursor.moveToNext();
//游标也需要释放
cursor.close();
db.close();
return result;
}
/**
* 修改一条记录
* @param name 用户名
* @param newnumber 用户手机号码
*/
public void update (String name,String newnumber)
{
SQLiteDatabase db = helper.getWritableDatabase();
String sql ="这里是修改的sql语句 set number=? where name=? ";
//bindArgs 则是一个数组 放添加的值
Object[] bindArgs ={name,newnumber};
db.execSQL(sql, bindArgs);
db.close();
}
/**
* 通过系统api修改一条记录
* @param name 用户名
* @param newnumber 用户手机号码
*/
public int updates (String name,String newnumber)
{
SQLiteDatabase db = helper.getWritableDatabase();
/**
* table 表名
* values ContentValues map 集合
* whereClause 选择条件
* whereArgs 站位符
*/
ContentValues values = new ContentValues();
values.put("newnumber", newnumber);
//返回的值大于零 语句执行成功
int num = db.update("sys_user", values, "name =?", new String[] {name}) ;
db.close();
return num;
}
/**
* 删除一条语句
* @param name 用户名
*/
public void delete (String name){
SQLiteDatabase db = helper.getWritableDatabase();
String sql ="这里是删除的sql语句 name=? ";
//bindArgs 则是一个数组 放添加的值
Object[] bindArgs ={name};
db.execSQL(sql, bindArgs);
db.close();
}
/**
* 通过系统api删除一条语句
* @param name 用户名
*/
public int delets (String name){
SQLiteDatabase db = helper.getWritableDatabase();
/**
* table 表名
* whereClause 条件
* whereArgs 占位符
*/
//返回的值大于零 语句执行成功
int num = db.delete("sys_user", "name = ?", new String[]{name});
db.close();
return num;
}
/**
* 返回全部数据信息
* @return
*/
public List<Person> findAll()
{
SQLiteDatabase db = helper.getReadableDatabase();
List<Person> persons = new ArrayList<Person>();
String sql ="查询全部 select * from sys_user";
//如果没有参数可以写null
String[] selectionArgs ={null};
Cursor cursor = db.rawQuery(sql, selectionArgs);
while(cursor.moveToNext()){
int id = cursor.getInt(cursor.getColumnIndex("id"));
String name = cursor.getString(cursor.getColumnIndex("name"));
String number =cursor.getString(cursor.getColumnIndex("number"));
Person p = new Person(id,name,number);
persons.add(p);
}
cursor.close();
db.close();
return persons;
}
/**
* 通过系统api返回全部数据信息
* @return
*/
public List<Person> findAlls(){
SQLiteDatabase db = helper.getReadableDatabase();
List<Person> persons = new ArrayList<Person>();
/**
* table 表名
* columns 返回具体列名
* selection 选择条件
* selectionArgs 选择参数
* groupBy, having, orderBy 有就写 没有写null
*
*/
Cursor cursor = db.query("sys_user", new String[]{"id","name","number"}, null, null, null, null, null);
while(cursor.moveToNext()){
int id = cursor.getInt(cursor.getColumnIndex("id"));
String name = cursor.getString(cursor.getColumnIndex("name"));
String number =cursor.getString(cursor.getColumnIndex("number"));
Person p = new Person(id,name,number);
persons.add(p);
}
cursor.close();
db.close();
return persons;
}
}