写了个数据库操作类,担心同步出问题?

原创 2017年01月03日 02:45:42
使用synchronized,却一直不很明白,是否已经做到同步绝对没问题了?

/*
 * 类介绍:数据库帮助
 * 
 * 说明:参考http://bbs.51cto.com/thread-990260-1.html
 * 如果多线程同时读写,保持单个SqliteOpenHelper实例,同时对所有数据库操作的方法添加synchronized关键字。
 */
public class DatabaseHelper extends SQLiteOpenHelper {
public static final String TAG = "DatabaseHelper";

private static DatabaseHelper instance;

/**
 * 构造
 * @param context
 */
private DatabaseHelper(Context context) {
super(context, DatabaseBean.DB_NAME, null, DatabaseBean.DB_VERSION);
}

/**
 * 获得单实例
 * @param context
 * @return
 */
public synchronized static DatabaseHelper the(Context context) {
if (DatabaseHelper.instance == null) {
DatabaseHelper.instance = new DatabaseHelper(context);
}

return DatabaseHelper.instance;
}

@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(DatabaseBean.DB_CREATE_TABLE_MSGBOX);
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
}

/**
 * 总数
 * @return
 */
    public synchronized long getCount() {
     long count = 0;
try {
SQLiteDatabase db = getReadableDatabase();
String sql = "SELECT COUNT(*) FROM " + DatabaseBean.DB_TABLE_MSGBOX;
SQLiteStatement sqLiteStatement = db.compileStatement(sql);
count = sqLiteStatement.simpleQueryForLong();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
         close();
        }
    
        return count;
    }
    
    /**
 * 查询
 * @param index
 * @return
 */
    public synchronized DatabaseBean query(int index) {
     DatabaseBean databaseBean = new DatabaseBean();
try {
SQLiteDatabase db = getWritableDatabase();
Cursor cursor = db.query(DatabaseBean.DB_TABLE_MSGBOX, null, null, null, null, null, null);
if (cursor != null) {
if (cursor.moveToPosition(index)) {
int id = cursor.getInt(DatabaseBean.COLUMN_IDX_ID);
String datatime = cursor.getString(DatabaseBean.COLUMN_IDX_DATETIME);
String content = cursor.getString(DatabaseBean.COLUMN_IDX_CONTENT);
databaseBean.setId(id);
databaseBean.setDatatime(datatime);
databaseBean.setContent(content);
}
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
         close();
        }
    
        return databaseBean;
    }
    
    /**
 * 插入
 * @param datetime
 * @param content
 * @return
 */
    public synchronized long insert(String datetime, String content) {
try {
SQLiteDatabase db = getWritableDatabase();
ContentValues contentValues = new ContentValues();
contentValues.put(DatabaseBean.COLUMN_DATETIME, datetime);
contentValues.put(DatabaseBean.COLUMN_CONTENT, content);
long count = db.insert(DatabaseBean.DB_TABLE_MSGBOX, null, contentValues);
return count;
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
         close();
        }
        
        return -1;
    }
    
    /**
     * 删除
     * @param id
     * @return
     */
    public synchronized int delete(int id) {
     int count = -1;
try {
SQLiteDatabase db = getWritableDatabase();
String[] whereArgs = {""+id};
count = db.delete(DatabaseBean.DB_TABLE_MSGBOX, DatabaseBean.WHERECLAUSE, whereArgs);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
         close();
        }
        
        return count;
    }
}

/**
 * 类介绍:数据库数据区定义
 */
public class DatabaseBean {
public static final String DB_NAME = "avc.db";
public static final int DB_VERSION = 1;
public static final String DB_TABLE_MSGBOX = "msgbox";

public static final String COLUMN_ID = "id";
public static final String COLUMN_DATETIME = "datetime";
public static final String COLUMN_CONTENT = "content";

public static final String[] COLUMNS = {
COLUMN_ID, COLUMN_DATETIME, COLUMN_CONTENT
    };
    
    public static final int COLUMN_IDX_ID = 0;
    public static final int COLUMN_IDX_DATETIME = 1;
    public static final int COLUMN_IDX_CONTENT = 2;

//最后COLUMNS没有逗号
public static final String DB_CREATE_TABLE_MSGBOX = "create table if not exists " + DB_TABLE_MSGBOX + "("
+ COLUMN_ID + " integer primary key autoincrement,"
+ COLUMN_DATETIME + " varchar(20),"
+ COLUMN_CONTENT + " varchar(120)"
+ ")";

public static final String WHERECLAUSE = COLUMN_ID + "=?";

private int id;
private String datatime;
private String content;

/**
 * 构造
 */
public DatabaseBean() {
super();
id = 0;
datatime = "";
content = "";
}

/**
 * @return the id
 */
public int getId() {
return id;
}

/**
 * @param id the id to set
 */
public void setId(int id) {
this.id = id;
}

/**
 * @return the datatime
 */
public String getDatatime() {
return datatime;
}

/**
 * @param datatime the datatime to set
 */
public void setDatatime(String datatime) {
this.datatime = datatime;
}

/**
 * @return the content
 */
public String getContent() {
return content;
}

/**
 * @param content the content to set
 */
public void setContent(String content) {
this.content = content;
}
}

C++通用数据库操作类实现

业务中涉及到要实现数据库操作的通用化,想了一种思路,欢迎讨论 sql语句在xml配置时写法   读取配置文件里的查询语句,XML里需要注意特殊符号转换   XML里表示=需要加   XML文档中包...
  • zhu339111520
  • zhu339111520
  • 2016年12月12日 15:16
  • 2609

php mysql数据库操作类,功能很强大

  • dongsg11200
  • dongsg11200
  • 2014年03月25日 13:23
  • 2949

自己写了个complex类

//: complex.h#ifndef _COMPLEX_H_#define _COMPLEX_H_namespace numeric {//////////////////////////////...
  • blas
  • blas
  • 2004年11月28日 10:39
  • 775

我们所担心的事,百分之九十都不会发生,而对永远不会发生的事情瞎操心是很悲哀的。

我们所担心的事,百分之九十都不会发生,而对永远不会发生的事情瞎操心是很悲哀的。你可以把最近忧郁的事情都写下来,然后过几个月再来看看这些你所忧郁的事情,是不是几乎所有的困难都过去了。那么,让这个月的经历...
  • yangjl
  • yangjl
  • 2005年01月09日 17:33
  • 5469

再次遇到CSDN blog无法发表的bug

今天在CSDN的blog上花了两个小时写完了《Ajax模式与最佳实践》 前6章的勘误。写好之后,点“发表文章”按钮,结果发现再次遇到以前曾经遇到过的无法发表的bug。就是没有任何的提示,貌似已经发...
  • itkbase
  • itkbase
  • 2008年03月11日 16:46
  • 216

MySQL数据库操作类(PHP实现,支持连贯操作)

使用过ThinkPHP框架的同学可能会对于其中数据库模型操作特别有好感,ThinkPHP提供了数据库操作的简单的操作,对于连接数据库,数据库的增删改查等数据操作都非常的nice,同时支持连贯操作,对于...
  • helencoder
  • helencoder
  • 2016年04月17日 11:27
  • 12905

ASP中一个数据库操作类

是否隐藏错误信息的选项,true=显示,false=隐藏const IS_DEBUG = true Class Conn Public objcn Private ConnStr Private Er...
  • theageofe
  • theageofe
  • 2007年08月18日 10:35
  • 329

C#数据库操作类(完整通用)

using System; using System.Collections.Generic; using System.Text; using System.Data.SqlClient; ...
  • angela8804100029
  • angela8804100029
  • 2013年04月14日 19:09
  • 1845

C#.NET操作数据库通用类

下面给出了一个C#操作MS SQL Server 数据库的通用类,通过该类可以对数据库进行任何操作,包括执行SQL语句、执行存储过程。以下是其详细实现过程,希望大家共同修改优化之。稍后将介绍如何使用它...
  • ecjtuync
  • ecjtuync
  • 2007年04月25日 16:47
  • 1462

pdo数据库操作类

pdo,有不局限数据库,和防止sql注入等很多优点,也是php官方推荐的方式,所以花点时间写个pdo数据库操作类!...
  • gongstrong123
  • gongstrong123
  • 2016年03月08日 21:58
  • 1084
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:写了个数据库操作类,担心同步出问题?
举报原因:
原因补充:

(最多只允许输入30个字)