Web Sql数据库简介

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

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

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

Web SQL创建的数据库在哪儿

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


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


打开数据库

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

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

1. 数据库名称

2. 版本号

3. 描述文件

4. 数据库大小

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

创建表

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

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

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

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

插入数据

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

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

删除数据

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

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

更新数据

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

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

查询数据

查询语句结构:

db.transaction(function (tx) {
            tx.executeSql('inquire statement',
             [],
             function (tx, results) {
             //put your code
             }
             },
             null);
         });

查询所有信息:

        var msg;
         db.transaction(function (tx) {
            //查询所有信息
            tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) {
               var i;
               var len;
               //获得记录总数
               len  = results.rows.length;
               msg = "<p>查询记录条数: " + len + "</p>";
               //获得id为"status"的第一个标签
               document.querySelector('#status').innerHTML +=  msg;

               //获得每一个记录
               for (i = 0; i < len; i++){
                  msg = "<p><b>" + results.rows.item(i).log + "</b></p>";
                  document.querySelector('#status').innerHTML +=  msg;
               }
            }, null);
         });

注:

1.document.querySelector(‘#status’)

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

<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. 编译原理LL1文法分析树(绘图过程)算法实现

    import hjzgg.analysistable.AnalysisTable; import hjzgg.first.First; import hjzgg.follow.Follow; impo ...

  2. SQL*Loader之CASE11

    CASE11 1. SQL脚本 [oracle@node3 ulcase]$ cat ulcase11.sql set termout off rem host write sys$output &q ...

  3. Bounce.js – 快速创建漂亮的 CSS3 动画效果

    Bounce.js 是一个用于制作漂亮的 CSS3 关键帧动画的 JavaScript 库,使用其特有的方式生成的动画效果.只需添加一个组件,选择预设,然后你就可以得到一个短网址或者导出为 CSS 代 ...

  4. 互动教程,让你5分钟掌握 Flexbox 布局模式

    Flexbox 布局模块目前是 W3C 候选标准,旨在提供一个更有效的方式进行布局,对齐和为容器里的项目分配空间,即使它们的大小是未知的或者动态的.这里分享一个基于 Knockout.js 构建的互动 ...

  5. 【图论】深入理解Dijsktra算法

    1. Dijsktra算法介绍 Dijsktra算法是大牛Dijsktra于1956年提出,用来解决有向图单源最短路径问题.但不能解决负权的有向图,若要解决负权图则需要用到Bellman-Ford算法 ...

  6. WebGL实现HTML5贪吃蛇3D游戏

    js1k.com收集了小于1k的javascript小例子,里面有很多很炫很酷的游戏和特效,今年规则又增加了新花样,传统的classic类型基础上又增加了WebGL类型,以及允许增加到2K的++类型, ...

  7. Android与Swift iOS开发:语言与框架对比

    Swift是现在Apple主推的语言,2014年新推出的语言,比Scala等“新”语言还要年轻10岁.2015年秋已经开源.目前在linux上可用,最近已经支持Android NDK:在树莓派上有Sw ...

  8. VS2015 新Web项目(C#6)出现CS1617错误的解决

    VS2015新增了对C#6的支持. 在新的Web项目模板中通过引入nuget包Microsoft.CodeDom.Providers.DotNetCompilerPlatform:1.0.0并在web ...

  9. 年薪10w和年薪100w的人,差在哪里?

    职场10年,为什么有人已经当上了董事总经理,而有的人还是资深销售经理? 出道10年,为什么有人已经当上了主编.出版人,而有的人还是资深编辑? 打拼10年,为什么有人已经身价数十亿美金,而有的人还在为竞 ...

  10. MVP的PV模式与SC模式

    MVC是现今挺被推崇的一种架构模式,而MVP在MVC的基础对视图与模型上再解耦,使结构和各自的功能也有所改变.在去年鄙人也尝试了一下使用MVP做了一个小Demo,作为了MVC的一个变体,MVP还分了两 ...