ConfigDBHelp

/**  
 * @Project: SQLiteDemo
 * @Title: ConfigDBHelp.java
 * @Package com.lilin.sqlite.db
 * @Description: do config table
 * @author lilin [email protected]
 * @date 2012-3-22 下午09:18:56
 * @Copyright: . All rights reserved.
 * @version V1.0  
 */

package com.lilin.sqlite.db;

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.lilin.sqlite.R;
import com.lilin.sqlite.model.Config;
import com.lilin.util.LogHelp;

//表名:config
public class ConfigDBHelp {

	private static final String TABLENAME = "config";

	// 参数2 空列的默认值
	// 参数3 ContentValues类型的一个封装了列名称和列值的Map;
	public static void insert(Context con, String key, String value) {
		DBOpenHelp dbhelper = new DBOpenHelp(con, con
				.getString(R.string.db_name));
		SQLiteDatabase db = dbhelper.getWritableDatabase();
		ContentValues cValue = new ContentValues();// 实例化常量值
		cValue.put("key", key);// 添加用户名
		cValue.put("value", value);
		db.insert(TABLENAME, null, cValue); // 调用insert()方法插入数据
		DBHelp.close(dbhelper, db, null);
	}

	// 通过SQL语句插入
	public static void insertSQL(Context con, String key, String value) {
		DBOpenHelp dbhelper = new DBOpenHelp(con, con
				.getString(R.string.db_name));
		SQLiteDatabase db = dbhelper.getWritableDatabase();
		try {
			String delSQL = "delete from config where key = '" + key + "'";
			db.execSQL(delSQL);
		} catch (Exception e) {
			e.printStackTrace();
			LogHelp.Log2SDErr(e, con.getString(R.string.logpath), con
					.getString(R.string.app_name));
		}
		// 方法一:
		String str[] = new String[] { key, value };
		db.execSQL("insert into config values(?,?)", str);
		// 方法二:
		// String insertSQL = "insert into config(key,value) values('" + key
		// + "','" + value + "')";
		// db.execSQL(insertSQL);
		DBHelp.close(dbhelper, db, null);
	}

	// update(String table,ContentValues values,String whereClause, String[])
	// whereArgs)
	// 参数1 表名称
	// 参数2 跟行列ContentValues类型的键值对Key-Value
	// 参数3 更新条件(where字句)
	// 参数4 更新条件数组
	public static void update(Context con, String value, String key) {
		DBOpenHelp dbhelper = new DBOpenHelp(con, con
				.getString(R.string.db_name));
		SQLiteDatabase db = dbhelper.getReadableDatabase();
		ContentValues values = new ContentValues();
		values.put("value", value);// 参数2 跟行列ContentValues类型的键值对Key-Value
		String whereClause = "key=?";
		String[] whereArgs = { key };
		db.update("usertable", values, whereClause, whereArgs);
		DBHelp.close(dbhelper, db, null);
	}

	public static void updateSQL(Context con, String value, String key) {
		DBOpenHelp dbhelper = new DBOpenHelp(con, con
				.getString(R.string.db_name));
		SQLiteDatabase db = dbhelper.getReadableDatabase();
		String updateSQL = "update config set value='" + value
				+ "' where key='" + key + "'";
		db.execSQL(updateSQL);
		DBHelp.close(dbhelper, db, null);
	}

	// delete(String table,String whereClause,String[] whereArgs)
	// 参数1 表名称
	// 参数2 删除条件
	// 参数3 删除条件值数组
	public static void delete(Context con, String key) {
		DBOpenHelp dbhelper = new DBOpenHelp(con, con
				.getString(R.string.db_name));
		SQLiteDatabase db = dbhelper.getReadableDatabase();
		String whereClause = "key=?";// 删除条件
		String[] whereArgs = { key }; // 删除条件参数
		db.delete(TABLENAME, whereClause, whereArgs);// 执行删除
		DBHelp.close(dbhelper, db, null);
	}

	public static void deleteSQL(Context con, String key) {
		DBOpenHelp dbhelper = new DBOpenHelp(con, con
				.getString(R.string.db_name));
		SQLiteDatabase db = dbhelper.getReadableDatabase();
		String delSQL = "delete from config where key = '" + key + "'";
		db.execSQL(delSQL);
		DBHelp.close(dbhelper, db, null);
	}

	// 根据key获得对应的Value
	public static String getValueByKey(Context con, String key) {
		DBOpenHelp dbhelper = new DBOpenHelp(con, con
				.getString(R.string.db_name));
		SQLiteDatabase db = dbhelper.getReadableDatabase();
		Cursor cursor = db.rawQuery("select value from config where key='"
				+ key + "'", null);
		String value = "";
		while (cursor.moveToNext()) {
			value = cursor.getString(0);
		}
		DBHelp.close(dbhelper, db, null);
		return value;
	}

	// 在Android中查询数据是通过Cursor类来实现的,当我们使用SQLiteDatabase.query()方法时,会得到一个Cursor对象,Cursor指向的就是每一条数据。它提供了很多有关查询的方法,具体方法如下:
	// public Cursor query(String table,String[] columns,String
	// selection,String[] selectionArgs,String groupBy,String having,String
	// orderBy,String limit);
	// 各个参数的意义说明:
	// 参数table:表名称
	// 参数columns:列名称数组
	// 参数selection:条件字句,相当于where
	// 参数selectionArgs:条件字句,参数数组
	// 参数groupBy:分组列
	// 参数having:分组条件
	// 参数orderBy:排序列
	// 参数limit:分页查询限制
	// 参数Cursor:返回值,相当于结果集ResultSet
	// Cursor是一个游标接口,提供了遍历查询结果的方法,如移动指针方法move(),获得列值方法getString()等.
	// Cursor游标常用方法
	// getCount() // 获得总的数据项数
	// isFirst() // 判断是否第一条记录
	// isLast() // 判断是否最后一条记录
	// moveToFirst() // 移动到第一条记录
	// moveToLast() // 移动到最后一条记录
	// move(int offset) // 移动到指定记录
	// moveToNext()// 移动到下一条记录
	// moveToPrevious() // 移动到上一条记录
	// getColumnIndexOrThrow(String columnName) // 根据列名称获得列索引
	// getInt(int columnIndex) // 获得指定列索引的int类型值
	// getString(int columnIndex)// 获得指定列缩影的String类型值

	public static List<Config> query(Context con) {
		DBOpenHelp dbhelper = new DBOpenHelp(con, con
				.getString(R.string.db_name));
		SQLiteDatabase db = dbhelper.getReadableDatabase();

		String columns[] = null;// 参数columns:列名称数组
		String selection = "";// 参数selection:条件字句:"ROWGUID=?"
		String selectionArgs[] = null;// 参数selectionArgs:条件字句,参数数组
		String groupBy = null;// 参数groupBy:分组列
		String having = null;// 参数having:分组条件
		String orderBy = null;// 参数orderBy:排序列
		// 参数limit:分页查询限制
		Cursor cursor = db.query(TABLENAME, columns, selection, selectionArgs,
				groupBy, having, orderBy);// 查询获得游标
		List<Config> list = new ArrayList<Config>();
		if (cursor.moveToFirst()) {// 判断游标是否为空
			// 遍历游标
			for (int i = 0; i < cursor.getCount(); i++) {
				cursor.move(i);
				Config mdate = new Config();
				mdate.setKey(cursor.getString(0).toString());
				mdate.setValue(cursor.getString(1).toString());
				list.add(mdate);
			}
		}
		DBHelp.close(dbhelper, db, cursor);
		return list;
	}

}
 

相关推荐