Android数据存储——sqlite方式一

添加测试工程:



数据库创建:

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());
	}
	
	
	
	
	
	
	

}


你可能感兴趣的:(Android数据存储——sqlite方式一)