【HTML5】HTML5本地数据库(Web Sql Database)
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】HTML5本地数据库(Web Sql Database)的更多相关文章
- HTML5本地存储——Web SQL Database
在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数据就 ...
- [转]HTML5本地存储——Web SQL Database
在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数据就 ...
- HTML5开发学习:本地存储Web Sql Database
Web Sql Database,中文翻译作"本地数据库",是随着HTML5规范加入的在浏览器端运行的轻量级数据库. 在HTML5中,大大丰富了客户端本地可以存储的内容 ...
- HTML5本地存储——Web SQL Database与indexedDB
虽然在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数 ...
- HTML5教程之html 5 本地数据库(Web Sql Database)
HTML5的Web SQL Databases(html5 本地数据库)的确很诱惑人,当你发现可以用与mysql查询一样的查询语句来操作本地数据库时,你会发现这东西挺有趣的.今天,我们一起来了解HTM ...
- HTML5 学习笔记(三)——本地存储(LocalStorage、SessionStorage、Web SQL Database)
一.HTML4客户端存储 B/S架构的应用大量的信息存储在服务器端,客户端通过请求响应的方式从服务器获得数据,这样集中存储也会给服务器带来相应的压力,有些数据可以直接存储在客户端,传统的Web技术中会 ...
- (转)HTML5开发学习(3):本地存储之Web Sql Database
原文:http://www.cnblogs.com/xumingxiang/archive/2012/03/25/2416386.html HTML5开发学习(3):本地存储之Web Sql Data ...
- html 5 本地数据库(Web Sql Database)核心方法openDatabase、transaction、executeSql 详解
Web SQL数据库API实际上不是HTML5规范的组成部分,而是单独的规范.它通过一套API来操纵客户端的数据库.Safari.Chrome. Firefox.Opera等主流浏览器都已经支持Web ...
- HTML5客户端数据存储机制Web Storage和Web SQL Database
引言 html5本地存储可以选择两种方式,一种是本地存储,一种是sqlite. 比如开发html5的购物车功能,就可以考虑选择其中之一,进行本地存储与操作. 又或者保存用户登录信息,可以使用local ...
随机推荐
- 大型 JavaScript 应用架构中的模式
原文:Patterns For Large-Scale JavaScript Application Architecture by @Addy Osmani 今天我们要讨论大型 JavaScript ...
- .NET面试题解析(04)-类型、方法与继承
系列文章目录地址: .NET面试题解析(00)-开篇来谈谈面试 & 系列文章索引 做技术是清苦的.一个人,一台机器,相对无言,代码纷飞,bug无情.须梦里挑灯,冥思苦想,肝血暗耗,板凳坐穿 ...
- Spring学习总结(一)——Spring实现IoC的多种方式
控制反转IoC(Inversion of Control),是一种设计思想,DI(依赖注入)是实现IoC的一种方法,也有人认为DI只是IoC的另一种说法.没有IoC的程序中我们使用面向对象编程对象的创 ...
- 增强学习(四) ----- 蒙特卡罗方法(Monte Carlo Methods)
1. 蒙特卡罗方法的基本思想 蒙特卡罗方法又叫统计模拟方法,它使用随机数(或伪随机数)来解决计算的问题,是一类重要的数值计算方法.该方法的名字来源于世界著名的赌城蒙特卡罗,而蒙特卡罗方法正是以概率为基 ...
- C#抓取天气数据
使用C#写的一个抓取天气数据的小工具,使用正则匹配的方式实现,代码水平有限,供有需要的同学参考.压缩包中的两个sql语句是建表用的. http://files.cnblogs.com/files/yu ...
- 一步一步开发Game服务器(一)
什么是服务器?对于很多人来说也许只是简单成为在服务器端运行的程序的确如此,服务器通常意义就是说在服务器端运行的程序而已.那么我们怎么理解和分析游戏服务器哪? 传统意义上来说,程序运行后,正常流程, 启 ...
- Oracle Flashback和RMAN示例
作者:Grey 原文地址:http://www.cnblogs.com/greyzeng/p/5346833.html 环境: Windows 10 专业版 Oracle Database 12c R ...
- C#如何调用COM
这章中描述的属性被用在创建和COM程序交互的程序中. 1.1 COMImport 属性 当被放在一个类上, COMImport 属性就把这个类标记为一个外部实现的COM 类.这样的一个类声明使得可以 ...
- LINQ的Any方法
返回布尔值,判断集合中是否有元素满足某一条件. source code: IEnumerable<string> str = new List<string> { " ...
- ASP.NET Core实现OAuth2.0的ResourceOwnerPassword和ClientCredentials模式
前言 开发授权服务框架一般使用OAuth2.0授权框架,而开发Webapi的授权更应该使用OAuth2.0授权标准,OAuth2.0授权框架文档说明参考:https://tools.ietf.org/ ...