注意:如果dbUtil内的方法要对外开放,则需在方法前面加 this.
/*管理本地sql相关脚本*/
var dbUtil = function () {
var dbName = 'wydb'; //数据库名
var version = '1.0'; //版本信息
var description = 'wydb'; //描述
var maxSize = 1024 * 1024 * 1024; //最大值
var dbObj = null;
//打开数据库
function openDB() {
try {
if (!dbObj) {
dbObj = openDatabase(dbName, version, description, maxSize);
}
} catch (e) {
alert("打开数据库出现未知错误: " + e);
dbObj = null;
}
return dbObj;
}
getDB = function () {
openDB();
return dbObj;
}
executeSqlDefault = function (sqlStr, params, successHandler, errorHandler) {
openDB();
dbObj.transaction(function (tx) {
tx.executeSql(sqlStr, params, successHandler, errorHandler);
}, null, null);
}
executeSqlTrans = function (fun, successHandler, errorHandler) {
openDB();
dbObj.transaction(fun, errorHandler, successHandler);
}
//修改数据库版本信息
changeDBVersion = function (oldVersion, newVersion) {
dbObj = openDB();
dbObj.changeVersion(oldVersion, newVersion, null, errorFun, null);
}
//判断某表是否存在:表名、存在回调函数、不存在回调函数
isExitTable = function (tableName, exitFun, noexitFun) {
dbObj = openDB();
var sql = "select * from sqlite_master where type='table' and name = ?";
dbObj.transaction(function (tx) {
tx.executeSql(sql, [tableName], function (transaction, result) {
if (result.rows.length > 0 && exitFun) {
exitFun.call();
} else if (result.rows.length <= 0 && noexitFun) {
noexitFun.call();
}
}, null);
});
}
//删除表数据:表名,删除成功回调函数
clearTableData = function (tableName, callBackFun) {
dbObj = openDB();
var sql = "delete from ?";
dbObj.transaction(function (tx) {
tx.executeSql(sql, [tableName], callBackFun, null);
});
}
//删除表,删除成功回调函数
deleteTable = function (tableName, callBackFun) {
dbObj = openDB();
var sql = "drop table ?";
dbObj.transaction(function (tx) {
tx.executeSql(sql, [tableName], callBackFun, null);
});
}
}
本文介绍了一个用于管理本地SQL脚本的方法,包括数据库的打开、版本变更、表的存在检查等功能。提供了基本的SQL操作,如执行SQL语句、事务处理等。
26万+

被折叠的 条评论
为什么被折叠?



