欢迎来到DIVCSS5查找CSS资料与学习DIV CSS布局技术!
    WebSQL数据库API并不是HTML5规范的一部分,但是它是一个独立的规范,引入了一组使用SQL操作客户端数据库的APIs。
 
    如果你是一个Web后端程序员,应该很容易理解SQL的操作。
 
    你也可以参考我们的SQL教程,了解更多数据库操作知识。
 
    WebSQL数据库可以在最新版的Safari,Chrome和Opera浏览器中工作。
 
    核心方法
 
    以下是规范中定义的三个核心方法:
 
    openDatabase:这个方法使用现有的数据库或者新建的数据库创建一个数据库对象。
 
    transaction:这个方法让我们能够控制一个事务,以及基于这种情况执行提交或者回滚。
 
    executeSql:这个方法用于执行实际的SQL查询。
 
    打开数据库
 
    我们可以使用openDatabase()方法来打开已存在的数据库,如果数据库不存在,则会创建一个新的数据库,使用代码如下:
 
    vardb=openDatabase('mydb','1.0','TestDB',2*1024*1024);
 
    openDatabase()方法对应的五个参数说明:
 
    数据库名称
 
    版本号
 
    描述文本
 
    数据库大小
 
    创建回调
 
    第五个参数,创建回调会在创建数据库后被调用。
 
    执行查询操作
 
    执行操作使用database.transaction()函数:
var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);
db.transaction(function (tx) {  
   tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)');
});
 
    上面的语句执行后会在'mydb'数据库中创建一个名为LOGS的表。
 
    插入数据
 
    在执行上面的创建表语句后,我们可以插入一些数据:
 
var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);
db.transaction(function (tx) {
   tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)');
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (1, "菜鸟教程")');
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "www.runoob.com")');
});
 
    我们也可以使用动态值来插入数据:
var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);
db.transaction(function (tx) {  
  tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)');
  tx.executeSql('INSERT INTO LOGS (id,log) VALUES (?, ?)', [e_id, e_log]);
});
 
    实例中的e_id和e_log是外部变量,executeSql会映射数组参数中的每个条目给"?"。
 
    读取数据
 
    以下实例演示了如何读取数据库中已经存在的数据:
 
var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);
 
db.transaction(function (tx) {
   tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)');
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (1, "菜鸟教程")');
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "www.runoob.com")');
});
 
db.transaction(function (tx) {
   tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) {
      var len = results.rows.length, i;
      msg = "<p>查询记录条数: " + len + "</p>";
      document.querySelector('#status').innerHTML +=  msg;
    
      for (i = 0; i < len; i++){
         alert(results.rows.item(i).log );
      }
    
   }, null);
});

如需转载,请注明文章出处和来源网址:http://www.divcss5.com/html/h63118.shtml