当前位置:Gxlcms > 数据库问题 > HTML5项目笔记5:使用HTML5 WebDataBase设计离线数据库

HTML5项目笔记5:使用HTML5 WebDataBase设计离线数据库

时间: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   

人气教程排行