数据库
首页 > 数据库> > javascript-从sqlite数据库读取信息,语法?如何在html5 webapp中使用它?

javascript-从sqlite数据库读取信息,语法?如何在html5 webapp中使用它?

作者:互联网

我有一个正在构建的Webapp,并且刚开始使用SQLite.我已经能够创建表单,打开我创建的数据库,创建表和所需的字段以及在字段中输入数据.

现在,我尝试使用SELECT语句读回数据,以将其显示在屏幕上以及列的列表中.我只是不知道javascriptHTML5中的SELECT statemnt的语法

‘SELECT * FROM MyTable’…我知道可以做到的,只需要一些帮助就可以将结果显示在屏幕上.

我从这个开始.

   

var db = window.openDatabase('TabOrder', '', 'Bar Tab Orders', 2500000);

 function insertDrinks(category, drinkname, our_cost, cust_cost){
  db.transaction(function(tx){
   tx.executeSql('INSERT INTO Drinks (category, drinkname, our_cost, cust_cost) VALUES (?, ?, ?, ?)', [category, drinkname, out_cost, cust_cost]);
  });
 }

 $(document).ready(function() {
  db.transaction(function(tx) {
   tx.executeSql('CREATE TABLE IF NOT EXISTS Drinks(id INTEGER PRIMARY KEY Autonumber, category TEXT, drinkname TEXT, our_cost FLOAT(6,2), cust_cost FLOAT(7,2))', []);
  });
 });
 

我以后有这个.



 View Cat / Drink List
 
 function readDrinks(id, category, drinkname, our_cost, cust_cost){
  db.transaction(function(tx) {
   tx.executeSql('SELECT * FROM Drinks', [id, category, drinkname, our_cost, cust_cost]);
  });
 document.write(id, category + " are the categories.");
 }
 


我只是试图将其拼凑在一起,除了基本的SQL之外,我一无所知.

非常感谢您的任何帮助…这是针对客户端DB,而不是连接到Web的用户.

谢谢….

解决方法:

请参阅the spec和此Apple tutorial.简而言之,您需要添加数据和错误回调.另外,您应该传递一个空数组(或null),因为查询没有参数.

db.transaction(function(tx) {
   tx.executeSql('SELECT * FROM Drinks', 
                 [],
                 function(tx, results)
                 {
                   // results is a http://dev.w3.org/html5/webdatabase/#sqlresultset .  
                   // It has insertId, rowsAffected, and rows, which is
                   // essentially (not exactly) an array of arrays. 
                 },
                 function(tx, error)
                 {

                 }
   );
});

由您决定使用命名函数还是匿名函数.

编辑:我在http://jsfiddle.net/WcV6Y/7/进行了工作演示.已在Chrome 5.0.375.70中测试.

标签:javascript,web-sql,html5,relational-database,web-applications
来源: https://codeday.me/bug/20191012/1898963.html