Web SQL Database 与 Indexed Database_function__的博客-程序员宝宝

技术标签: sqlite  Web SQL Database  浏览器本地存储  Web SQL Database 与 I  HTML  Indexed Database  

Web SQL Database 和 Indexed Database 都是在客户端存储大量结构化数据的解决方案。Web SQL Database 实现了传统的基于 SQL 语句的数据库操作,而 Indexed Database 实现了 NoSQL 的存储方式。本文主要对比两者在 CRUD 操作方面的实现方法,按照本文所述读者可以详细了解两者异同。



  • expand内容

HTML5 简介

HTML 标准自 1999 年 12 月发布的 HTML 4.01 后,后继的 HTML 5 和其它标准被束之高阁,为了推动 web 标准化运动的发展,一些公司联合起来,成立了一个叫做 Web Hypertext Application Technology Working Group (Web 超文本应用技术工作组 - WHATWG) 的组织,HTML5 草案的前身名为 Web Applications 1.0,於 2004 年被 WHATWG 提出,於 2007 年被 W3C 接纳,并成立了新的 HTML 工作团队。HTML 5 的第一份正式草案已于 2008 年 1 月 22 日公布。HTML 5 有两大特点:首先,强化了 Web 网页的表现性能。其次,追加了 本地数据库等 Web 应用的功能。HTML5 规范可以参考 W3C 官方网站

Web SQL Database 和 Indexed Database 简介

Web SQL Database 介绍

Web SQL Database API 实际上未包含在 HTML 5 规范之中,它是一个独立的规范,它引入了一套使用 SQL 操作客户端数据库的 API,这些 API 有同步的,也有异步的, 同步版本的 API 只在工作线程(Worker Threads)上有用,由于并不是所有的浏览器都支持工作线程,一般情况下,都会使用异步 API。它的核心方法有三个:openDatabase,transaction 和 executeSql。 这些 API 已经被广泛的实现在了不同的浏览器里,尤其是手机端浏览器。虽然 W3C 官方在 2011 年 11 月声明已经不再维护 Web SQL Database 规范,但由于其广泛的实现程度,了解这些 API 对 Web 开发还是非常有必要的。 详细的 Web SQL Database 规范可以参考 官方网站

Indexed Database 介绍

Indexed Database,也可简称为 IndexedDB(以前被称作 WebSimpleDB),同样是一个 Web 客户端存储结构化数据的规范,在 2009 年由 Oracle 提出。如果说 Web SQL Databae 在客户端实现了 传统的 SQL 数据库操作,那么 Indexed Database 更类似于 NoSQL 的形式来操作数据库 , 其中最重要的是 Indexed Database 不使用 SQL 作为查询语言。其数据存储可以不需要固定的表格模式,也经常会避免使用 SQL 的 JOIN 操作,并且一般具有水平可扩展性。目前 W3C 官方也把焦点 投到对 Indexed Database 规范的制定当中来,而 Microsoft 和 Mozilla 是对这个规范重要的两个推动者,Firefox 4 以上已经部分实现了 Indexed DB API,并且 IE 10 中也将实现 Indexed DB API。由于在手机等移动设备的浏览器中都没有实现 Indexed DB API,所以其还有一定的局限性,但这并 不妨碍它作为未来的 HTML5 的焦点而存在。详细的 Indexed Database 规范可以参考 官方网站

浏览器对 Web SQL Database 和 Indexed Database 支持情况

表 1. Web SQL Databse
IE Firefox Chrome Safari Opera iOS Safari Android Browser
6.0( × ) 4.0~7.0( × ) 10.0~13.0( √ ) 3.1~3.2( √ ) 10.5~11.0( √ ) 3.2( √ ) 2.1( √ )
7.0( × ) 8.0( × ) 14.0( √ ) 4.0( √ ) 11.1( √ ) 4.0~4.1( √ ) 2.2( √ )
8.0( × ) 9.0( × ) 15.0( √ ) 5.0( √ ) 11.5( √ ) 4.2~4.3( √ ) 2.3,3.0( √ )
9.0( × ) 10.0( × ) 16.0( √ ) 5.1( √ ) 11.6( √ ) 5.0( √ ) 4.0( √ )
10.0( × ) 11.0( × ) 17.0( √ ) 6.0( √ ) 12.0( √ )    
  12.0( × ) 18.0( √ )        
表 2. Indexed Databse
IE Firefox Chrome Safari Opera iOS Safari Android Browser
6.0( × ) 4.0~7.0( √ ) 11.0~13.0( √ ) 3.1~3.2( × ) 10.5~11.0( × ) 3.2( × ) 2.1( × )
7.0( × ) 8.0( √ ) 14.0( √ ) 4.0( × ) 11.1( × ) 4.0~4.1( × ) 2.2( × )
8.0( × ) 9.0( √ ) 15.0( √ ) 5.0( × ) 11.5( × ) 4.2~4.3( × ) 2.3,3.0( × )
9.0( × ) 10.0( √ ) 16.0( √ ) 5.1( × ) 11.6( × ) 5.0( × ) 4.0( × )
10.0( √ ) 11.0( √ ) 17.0( √ )        
  12.0( √ ) 18.0( √ )        

浏览器对 Web SQL Database 和 Indexed Database 支持的更详细信息可以参考网站 When can I use...

Web SQL Database 和 Indexed Database 的 CRUD 操作

本文以网上购物中的购物车为例,在场景中,用户可以添加多个商品到购物车,并且可以在购物车中进行删除修改等操作。而购物车的数据用户希望关闭浏览器后仍然存在,以便下 次用户再次打开此网站,仍可以看到这些购物车中的商品。这个场景比较适合用客户端数据库存储购物车中的商品,因为这些商品是结构化的数据,并且购物车中可能会存在大量商品。 以下示例 code 在 Chrome 16.0 中通过测试。

1. 创建数据库以及相应的表

在 Web SQL Database 中,由于内嵌的是 SQLite 数据库,所以仍需用 SQL 语句创建表 , 而列的数据类型可以参考 SQLite 数据库支持的数据类型。 应用 Web SQL Database API 提供的 OpenDatabase 方法创建 ShoppingCartDB 数据库,并且应用传统的 CREATE TABLE SQL 句法创建 ShoppingCart 表。

清单 1. Web SQL Database 创建操作
 var dbInfo={ 
	 dbName:"ShoppingCartDB",  // 名称
    dbVersion:"0.1", // 版本
    dbDisplayName:"Shopping Cart Database", // 显示名称
    dbEstimatedSize:10*11024*1024  // 大小 (byte) 
 }; 
		
 var db; 
 function createDB(){ 
	 db = window.openDatabase(dbInfo.dbName , dbInfo.dbVersion , 
		 dbInfo.dbDisplayName , dbInfo.dbEstimatedSize); 
 } 

 function dbError(tx, error){ 
	 console.error(error); 
 } 

 function createShoppingCartTable(){ 
	 db.transaction(function(tx){ 
     tx.executeSql( 
		"CREATE TABLE IF NOT EXISTS ShoppingCart " + 
        "(Id TEXT PRIMARY KEY, Name TEXT, Price REAL,Count INTEGER,Desc TEXT)", [],
         function(){ console.log('ShoppingCart database created successfully!' ); }, 
		 dbError 
		 ); 
	 }); 
 }

在 Indexed Database 中,ObjectStore 代替了传统的表概念。每个 ObjectStore 相当于一个 key 和 value 的集合,key 相当于传统数据库表中的主键, 每个数据库可以有多个 ObjectStore。创建数据库时需要使用 Indexed Database API 的 open 方法,创建 ShoppingCartDB,并且调用 createObjectStore 方法创建 ShoppingCart ObjectStore。

清单 2. Indexed Database 创建操作
 var dbInfo={ 
	 dbName:"ShoppingCartDB",  // 名称
    dbVersion:"0.1"// 版本
 }; 
		
 var db; 
 var indexedDB = window.indexedDB || window.webkitIndexedDB; 

 if ('webkitIndexedDB' in window) { 
	 window.IDBTransaction = window.webkitIDBTransaction; 
	 window.IDBKeyRange = window.webkitIDBKeyRange; 
 } 

 function createDBAndShoppingCartTable(){ 
	 var request = indexedDB.open(dbInfo.dbName); 
	 request.onsuccess = function(evt) { 
		 db = evt.target.result; 
		 // 只能在 setVersion 事务中创建 Object Stores; 
		 if (dbInfo.dbVersion!= db.version) { 
			 var setVReq = db.setVersion(dbInfo.dbVersion); 
			 // onsuccess 方法是唯一创建 Object Stores 的地方
			 setVReq.onerror = dbError; 
			 setVReq.onsuccess = function() { 
				 if(db.objectStoreNames.contains("ShoppingCart")) { 
          db.deleteObjectStore("ShoppingCart"); 
				 } 
				 db.createObjectStore("ShoppingCart",{keyPath: "id"});
				 refreshShoppingCart(); 
			 }; 
		 } 
		 else{ 
			 refreshShoppingCart(); 
		 } 
	 }; 
	 request.onerror = dbError; 
 } 

 function dbError(error){ 
	 console.error(error); 
 }

2. 添加商品数据

图 1. 添加商品界面
添加商品界面

在 Web SQL Database 中仍需使用传统的 SQL INSERT 操作,向表中添加数据。Web SQL Database API 提供的方法可以使用参数形式向表中插入数据。

清单 3. Web SQL Database 添加数据操作
 function insertDataToShoppingCart(data){ 
	 db.transaction(function(tx){ 
		 tx.executeSql("INSERT INTO ShoppingCart " + 
			"(Id, Name,Price,Count,Desc) VALUES (?,?,?,?,?)" , 
			 [data.id, data.name,data.price,data.count,data.desc], 
			 function(tx, result){ 
				 refreshShoppingCart(); 
			 }, 
			 dbError 
		 ); 
	 }); 
 }

在 Indexed Database 中需要使用 ObjectStore 的 put 方法,把 key 和 value 添加到 ObjectStore 中。

清单 4. Indexed Database 添加数据操作
 //data 是个 JavaScript 对象结构是 {id:String,item:Object} 
 //data 中的 item 属性是个对象,包括商品的信息,例如名称,价格等
 function insertOrUpdateDataToShoppingCart(data){ 
	 console.log("insertOrUpdateDataToShoppingCart",data); 
	 var trans = db.transaction(["ShoppingCart"], IDBTransaction.READ_WRITE); 
	 var store = trans.objectStore("ShoppingCart"); 
	 var request = store.put(data); 
	 request.onsuccess = function(e) { 
		 refreshShoppingCart(); 
	 }; 
	 request.onerror = dbError; 
 }

3. 读取商品数据

图 2. 购物车列表界面
购物车列表界面

在 Web SQL Database 可以使用 SQL 的 SELECT 语句查询出所有的记录,然后遍历行数据,获取所有商品信息。

清单 5. Web SQL Database 读取数据操作
 function refreshShoppingCart(){ 
	 dojo.byId("shoppingCartTableData").innerHTML=""; 
	 db.transaction(function(tx){ 
		 tx.executeSql("SELECT * FROM ShoppingCart" ,[], 
			 function(tx, result){ 
				 for(var i=0;i<result.rows.length;i++){  
          var item=result.rows.item(i); 
          var shoppingCart = dojo.byId("shoppingCartTableData"); 
          var tableRow = dojo.create("tr",{},shoppingCart); 
          dojo.create("td",{"innerHTML":item.Name},tableRow); 
          dojo.create("td",{"innerHTML":item.Price},tableRow); 
          dojo.create("td",{"innerHTML":item.Count},tableRow); 
          dojo.create("td",{"innerHTML":item.Desc},tableRow); 
          dojo.create("td",{"innerHTML":item.Price*item.Count},tableRow); 
          var actions = dojo.create("td",{},tableRow); 
          var btnDelete = new dijit.form.Button({ 
						"label":"删除", 
						"onClick":(function(id){ 
		          return function(){deleteDataFromShoppingCart(id)}} 
	          )(item.Id) 
          }); 
          var btnUpdate = new dijit.form.Button({ 
                         "label":"更新", 
                         "onClick":(function(item){return function(){ 
		          showUpdateDataDialog( 
			          {id:item.Id,name:item.Name,price:item.Price, 
			          count:item.Count,desc:item.Desc}); 
	          }})(item) 
          }); 
          actions.appendChild(btnDelete.domNode); 
          actions.appendChild(btnUpdate.domNode); 
				 } 
			 }, 
			 dbError 
		 ); 
	 }); 
 }

在 Indexed Database 中需要根据其提供的查询 API 进行数据的查询。这里使用 IDBKeyRange 这个对象确定需要查询数据的上下限,在调用 ObjectStore 提供的 openCursor 方法,传进 IDBKeyRange 对象作为参数。然后像使用数据库游标一样,在 onsuccess 回调方法中,获取数据对象,每次获取下一行数据时需要调用 result 对象的 continue 方法。

清单 6. Indexed Database 读取数据操作
 function refreshShoppingCart(){ 
	 dojo.byId("shoppingCartTableData").innerHTML=""; 
	 var trans = db.transaction(["ShoppingCart"], IDBTransaction.READ_ONLY); 
	 var store = trans.objectStore("ShoppingCart"); 
	 var keyRange = IDBKeyRange.lowerBound(0);// 查询所有数据
	 var cursorReq = store.openCursor(keyRange); 
	 cursorReq.onsuccess = function(evt) { 
		 var result = evt.target.result; 
		 if(!result)return;// 没有数据返回
		 var item = result.value.item 
		 var shoppingCart = dojo.byId("shoppingCartTableData"); 
		 var tableRow = dojo.create("tr",{},shoppingCart); 
		 dojo.create("td",{"innerHTML":item.name},tableRow); 
		 dojo.create("td",{"innerHTML":item.price},tableRow); 
		 dojo.create("td",{"innerHTML":item.count},tableRow); 
		 dojo.create("td",{"innerHTML":item.desc},tableRow); 
		 dojo.create("td",{"innerHTML":item.price*item.count},tableRow); 
		 var actions = dojo.create("td",{},tableRow); 
		 var btnDelete = new dijit.form.Button({ 
			"label":"删除", 
			"onClick":(function(id){ 
				 return function(){deleteDataFromShoppingCart(id)}} 
			 )(result.value.id) 
		 }); 
		 var btnUpdate = new dijit.form.Button({ 
			"label":"更新", 
			"onClick":(function(item){return function(){ 
		  showUpdateDataDialog({id:result.value.id,name:item.name, 
          price:item.price,count:item.count,desc:item.desc}); 
			 }})(item) 
		 }); 
		 actions.appendChild(btnDelete.domNode); 
		 actions.appendChild(btnUpdate.domNode); 
		 result.continue();// 继续读取下一行操作
	 }; 
	 cursorReq.onerror = dbError; 
 }

3. 更新商品数据

图 3. 更新商品信息界面
更新商品信息界面

在 Web SQL Database 中需要使用传统的 SQL UPDATE 操作更新数据库表中的数据。

清单 7. Web SQL Database 更新数据操作
 function updateDataToShoppingCart(data){ 
	 console.log("updateDataToShoppingCart",data); 
	 db.transaction(function(tx){ 
		 tx.executeSql("UPDATE ShoppingCart SET " + 
			"Name = ?, Price = ? , Count = ?,Desc = ? WHERE Id = ?" , 
			 [data.name,data.price,data.count,data.desc,data.id], 
			 function(tx, result){ 
				 refreshShoppingCart(); 
			 }, 
			 dbError 
		 ); 
	 }); 
 }

在 Indexed Database 操作中,更新数据和添加数据的方法是一样,如果 data 中的 id 在 ObjectStore 中已经存在了,将进行更新操作,否则将添加新数据

清单 8. Indexed Database 更新数据操作
 function insertOrUpdateDataToShoppingCart(data){ 
	 console.log("insertOrUpdateDataToShoppingCart",data); 
	 var trans = db.transaction(["ShoppingCart"], IDBTransaction.READ_WRITE); 
	 var store = trans.objectStore("ShoppingCart"); 
	 var request = store.put(data); 
	 request.onsuccess = function(e) { 
		 refreshShoppingCart(); 
	 }; 
	 request.onerror = dbError; 
 } 3

3. 删除商品数据

在 Web SQL Database 中需要使用传统的 SQL DELETE 操作删除数据库中表记录。

清单 9. Web SQL Database 删除数据操作
 function deleteDataFromShoppingCart(id){ 
	 console.log("deleteDataFromShoppingCart",id); 
	 db.transaction(function(tx){ 
		 tx.executeSql("DELETE FROM ShoppingCart WHERE Id = ?" , 
			 [id], 
			 function(tx, result){ 
				 refreshShoppingCart(); 
			 }, 
			 dbError 
		 ); 
	 }); 
 }

在 Indexed Database 中,需要使用 API 中 ObjectStore 的 delete 方法,传进 key 值作为参数,删除相应的记录。

清单 10. Indexed Database 删除数据操作
 function deleteDataFromShoppingCart(id){ 
	 console.log("deleteDataFromShoppingCart",id); 
	 var trans = db.transaction(["ShoppingCart"], IDBTransaction.READ_WRITE); 
	 var store = trans.objectStore("ShoppingCart"); 
	 var request = store.delete(id); 
	 request.onsuccess = function(e) { 
		 refreshShoppingCart(); 
	 }; 
	 request.onerror = dbError; 
 }

结束语

本文基于购物车示例详细介绍了 Web SQL Database 和 Indexed Database 的 CRUD 操作,从代码简洁程度来看,Indexed Database 的操作更清晰。但 Web SQL Database 的 操作方式对传统开发人员来说更友好。由于在不同的平台上浏览器对两种客户端数据库的支持程度的差异,分别掌握两种客户端数据库的操作方法还是非常有必要的。 随着 HTML5 规范的发展,相信未来在客户端存储数据将会越来越容易。





文章二,HTML5 内置本地数据库之Sqlite

一、关于HTML5和web本地数据库

SQLite 可以很好的支持关系型数据库所具备的一些基本特征,如标准SQL语法、事物、数据表和索引等,且占用资源较少,可在移动设备上轻松使用。 
HTML5中添加了很多功能,将一些以前必须保存在服务器上的数据转向本地保存,提高了Web应用程序性能的同时还减轻了服务器的负担。然而关于Web SQL Database有一个不太好的消息(来自网络):

我们经常在数据库中处理大量结构化数据,Html5引入Web SQL Database概念,它使用 SQL 来操纵客户端数据库的 API,这些 API 是异步的,规范中使用的是SQLlite,悲剧正是产生于此,Web SQL Database规范页面有着这样的声明

这里写图片描述

This document was on the W3C Recommendation track but specification work has stopped. The specification reached an impasse: all interested implementors have used the same SQL backend (Sqlite), but we need multiple independent implementations to proceed along a standardisation path.

大概意思就是

这个文档曾经在W3C推荐规范上,但规范工作已经停止了。目前已经陷入了一个僵局:目前的所有实现都是基于同一个SQL后端(SQLite),但是我们需要更多的独立实现来完成标准化。

也就是说这是一个废弃的标准了,虽然部分浏览器已经实现

一上来就泼凉水确实不太好 ,但是学习一下总归没有什么坏处的,对吧? 
目前我已知的支持Web SQL Database的浏览器有chrome(估计还有别的,只是我没用到~),然而火狐和IE并不支持。 
W3C目前力推的H5本地数据库是IndexedDB

二、H5 Sqlite数据库三个核心API

opendatabase:使用现有数据库或创建新数据库创建数据库对象

var db = openDatabase('myTel','1.0','test db',1024*100);
//四个参数分别是数据库名 版本 数据库描述 大小
//当该数据库不存在的时候创建并打开数据库,否则直接打开数据库。
//创建的数据库存于本地浏览器的Cache 文件夹。
 
 
  
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

transaction:事务,可根据情况控制事务提交或回滚

db.transaction(callback)
//用作事务处理,来操作数据库

 
 
  
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

executeSql:用于执行SQL查询

db.transaction(function(tx){
    
    tx.executeSql('SQL语句',[参数数组],dataHandler,errorHandler)
})
//executeSql的四个参数:
//1、操作数据库的SQL语句
//2、SQL语句中使用的参数的数组
//3、语句操作成功调用的方法
//4、语句操作失败调用的方法
 
 
  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

关于dataHandler和errorHandler:

function dataHandler(transaction,results);
// 其中,resultsrows属性中保存了查询到的每一条记录,rows.length属性可以获取记录的条数
// 可使用rows[index]或rows[item]来单独取到某条记录
function errorHandler(transaction,errMsg);
 
 
  
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

三、一个例子

下面使用一个比较完整的例子来演示。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Sqlite</title>
</head>
<body onload="init()">
    <!-- 创建数据库对象、使用事务进行数据库操作 -->
    姓名:<input type="text" id="name"/>
    电话:<input type="text" id="tel" />
    <input type="button" value="保存" onclick="saveData()" />
    <hr/>
    <input type="button" onclick="showAllData()" value="显示全部">
            <input type="button" onclick="delAllData()" value="清空全部">
    <hr/>
    <table id="datatable" border="1">

    </table>
    <p id="'msg"></p>

</body>
<script type="text/javascript">
    var datatable = null;
    var db = openDatabase('myTel','1.0','test db',1024*100);//数据库名 版本 数据库描述 大小

    function init(){
     //初始化工作
        datatable = document.getElementById('datatable');
        showAllData();
    }
    function removeAllData(){
     //移除页面上展示的数据
        for(var i = datatable.childNodes.length-1;i>=0;i--){
            datatable.removeChild(datatable.childNodes[i]);
        }
        var tr = document.createElement('tr');
        var th1 = document.createElement('th');
        var th2 = document.createElement('th');
        th1.innerHTML = '姓名';
        th2.innerHTML = '电话';
        tr.appendChild(th1);
        tr.appendChild(th2);
        datatable.appendChild(tr);

    }
    function showData(row){
     //显示数据
        var tr = document.createElement('tr');
        var td1 = document.createElement('td');
        td1.innerHTML = row.name;
        var td2 = document.createElement('td');
        td2.innerHTML = row.tel;
        tr.appendChild(td1);
        tr.appendChild(td2);
        datatable.appendChild(tr);
    }
    function showAllData(){
     //显示所有数据

        db.transaction(function (tx){
     
            tx.executeSql('create table if not exists TelData(name TEXT,tel TEXT)',[],function(tx,res){
     

                },function(tx,err){
     
                    alert(err.message)
                });

            tx.executeSql('select * from TelData',[],function(tx,result){
     
                removeAllData();
                for(var i = 0 ;i<result.rows.length;i++){
                    showData(result.rows.item(i));
                }
            })
        })
    }
    function saveData(){
     //保存数据
        var name = document.getElementById('name').value;
        var tel = document.getElementById('tel').value;
        addData(name,tel);
        showAllData();
    }
    function addData(name,tel){
     //添加数据
        db.transaction(function(tx){
     
            tx.executeSql('insert into TelData values(?,?)',[name,tel],function(tx,rs){
     
                alert('yes');
            },
            function (tx,err){
     
                alert(err.source +'===='+err.message);
            })
        })
    }
    function  delAllData(){
     //删除所有数据
        db.transaction(function(tx){
     
            tx.executeSql('delete from TelData',[],function(tx,res){
     
                alert('删除成功~');
            },function (tx,err){
     
                alert('删除失败'+err.message);
            })
        })
        showAllData();
    }
</script>
</html>
 
 
  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98

执行结果:

添加一条数据:

这里写图片描述

运行结果:

这里写图片描述

再添两条:

这里写图片描述

关闭浏览器后重新打开:

这里写图片描述

全部清空之后

这里写图片描述

文章三,SQLLite本地数据库

本地数据库支持比较少,不够规范,建议少用

本地数据库是H5之后出现的SQLLite数据库,可以通过SQL语言来访问文件型SQL数据库

使用数据库的步骤:

  1. 创建访问数据库
  2. 使用事务处理

创建访问数据库对象 
博客出处 
var db= openDatabase(‘mydb’,’1.0’,’TestDB’,2*1024*1024)

第一个参数:数据库名

第二个参数:版本号

第三个参数:数据库描述

第四个参数:数据库大小

该方法返回创建后的数据库访问对象,如果该数据库不存在,则创建数据库

用executeSql执行查询

transaction.executeSql(sqlquery,[],dataHandler,errorHandler);

第一个参数:查询语句

第二个参数:查询语句中的?

eg: transaction.executeSql(“UPDATE people set age=? which name=?”,[age,name])

第三个参数:执行成功时调用的回调函数

function dataHandler(transaction,result){//回调函数内容}

第四个参数:执行失败时调用的回调函数

function errorHandler(transaction,erromsg){//alert(“执行出错!”)}

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Sqlite</title>
</head>
<body onload="init()">
    <!-- 创建数据库对象、使用事务进行数据库操作 -->
    姓名:<input type="text" id="name"/>
    电话:<input type="text" id="tel" />
    <input type="button" value="保存" onclick="saveData()" />
    <hr/>
    <input type="button" onclick="showAllData()" value="显示全部">
            <input type="button" onclick="delAllData()" value="清空全部">
    <hr/>
    <table id="datatable" border="1">

    </table>
    <p id="'msg"></p>

</body>
<script type="text/javascript">
    var datatable = null;
    var db = openDatabase('myTel','1.0','test db',1024*100);//数据库名 版本 数据库描述 大小

    function init(){
     //初始化工作
        datatable = document.getElementById('datatable');
        showAllData();
    }
    function removeAllData(){
     //移除页面上展示的数据
        for(var i = datatable.childNodes.length-1;i>=0;i--){
            datatable.removeChild(datatable.childNodes[i]);
        }
        var tr = document.createElement('tr');
        var th1 = document.createElement('th');
        var th2 = document.createElement('th');
        th1.innerHTML = '姓名';
        th2.innerHTML = '电话';
        tr.appendChild(th1);
        tr.appendChild(th2);
        datatable.appendChild(tr);

    }
    function showData(row){
     //显示数据
        var tr = document.createElement('tr');
        var td1 = document.createElement('td');
        td1.innerHTML = row.name;
        var td2 = document.createElement('td');
        td2.innerHTML = row.tel;
        tr.appendChild(td1);
        tr.appendChild(td2);
        datatable.appendChild(tr);
    }
    function showAllData(){
     //显示所有数据

        db.transaction(function (tx){
     
            tx.executeSql('create table if not exists TelData(name TEXT,tel TEXT)',[],function(tx,res){
     

                },function(tx,err){
     
                    alert(err.message)
                });

            tx.executeSql('select * from TelData',[],function(tx,result){
     
                removeAllData();
                for(var i = 0 ;i<result.rows.length;i++){
                    showData(result.rows.item(i));
                }
            })
        })
    }
    function saveData(){
     //保存数据
        var name = document.getElementById('name').value;
        var tel = document.getElementById('tel').value;
        addData(name,tel);
        showAllData();
    }
    function addData(name,tel){
     //添加数据
        db.transaction(function(tx){
     
            tx.executeSql('insert into TelData values(?,?)',[name,tel],function(tx,rs){
     
                alert('yes');
            },
            function (tx,err){
     
                alert(err.source +'===='+err.message);
            })
        })
    }
    function  delAllData(){
     //删除所有数据
        db.transaction(function(tx){
     
            tx.executeSql('delete from TelData',[],function(tx,res){
     
                alert('删除成功~');
            },function (tx,err){
     
                alert('删除失败'+err.message);
            })
        })
        showAllData();
    }
</script>
</html>

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/function__/article/details/60588367

智能推荐

python 学习4 列表、元组和字符串_字符串、列表、元组和集合都是序列,其中每个元素都有编号,因此都可以通过索引对其_啦啦啦-1222的博客-程序员宝宝

一、序列序列,指的是一块可存放多个值的连续内存空间,这些值按一定顺序排列,可通过每个值所在位置的编号(称为索引)访问它们。为了更形象的认识序列,可以将它看做是一家旅店,那么店中的每个房间就如同序列存储数据的一个个内存空间,每个房间所特有的房间号就相当于索引值。也就是说,通过房间号(索引)我们可以找到这家旅店(序列)中的每个房间(内存空间)。在 Python 中,序列类型包括字符串、列表、元组、集合和字典,这些序列支持以下几种通用的操作,但比较特殊的是,集合和字典不支持索引、切片、相加和相乘操作。字符

Yii框架和Vue的完美结合完成前后端分离项目_weixin_34061555的博客-程序员宝宝

背景说明本文假设你对Yii和Vue都比较熟悉,至少都在项目里用过,另外笔者新人,以后不定时放一些干货,欢迎程序媛关注Yii是一个PHP全端框架,典型的mvc的项目结构,后端接口都是一个控制器里放了很多的action,每个action都是一个接口,可以返回JSON,也可以render出一个html5页面,这些页面就是mvc的view,结构紧凑强耦合。Vue是一个前端框架,主要思想就是SP...

MacBook/MacOS/Mac OS 关于启动/停止/重启服务(进程/程序)的命令_macos 重启服务_liaowenxiong的博客-程序员宝宝

文章目录查看某个进程的信息命令一命令二停止某个进程启动某个进程查看某个进程是否启动查看某个进程的信息命令一查看 sshd 相关的进程:liaowenongdeair:etc root# ps auwx|grep sshdroot 1987 1.0 0.0 4285816 724 s000 S+ 2:37下午 0:00.00 grep sshdliaowenongdeair:etc root# ps auwx|grep sshroot

vue中axios数据请求封装_大把小米的博客-程序员宝宝

anxious数据请求封装以及拦截器 1 /* 做数据请求封装 */ 2 import axios from 'axios' 3 // 1. axios默认配置 4 // axios.defaults.baseURL = 'http://localhost:3000'; 5 // axios.defaults.headers.common['Authorization'...

随便推点

Lambda表达式-使用说明_lambda () -> true;_Luke_卢的博客-程序员宝宝

公众号:    jdk8已经发布4年,其中有一个特性:Lambda,它是一个令开发者便捷开发的一种方式,Lambda Expression (Lambda表达式)是为了让java提供一种面向函数编程,原本在jdk8之前只支持面向对象编程,而函数式编程则是对行为的抽象(将行为作为一个参数进行传递),接下来通过例子来说明:这是一个线程对象,传入匿名内部类的例子:new...

《企业破局的34个锦囊》之领导者必备的技术思维_hzbooks的博客-程序员宝宝

本文简要总结本书的技术部分—第11~16章。为了在数字化时代取得业务成效,这是我们认为所有领导者都需要具备的技术思维的最小集合。1.技术卓越至关重要通过技术卓越提升软件内部质量,使软件...

CSS使图片变模糊,亲测非常好用_lxw1844912514的博客-程序员宝宝

文章目录效果图html代码css代码效果图html代码&lt;div class="blur container"&gt; &lt;div&gt; &lt;img src="https://timgsa.baidu.com/timg?image&amp;quality=80&amp;size=b9999_10000&amp;sec=1548676269108&amp;di=64d110c6c0c15d9bc77c7ffd4f049f1b&amp;imgtype=0&amp;s...

signature=ddd5150b1da9eebcbab4d57cf9321a88,Lung Cancer Signature Biomarkers: tissue specific semanti..._贾华京的博客-程序员宝宝

摘要:The tissue-specific Unigene Sets derived from more than one million expressed sequence tags (ESTs) in the NCBI, GenBank database offers a platform for identifying significantly and differentially e...

3D打印材料的发展现状(1)_weixin_34077371的博客-程序员宝宝

材料是3D打印的物质基础,也是当前制约3D打印发展的瓶颈。3D打印材料 3D打印材料是3D打印技术发展的重要物质基础,材料的发展对于3D打印的发展有重要的作用。 目前,3D打印材料主要包括工程塑料、光敏树脂、橡胶类材料、金属材料和陶瓷材料。此外,彩色石膏材料、人造骨粉、细胞生物原料以及砂糖等食品材料也在3D打印领域得到应用。 3D打印所用原材料都是专门...

推荐文章

热门文章

相关标签