package com.metoo.girls;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;

/**
 * @author wbhuang
 * @time 20130912
 * @description 数据库操作封装
 */
public class GirlsDbHelper {
	private static String TAG = "GirlsDbHelper";
	private static GirlsDbHelper girlsDbHelper = null;
	private static DatabaseHelper dbHelper;
	private static SQLiteDatabase db;
	private static final String GRILS_DB_NAME = "girls.db";
	private static final int GIRLS_DB_VERSION = 1;
	private Context context;

	private GirlsDbHelper(Context c) {
		context = c;
	}

	private static class DatabaseHelper extends SQLiteOpenHelper {
		public DatabaseHelper(Context c) {
			super(c, GRILS_DB_NAME, null, GIRLS_DB_VERSION);
		}

		@Override
		public void onCreate(SQLiteDatabase arg0) {
		}

		@Override
		public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
		}
	} 

	public static GirlsDbHelper getInstance(Context c) {
		if (null == girlsDbHelper) {
			girlsDbHelper = new GirlsDbHelper(c);
		}
		return girlsDbHelper;
	}

	/**
	 * 打开数据库
	 */
	public void open() {
		Log.v(TAG, "open");
		dbHelper = new DatabaseHelper(context);
		db = dbHelper.getWritableDatabase();
	}

	/**
	 * 关闭数据库
	 */
	public void close() {
		Log.v(TAG, "close");
		db.close();
		dbHelper.close();
	}

	/**
	 * 插入数据
	 * @param tblName 表名
	 * @param values 要插入的列对应值
	 * @return
	 */
	public long insert(String tblName, ContentValues values) {
		return db.insert(tblName, null, values);
	}

	/**
	 * 删除数据
	 * @param tblName 表名
	 * @param deleteCondition 删除条件
	 * @param deleteArgs 如果deleteCondition中有"?"号,将用次数组替换
	 * @return
	 */
	public long delete(String tblName, String deleteCondition, String[] deleteArgs) {
		return db.delete(tblName, deleteCondition, deleteArgs);
	}

	/**
	 * 更新数据
	 * @param tblName 表名
	 * @param values 要更新的列
	 * @param selection 更新的条件
	 * @param selectArgs 如果selection中有"?"将由此数组中的值替换
	 * @return
	 */
	public long update(String tblName, ContentValues values, String selection, String[] selectArgs) {
		return db.update(tblName, values, selection, selectArgs);
	}

	/**
	 * 查询多行数据
	 * @param tblName 表名
	 * @param columns 查询的列
	 * @param selection 查询条件
	 * @param selectionArgs 如果selection中有"?"将由此数组中的值替换
	 * @return
	 */
	public Cursor queryList(String tblName, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy) {
		return db.query(tblName, columns, selection, selectionArgs, groupBy, having, orderBy);
	}

	/**
	 * 查询单行数据
	 * @param tblName 表名
	 * @param columns 查询的列
	 * @param selection 查询条件
	 * @param selectionArgs 如果selection中有"?"将由此数组中的值替换
	 * @return
	 */
	public Cursor queryOne(String tblName, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy) {
		Cursor cursor = db.query(tblName, columns, selection, selectionArgs, groupBy, having, orderBy);
		if (cursor != null) {
			cursor.moveToFirst();
		}
		return cursor;
	}

	/**
	 * 执行SQL语句
	 * @param sql
	 */
	public void execSQL(String sql){
		db.execSQL(sql);
	}  

	/**
	 * 判断表是否存在
	 * @param tableName
	 * @return
	 */
	public boolean isTableExist(String tableName){
		boolean result = false;
		if(tableName == null){
			return false;
		}
		try {
			Cursor cursor = null;
			String sql = "select count(1) as c from sqlite_master where type ='table' and name ='"+tableName.trim()+"' ";
			cursor = db.rawQuery(sql, null);
			if(cursor.moveToNext()){
				int count = cursor.getInt(0);
				if(count > 0){
					result = true;
				}
			}
			cursor.close();
		} catch (Exception e) {
			Log.e(TAG, "isTableExist exception");
		}
		return result;
	}  

	 /**
	  * 判断是否存在某字段(要先判断表是否存在)
	  * @param tabName 表名
	  * @return
	  */
	public boolean isColumnExist(String tableName,String columnName){
		boolean result = false;
		if(tableName == null) {
			return false;
		}
		try {
			Cursor cursor = null;
			String sql = "select count(1) as c from sqlite_master where type ='table' and name ='"+tableName.trim()+"' and sql like '%"+ columnName.trim() +"%'" ;
			cursor = db.rawQuery(sql, null);
			if(cursor.moveToNext()){
				int count = cursor.getInt(0);
				if(count > 0){
					result = true;
				}
			}
			cursor.close();
		} catch (Exception e) {
			Log.e(TAG, "isColumnExist exception");
		}
		return result;
	}  

}
package com.metoo.girls;

import android.content.ContentValues;
import android.database.Cursor;
import android.test.AndroidTestCase;
import android.util.Log;
/**
 * 单元测试操作sqlLite的各种sql
 */
public class GirlsDbHelperTest extends AndroidTestCase{
	/**
	 * 创建表
	 * @throws Exception
	 */
	public void createTable() throws Exception{
		GirlsDbHelper dbHelper = GirlsDbHelper.getInstance(this.getContext());
		dbHelper.open();
		String deleteSql = "drop table if exists user ";
		dbHelper.execSQL(deleteSql);
		 //id是自动增长的主键,username和 password为字段名, text为字段的类型
		String sql = "CREATE TABLE user (id integer primary key autoincrement, username text, password text)";
		dbHelper.execSQL(sql);
		dbHelper.close();
	}

	/**
	 * 插入数据
	 * @throws Exception
	 */
	public void insert() throws Exception{
		GirlsDbHelper dbHelper = GirlsDbHelper.getInstance(this.getContext());
		dbHelper.open();
		ContentValues values =  new ContentValues();  //相当于map
		values.put("username", "test");
		values.put("password", "123456");
		dbHelper.insert("user", values);
		dbHelper.close();
	}

	/**
	 * 更新数据
	 * @throws Exception
	 */
	public void update() throws Exception{
		GirlsDbHelper dbHelper = GirlsDbHelper.getInstance(this.getContext());
		dbHelper.open();
		ContentValues initialValues = new ContentValues();
		initialValues.put("username", "changename");  //更新的字段和值
		dbHelper.update("user", initialValues, "id = '1'", null);   //第三个参数为 条件语句
		dbHelper.close();
	}

	/**
	 * 删除数据
	 * @throws Exception
	 */
	public void delete() throws Exception{
		GirlsDbHelper dbHelper = GirlsDbHelper.getInstance(this.getContext());
		dbHelper.open();
		String testId = "1";
		dbHelper.delete("user", "id = '"+ testId +"'", null);
		dbHelper.close();
	}

	/**
	 * 增加字段
	 * @throws Exception
	 */
	public void addColumn() throws Exception{
		GirlsDbHelper dbHelper = GirlsDbHelper.getInstance(this.getContext());
		dbHelper.open();
		String updateSql = "alter table user add company text";
		dbHelper.execSQL(updateSql);
	}

	/**
	 * 查询列表
	 * @throws Exception
	 */
	public void selectList() throws Exception{
		GirlsDbHelper dbHelper = GirlsDbHelper.getInstance(this.getContext());
		dbHelper.open();
		Cursor returnCursor = dbHelper.queryList("tbl_sexy_state", new String[] {"id", "index", "unlocked"}, "index = ", null,null, null, "id desc");
		while(returnCursor.moveToNext()){
			String id = returnCursor.getString(returnCursor.getColumnIndexOrThrow("id"));
			String username = returnCursor.getString(returnCursor.getColumnIndexOrThrow("username"));
			String password = returnCursor.getString(returnCursor.getColumnIndexOrThrow("password"));
		}
	}

	/**
	 * 某条信息
	 * @throws Exception
	 */
	public void selectInfo() throws Exception{
		GirlsDbHelper dbHelper = GirlsDbHelper.getInstance(this.getContext());
		dbHelper.open();
		Cursor returnCursor = dbHelper.queryList("user",new String[] {"id","username", "password"}, "id = '1'", null,null, null, "id desc");
		if (returnCursor.getCount() > 0) {
			returnCursor.moveToFirst();
			String id = returnCursor.getString(returnCursor.getColumnIndexOrThrow("id"));
			String username = returnCursor.getString(returnCursor.getColumnIndexOrThrow("username"));
			String password = returnCursor.getString(returnCursor.getColumnIndexOrThrow("password"));
		}
	}
}

关于android的DB操作的更多相关文章

  1. [Android] Android 使用 Greendao 操作 db sqlite(2)-- 封装DaoUtils类

    继续接上文: Android 使用 Greendao 操作 db sqlite(1)-- 直接在MainActivity中调用 布局文件同上文一致,这里就不贴了. 一.封装DaoUtils类 User ...

  2. [Android] Android 使用 Greendao 操作 db sqlite(1)-- 直接在MainActivity中调用

    继续接上文: Android 使用 Greendao 操作 db sqlite 布局文件: activity_test_green.xml <?xml version="1.0&quo ...

  3. [Android] Android 使用 Greendao 操作 db sqlite

    Android 使用 Greendao 操作 db sqlite GreenDAO是一个开源的安卓ORM框架,能够使SQLite数据库的开发再次变得有趣.它减轻开发人员处理低级数据库需求,同时节省开发 ...

  4. android管理联系人操作

    ContentProvider扩展之管理系统联系人 我们都知道ContentProvider是用来共享数据的,然而android本身就提供了大量的ContentProvider,例如联系人信息,系统的 ...

  5. [转]Android - 文件读写操作 总结

     转自:http://blog.csdn.net/ztp800201/article/details/7322110 Android - 文件读写操作 总结 分类: Android2012-03-05 ...

  6. 【转】Android 使用ORMLite 操作数据库

    Android 使用ORMLite 操作数据库   用过ssh,s2sh的肯定不会陌生 ,应该一学就会 第一步: 下载ormlite-android-4.41.jar和ormlite-core-4.4 ...

  7. Android开发---如何操作资源目录中的资源文件4 ---访问xml的配置资源文件的内容

    Android开发---如何操作资源目录中的资源文件4 XML,位于res/xml/,这些静态的XML文件用于保存程序的数据和结构. XmlPullParser可以用于解释xml文件 效果图: 描述: ...

  8. Android开发---如何操作资源目录中的资源文件3--圆角边框、背景颜色渐变效果、边框颜色

    Android开发---如何操作资源目录中的资源文件3 效果图 1.圆角边框 2.背景颜色渐变效果 1.activity_main.xml 描述: 定义了一个shape资源管理按钮 <?xml ...

  9. Android开发 ---如何操作资源目录中的资源文件2

    Android开发 ---如何操作资源目录中的资源文件2 一.颜色资源管理 效果图: 描述: 1.改变字体的背景颜色 2.改变字体颜色 3.改变按钮颜色 4.图像颜色切换 操作描述: 点击(1)中的颜 ...

随机推荐

  1. 数字串(codevs 1394)

    题目描述 Description 给你一个长度为n的数字串,数字串里会包含1-m这些数字.如果连续的一段数字子串包含了1-m这些数字,则称这个数字字串为NUM串.你的任务是求出长度最短的NUM串是什么 ...

  2. 网上找的一篇博文,原文搞错了,应该是\r\n,本文已改正!——回车CR和换行line feed

    "回车"(carriage return)和"换行"(line feed)与 ASCII表 关于“回车”(carriage return)和“换行”(line  ...

  3. JS基础之BOM对象

    BOM 对象 JavaScript分为 ECMAScript,DOM,BOM. BOM(浏览器对象模型),可以对浏览器窗口进行访问和操作.使用 BOM,开发者可以移动窗口.改变状态栏中的文本以及执行其 ...

  4. 2017 ACM/ICPC Asia Regional Qingdao Online 记录

    题目链接  Qingdao Problem C AC自动机还不会,暂时暴力水过. #include <bits/stdc++.h> using namespace std; #define ...

  5. 非旋转Treap:用运行时间换调试时间的有效手段

    非旋转Treap:用运行时间换调试时间的有效手段   Hello大家好,我们今天来聊一聊非旋转Treap. 相信各位或多或少都做过些序列上的问题.如果水题我们考虑暴力:不强制在线我们可能用过莫队和待修 ...

  6. 洛谷——P1025 数的划分

    P1025 数的划分 题目描述 将整数n分成k份,且每份不能为空,任意两个方案不相同(不考虑顺序). 例如:n=7,k=3,下面三种分法被认为是相同的. 1,1,5; 1,5,1; 5,1,1; 问有 ...

  7. jquery 实现鼠标点击div盒子移动功能

    // Start 窗口的拖动 var _move=false; //移动标记 var _x,_y; //鼠标离控件左上角的相对位置 $(document).ready(function(){ $(&q ...

  8. 改动C:\WINDOWS\system32\drivers\etc\hosts 文件有什么作用

    host是一个没有扩展名的系统文件,能够用记事本等工具打开,其作用就是将一些常常使用的网址域名与其相应的IP地址建立一个关联"数据库".当用户在浏览器中输入一个须要登录的网址时,系 ...

  9. 【Todo】Java的JIT机制

    先是参考了这篇说的不怎么详细的文章<Java的JIT机制>(Link) JIT是just in time,即时编译技术.使用该技术,能够加速java程序的执行速度. 通常javac将程序源 ...

  10. 第二讲_图像数据处理Image Data Processing

    第二讲_图像数据处理Image Data Processing 深度模型出现后被弱化,但是思想的影子在深度模型中可以看到的 图片存储原理 RGB颜色空间:三通道(b,g,r),加法混色 CMY(K): ...