Web SQL Database的基本使用方法

本文详细介绍了如何使用WebSQL在浏览器环境中创建、管理和查询数据库。包括检查浏览器支持情况、打开数据库、开始事务处理、执行SQL语句及处理执行结果等步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

      1. 打开数据库
      2. 开始事务处理
      3. 执行SQL
      4. 处理SQL的执行结果

        首先:检查是否支持Web SQL Database
        if(window.openDatabase==undefined){
      alert("浏览器不支持Web Database!");
      return;
        }

        第二:打开数据库
        window.openDatabase(数据库名,版本号,显示名,预计占用空间);
        数据库名:指定数据库的名称
        版本号:指定数据模式的版本号
        显示名:调试时候使用的数据库略称
        预计占用空间:以字节单位指定数据库预计会占用的空间
        db=window.openDatabase("testdb","1.0","sample",1024*1024);

        第三:开始事务处理
        打开数据库之后,在进行任何数据库操作时调用transaction()方法。在transaction()方法的callback函数内执行具体的SQL
        transaction
        (Database对象).transaction(callback,onError,onSuccess);
        callback:事务处理内执行的处理
        onError:事务处理发生错误时候的处理
        onSuccess:事务处理成功的处理
      例如
         db.transaction(function(txt)){
      //事务处理中执行的处理
         }

        第四:执行SQL
        在事务处理方法中执行SQL。调用callback函数参数(tx)的方法来执行SQL
        (SQLTransaction对象).executeSql(sql,args,onSuccess,onError);
        上述参数的具体含义
        sql:指定的SQL语句
        args:替换SQL中?
        onSuccess:成功执行SQL时候的处理
        onError:SQL执行失败时候的处理
        
        db.transaction(function(tx)){
              var sec=new Date().getTime();
              var str=new Date().toString();
      tx.executeSql("insert into table(sec,str) values(?,?)",[sec,str]);
        }
        
         
        第五:处理SQL的执行结果
        处理SELECT语句的执行结果再onSuccess()函数中
        function onSuccess(tx,resultSet){
        }
        tx:获得SQL Transaction对象
        resultSet:获得SQL ResultSet对象

        SQL ResultSet对象包含的属性
        insertId:执行INSERT语句返回的ID
        rowsAffected:执行SQL语句返回的处理行数
        rows:执行SELECT语句返回的结果集合
        
        另外rows中含有如下方法和属性
        item(index): 指定index从结果集合中取出记录
        length :获得记录数

        db.transaction(function(tx)){
           tx.executeSql("select * from time",[],function(tx,rs){
      //处理并显示执行结果
              for(var i=0;i<rs.rows.length;i++){
          var row=rs.rows.item(i);
                  document.write(row.str+"<br>");
              }    
        });
        }

        

        
<?php $link=mysqli_connect("localhost","user","123456","database","3307"); if(!empty($_POST["tijiao"])) { //$sql="delete from xxnews where ID=".$_GET["dID"]; //$rs=mysqli_query($link,$sql); $title=$_POST["title"]; $author=$_POST["author"]; $newsDate=$_POST["newsDate"]; $source=$_POST["source"]; $content=$_POST["content"]; $sql="update from xxnews where ID=".$_POST["uID"]; $rs=mysqli_query($link,$sql); //$link=mysqli_connect("localhost","user","123456","database","3307"); // $sql="update xxnews set title='".$title."',author='".$author."',newsDate='".$newsDate."',source='".$source."',content='".$content."' where ID=".$_GET["uID"]; // $rs=mysqli_query($link,$sql); } ?> <div class="head1"> XX新闻中心 </div> <?php $link=mysqli_connect("localhost","user","123456","database","3307"); $sql="SELECT * FROM xxnews WHERE ID = ".$_POST["ID"]; $rs=mysqli_query($link,$sql); while($rows=mysqli_fetch_array($rs)) { echo "<form action='update.php?uID=".$rows["ID"]."' method='post' target='_blank'>"; echo "<div class='head2'>"; echo "标题:<input type='text' name='title' value='".$rows["title"]."' />"; echo "</div>"; echo "<div class='head3'>"; echo "作者:<input type='text' name='author' value='".$rows["author"]."' />       "; echo "时间:"; date_default_timezone_set('PRC'); echo "<input type='text' name='newsDate' value='".date('Y-m-d', time())."' />"; echo "        来源:<input type='text' name='source' value='".$rows["source"]."' />       <input type='submit' name='tijiao' value='修改新闻' class='tijiao' />"; echo "</div>"; echo "<div class='content'>"; echo "<textarea class='content1' name='content'>"; echo $rows["content"]; echo "</textarea>"; echo "</div>"; echo "</form>"; } ?> <div class="footer"> XX新闻<br /> 地址:广东省肇庆市州区广东工商职业技术大学星湖校区<br /> 电话:123456789 </div>这段代码有什么问题
06-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值