Heim > Web-Frontend > H5-Tutorial > Detaillierte HTML5-Einführung in die Web SQL-Datenbank

Detaillierte HTML5-Einführung in die Web SQL-Datenbank

黄舟
Freigeben: 2017-07-18 14:02:37
Original
2285 Leute haben es durchsucht

Die Web SQL-Datenbank-API ist nicht Teil der HTML5-Spezifikation, sondern eine unabhängige Spezifikation, die eine Reihe von APIs für die Verwendung von SQL zum Betrieb von Client-Datenbanken einführt.

Kernmethoden

OpenDatabase – Erstellen Sie ein Datenbankobjekt unter Verwendung einer vorhandenen Datenbank oder einer neuen Datenbank

Transaktion – Fähigkeit, eine Sache zu steuern , und führen Sie basierend auf dieser Situation ein Commit oder Rollback durch

executeSql – führt die eigentliche SQL-Anweisung aus

öffnet die Datenbank


//用openDatabase()方法打开已存在的数据库,如果数据库不存在,则会创建一个新的数据库
var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);
Nach dem Login kopieren

Die Beschreibung der fünf Parameter, die der openDatabase()-Methode entsprechen:

  1. Datenbankname

  2. Versionsnummer

  3. Beschreibungstext

  4. Datenbankgröße (Byte)

  5. Rückruf erstellen (optional)

Der fünfte Parameter, der Erstellungsrückruf, wird aufgerufen, nachdem die Datenbank erstellt wurde.

Tabelle erstellen


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)');
});
Nach dem Login kopieren

Daten einfügen


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.cnblogs.com")');
});
Nach dem Login kopieren

Sie können Daten auch mithilfe dynamischer Werte einfügen


//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 (?, ?)', [e_id, e_log]);
});
Nach dem Login kopieren

Daten lesen


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.cnblogs.com")');
});
 
db.transaction(function (tx) {
   tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) {
      var len = results.rows.length;
      msg = "<p>查询记录条数: " + len + "</p>";
      document.querySelector(&#39;#status&#39;).innerHTML +=  msg;
    
      for (i = 0; i < len; i++){
          msg = "<p><b>" + results.rows[i].log + "</b></p>";
      }
    
   }, null);
});
Nach dem Login kopieren

Datensätze löschen


db.transaction(function (tx) {
    tx.executeSql(&#39;DELETE FROM LOGS  WHERE id=1&#39;);
});
Nach dem Login kopieren

Das Löschen von Daten kann auch dynamisch erfolgen


db.transaction(function(tx) {
    tx.executeSql(&#39;DELETE FROM LOGS WHERE id=?&#39;, [id]);
});
Nach dem Login kopieren

Datensätze aktualisieren


tx.executeSql("UPDATE CC SET logname=&#39;www.baidu.com&#39; WHERE id=2");
Nach dem Login kopieren

Aktualisierungsdaten können auch dynamisch sein


tx.executeSql("UPDATE CC SET logname=&#39;www.baidu.com&#39; WHERE id=?", [id]);
Nach dem Login kopieren

Hinweis: Löschen und Ändern können nicht in derselbenexecuteSql wie die Tabellenerstellungsanweisung platziert werden. Es ist am besten, sie separat zu schreiben

Das Folgende ist erstellte Datenbank

HTML5-Web SQL数据库0

Das obige ist der detaillierte Inhalt vonDetaillierte HTML5-Einführung in die Web SQL-Datenbank. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage