时间:2021-07-01 10:21:17 帮助过:4人阅读
这边还可以设置数据库的名称dbName和数据库大小size,默认数据库名称是OFLMAIL,就是我们这个离线系统的名称,默认大小是2兆。
我们还可以设置错误处理方法sqlErrorHandler,用户处理操作失败之后的错误捕捉
这样,我们就拿到了操作SQLite的数据上下文db,通过上下文db,我们可以执行相应的CURD操作。
第一步,我们写一个创建数据表的方法,把这个方法放在SQLProvider方法体里面,
View Code一共包含了三个参数tableName,fileds,callBack,分表代表你要创建的表名,所对应的字段数组,就是把这个表相应的字段用数组保存起来(方法里面还会自动创建一个表名加上“_SEC”的字段,他是个增量标识,用做主键),callBack顾名思义,回调函数,这个参数可以不传。这个回调函数的存在很重要,因为整个基于SQLite数据库的操作方法都是异步调用的,所以需要在回调函数中嵌套执行,否则有些执行会被中断。
将这个函数放在SQLProvider里面,有一个好处就是到时候可以在SQLProvider的动态实例化中直接调用该函数
如:var sqlProvider = new SQLProvider();
sqlProvider.createTable(“UserInfo”,new Array(“UserName”,”UserPwd”));
这样子,方便我们在页面中调用。这种操作方法相当于C#里面的动态类创建方法,SQLProvider就是类名,createTable就是类中的方法,实例化调用。
接下来我们的数据库的操作,包括数据表和数据的CURD操作,都会以这种方法写在里面:
删除数据表(只需传入表名就行了,他会删除相应的数据表):
View Code
添加数据(包含了四个参数:表名,字段数组,字段所对应的值的数组,和一个回调函数)
这边的fields和values代表了字段数组和值数组,他们一一对应:
如 var fileds=new Array(“UserName”,”UserPwd”);
var values=new Array(“Ben”,”123456”);则说明在UserInfo表里面添加了一条数据,这条数据至少包含三个有值的字段,主键,UserName和UserPwd,而values 则是相应的值数组。
回调函数中带有一个返回的参数,返回了你所添加的改行数据的主键。
View Code
删除数据 (包含了三个参数:表名tableName,主键sec和一个回调函数callback)
这个主键SEC是该待删除的数据在Web DataBase中的主键,我们前面在建表的时候有一个增量标识字段,该字段的名称为表名加上“_SEC”,因为唯一性,所以我们可以根据这个主键来删除该行数据,
代码如下:
View Code
修改数据(这边包括了四个参数,表名tableName,字段数组fields,值数组values,回调函数callback)
字段数组和值数组必须是一一对应的,而且第一个字段必须是主键,所对应的values的第一个值也必须是主键的值,这样,可以根据字段的主键来查询相应的数据行。
查出的数据行之后,可以根据后面的相应字段,进行修改。
View Code调用方式类似如下:
var fileds=new Array(“UserInfo_SEC”,“UserName”,”UserPwd”);
var values=new Array(“5”,“Ben”,”123456”);
sqlProvider.updateRow(“UserInfo”,fileds ,values,function(){
log.debug(“修改成功!”);
});
这样子就是在UserInfo表里面修改主键为5的数据行,修改它的UserName的值为:“Ben”,
修改它的UserPwd的值为:“123456”
根据主键查询单行数据(包含三个参数表名tableName,主键SEC,回调函数callback):
根据表名和主键名称获取到该行数据,并返回,注意到这边通过cllback回调函数来返回查询的结果,通过数据上下文tx执行该SQL脚本,返回的是结果集result,这边我们取他结果集的第一条数据也即是result.rows.item(0),实际上结果集中也只有一条数据。
View Code
读取指定的数据表(根据表名来读取相应的数据表,并返回结果集):
View Code结果集result中的列的集合用result.rows表示
列的数量用result.rows.length来表示
单条数据是用result.rows.item(index)表示,index指的是列的索引位置,从0开始
根据SQL的where条件语句来读取指定的数据表(根据表名tableName和sqlSenten条件语句来执行,并返回结果集):
View Code与上面的方法类似,只是多了一个sqlSenten条件语句来筛选数据
根据某个字段检查是否存在该列(通过字段名和字段所对应的值)来进行操作,过多地用于根据主键来查询数据行:
View Code当检索读到的结果集合中包含了一条数据的时候,返回1,代表存在该行,为0的时候代表不存在该行。这边做的其实不完善只能在唯一值的字段中才能够过正确显示,如主键,此外还可以通过where条件语句来验证是否存在该行。这边就不说了,自己去尝试。
这样就完成了整个离线数据库的CURD操作,如果有不够的地方,我们可以继续修改完善,完整代码如下,在代码的结尾我们进行了实例化,我们把这些代码独立地存放到WebDataBase.js文件里面,这样可以在继承这个脚本文件的页面里直接调用这个脚本库的方法。
现在我们把这些数据库的的操作应用到我们的系统中,
我们的用户信息页面(Information.html),用来保存登录用户的个人信息的:
包含了如下字段:姓名,性别,入职时间,工号和部门:
在载入的时候查看是否有数据,有数据则显示第一条
View Code我们的保存按钮的代码如下:
View Code保存成功之后,数据就存储在我们离线的数据库里面了,载入时显示在页面效果如下:
我们去浏览器中的DataBase中查看,就可以看到这条数据了,如图:
//以下是表单重置函数,删掉该用户信息的代码
function resets() {
var UserInfo_SEC = $("#UserInfo_SEC").val();
if (UserInfo_SEC != "0") {
sqlProvider.deleteRow("UserInfo", UserInfo_SEC, function () {
window.location.reload(true);
})
}
}
2010.11.18, W3C 宣布 将不再关注Web SQL databas,并且不再维护它的过时的规范,浏览器厂商也不会再在他们的新版浏览器中更新和升级这一块,取而代之的就是IndexedDB,W3C组织鼓励和推崇使用IndexedDB。所以,建议学习人员去看一下IndexedDB的使用方法。
HTML5项目笔记5:使用HTML5 WebDataBase设计离线数据库
标签:功能 管理 end 网络不通 llb 方式 orm com ror