Web Sql数据库简介

Web SQL数据库API实际上不是HTML5规范的组成部分,而是单独的规范。它通过一套API来操纵客户端的数据库。

Web SQL数据库的浏览器支持情况

Web SQL 数据库可以在最新版的 Safari, Chrome 和 Opera 浏览器中工作。

Web SQL创建的数据库在哪儿

这要依据你使用的浏览器的数据存储位置,默认是在安装目录的User Data文件夹。


html5创建的是一个sqllite数据库,用SQLiteSpy打开文件,可以看到里面的数据。SQLiteSpy是一个绿色软件,可以百度一下下载地址或SQLiteSpy官方下载。


打开数据库

  1. var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);

openDatabase() 方法对应的五个参数说明:

1. 数据库名称

2. 版本号

3. 描述文件

4. 数据库大小

5. 创建回调,该参数会再创建数据库后被调用

创建表

  1. tx.executeSql('CREATE TABLE LOGS (id unique, log)');

注:
1.创建表的命令不能单独使用,必须要和插入数据或是查询数据搭配使用,否则会报错。
2.有些地方写的格式是类似这样的

  1. dataBase.transaction( function(tx) {
  2. tx.executeSql(
  3. "create table if not exists stu (id REAL UNIQUE, name TEXT)",
  4. [],
  5. function(tx,result){ alert('创建stu表成功'); },
  6. function(tx, error){ alert('创建stu表失败:' + error.message);
  7. });
  8. });

不过自己试了试,发现function(tx,result){}和function(tx,error) {}除了前者在查询语句中起了作用,其余的语句都没有任何作用。

插入数据

  1. var pid = 2;
  2. var id = 3;
  3. var plog = "www.success.com";
  4. var log = "www.jame.com";
  5. db.transaction(function (tx) {
  6. //创建表
  7. tx.executeSql('DROP TABLE IF EXISTS LOGS');
  8. tx.executeSql('CREATE TABLE LOGS (id unique, log)');
  9. //静态插入数据
  10. tx.executeSql('INSERT INTO LOGS (id, log) VALUES (1, "www.honor.com")');
  11. //动态插入数据
  12. tx.executeSql('INSERT INTO LOGS (id, log) VALUES (?, ?)',[pid,plog]);
  13. tx.executeSql('INSERT INTO LOGS (id, log) VALUES (?, ?)',[id,log]);
  14. });

注:
1.处理数据的格式都有两种,分别为静态的和动态的。
2.在使用动态方法的时候需要注意语法

删除数据

  1. var did = 1;
  2. db.transaction(function (tx) {
  3. tx.executeSql('DELETE FROM LOGS WHERE id='+did);
  4. });

  1. db.transaction(function (tx)){tx.executeSql('DELETE FROM LOGS WHERE id = 1');

更新数据

  1. var uid = 2;
  2. db.transaction(function (tx) {
  3. tx.executeSql('UPDATE LOGS SET log=\'www.successful.cc\' WHERE id='+uid);
  4. });

  1. db.transaction(function (tx) {tx.executeSql('UPDATE LOGS SET log=\'www.successful.cc\' WHERE id=2');});

查询数据

查询语句结构:

  1. db.transaction(function (tx) {
  2. tx.executeSql('inquire statement',
  3. [],
  4. function (tx, results) {
  5. //put your code
  6. }
  7. },
  8. null);
  9. });

查询所有信息:

  1. var msg;
  2. db.transaction(function (tx) {
  3. //查询所有信息
  4. tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) {
  5. var i;
  6. var len;
  7. //获得记录总数
  8. len = results.rows.length;
  9. msg = "<p>查询记录条数: " + len + "</p>";
  10. //获得id为"status"的第一个标签
  11. document.querySelector('#status').innerHTML += msg;
  12. //获得每一个记录
  13. for (i = 0; i < len; i++){
  14. msg = "<p><b>" + results.rows.item(i).log + "</b></p>";
  15. document.querySelector('#status').innerHTML += msg;
  16. }
  17. }, null);
  18. });

注:

1.document.querySelector(‘#status’)

    该函数将获得id值为status的第一个标签。
2.id为status的标签如下:

  1. <div id="status" name="status"></div>

参考文章

HTML5 Web SQL

HTML5教程之html 5 本地数据库(Web Sql Database)

【HTML5】HTML5本地数据库(Web Sql Database)的更多相关文章

  1. HTML5本地存储——Web SQL Database

    在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数据就 ...

  2. [转]HTML5本地存储——Web SQL Database

    在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数据就 ...

  3. HTML5开发学习:本地存储Web Sql Database

       Web Sql Database,中文翻译作"本地数据库",是随着HTML5规范加入的在浏览器端运行的轻量级数据库.    在HTML5中,大大丰富了客户端本地可以存储的内容 ...

  4. HTML5本地存储——Web SQL Database与indexedDB

    虽然在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数 ...

  5. HTML5教程之html 5 本地数据库(Web Sql Database)

    HTML5的Web SQL Databases(html5 本地数据库)的确很诱惑人,当你发现可以用与mysql查询一样的查询语句来操作本地数据库时,你会发现这东西挺有趣的.今天,我们一起来了解HTM ...

  6. HTML5 学习笔记(三)——本地存储(LocalStorage、SessionStorage、Web SQL Database)

    一.HTML4客户端存储 B/S架构的应用大量的信息存储在服务器端,客户端通过请求响应的方式从服务器获得数据,这样集中存储也会给服务器带来相应的压力,有些数据可以直接存储在客户端,传统的Web技术中会 ...

  7. (转)HTML5开发学习(3):本地存储之Web Sql Database

    原文:http://www.cnblogs.com/xumingxiang/archive/2012/03/25/2416386.html HTML5开发学习(3):本地存储之Web Sql Data ...

  8. html 5 本地数据库(Web Sql Database)核心方法openDatabase、transaction、executeSql 详解

    Web SQL数据库API实际上不是HTML5规范的组成部分,而是单独的规范.它通过一套API来操纵客户端的数据库.Safari.Chrome. Firefox.Opera等主流浏览器都已经支持Web ...

  9. HTML5客户端数据存储机制Web Storage和Web SQL Database

    引言 html5本地存储可以选择两种方式,一种是本地存储,一种是sqlite. 比如开发html5的购物车功能,就可以考虑选择其中之一,进行本地存储与操作. 又或者保存用户登录信息,可以使用local ...

随机推荐

  1. SVN更改登录用户

    如果装了TortoiseSVN: Settings -> Saved Data -> Authentication Data -> clear.即可清除保存的上个用户登录信息:当再次 ...

  2. Js控制显示、隐藏文本框中的密码

    Js控制显示.隐藏文本框中的密码,也可称为是一款小型的JavaScript星号密码破解器,点击会显示出密码类型的文本框中的真实信息,再次点击则还原,程序 主要是获取HTML元素对象,然后强制更改元素属 ...

  3. 那些年,在AngularJS的路上遇到的坑

    使用AngularJS这么久以来,遇到过一些坑,之前一直没有以书面的形式整理下,现在好好总结下,以供后面查备. 一.angular scope 在ng-if与ng-show下的区别(两者作用域的差别) ...

  4. eclipse使用tomcat进行部署时编译代码不一致的处理

    操作步骤: 1. 先add and remove 去除项目 2. clean 完成清除工程在tomcat的目录 3. project-->clean 4. add adn remove 重新添加 ...

  5. SQLServer学习笔记系列6

    一.写在前面的话 时间是我们每个人都特别熟悉的,但是到底它是什么,用什么来衡量,可能很多人会愣在那里.时间可以见证一切,也可以消磨一切,那些过往的点点滴滴可思可忆.回想往年清明节过后,在家乡的晚上总能 ...

  6. 【Java基础】枚举和注解

    在Java1.5版本中,引入了两个类型:枚举类型enum type和注解类型annotation type. Num1:用enum代替int常量 枚举类型enum type是指由一组固定的常量组成合法 ...

  7. Cordova webapp实战开发:(6)如何写一个iOS下获取APP版本号的插件?

    上一篇我们学习了如何写一个Andorid下自动更新的插件,我想还有一部分看本系列blog的开发人员希望学习在iOS下如何做插件的吧,那么今天你就可以来看看这篇文字了. 本次练习你能学到的 学习如何获取 ...

  8. 基于HTML5的Drag and Drop生成图片Base64信息

    HTML5的Drag and Drop是很不错的功能,网上使用例子较多如 http://html5demos.com/drag ,但这些例子大部分没实际用途,本文将搞个有点使用价值的例子,通过Drag ...

  9. Maven提高篇系列之(六)——编写自己的Plugin(本系列完)

    这是一个Maven提高篇的系列,包含有以下文章: Maven提高篇系列之(一)——多模块 vs 继承 Maven提高篇系列之(二)——配置Plugin到某个Phase(以Selenium集成测试为例) ...

  10. SQL中 将同一个表中的A列更新到B列,B列更新到A列

    有网友在SKYPE问及,如标题,SQL中 将同一个表中的A列更新到B列,B列更新到A列. 其实这个不是问题,直接写更新语句即可,可以参考下面动画演示: SQL source code: CREATE ...