HTML5 - Base de données Web SQL
L'API Web SQL Database ne fait pas partie de la spécification HTML5, mais il s'agit d'une spécification distincte qui introduit un ensemble d'API pour manipuler les bases de données côté client à l'aide de SQL.
Je suppose que vous êtes un grand développeur Web et si tel est le cas, vous connaissez sans aucun doute les concepts SQL et SGBDR. Si vous souhaitez toujours avoir une session avec SQL, vous pouvez suivre notre didacticiel SQL .
Web SQL Database fonctionnera dans la dernière version de Safari, Chrome et Opera.
Les méthodes de base
Il existe trois méthodes de base définies dans la spécification que je vais couvrir dans ce didacticiel -
openDatabase - Cette méthode crée l'objet de base de données en utilisant la base de données existante ou en en créant une nouvelle.
transaction - Cette méthode nous donne la possibilité de contrôler une transaction et d'effectuer une validation ou une annulation en fonction de la situation.
executeSql - Cette méthode est utilisée pour exécuter une requête SQL réelle.
Ouverture de la base de données
La méthode openDatabase s'occupe d'ouvrir une base de données si elle existe déjà, cette méthode la créera si elle n'existe pas déjà.
Pour créer et ouvrir une base de données, utilisez le code suivant -
var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);
La méthode ci-dessus a pris les cinq paramètres suivants -
- Nom de la base de données
- Numéro de version
- Description textuelle
- Taille de la base de données
- Rappel de création
Le dernier et le 5e argument, le rappel de création sera appelé si la base de données est en cours de création. Sans cette fonctionnalité, cependant, les bases de données sont toujours créées à la volée et correctement versionnées.
Exécuter des requêtes
Pour exécuter une requête, vous utilisez la fonction database.transaction (). Cette fonction a besoin d'un seul argument, qui est une fonction qui s'occupe d'exécuter réellement la requête comme suit -
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)');
});
La requête ci-dessus créera une table appelée LOGS dans la base de données «mydb».
Opération INSERT
Pour créer des entrées dans la table, nous ajoutons une requête SQL simple dans l'exemple ci-dessus comme suit -
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, "foobar")');
tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "logmsg")');
});
Nous pouvons passer des valeurs dynamiques lors de la création en entrant comme suit -
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];
});
Ici e_id et e_log sont des variables externes, et executeSql mappe chaque élément de l'argument du tableau aux "?".
LIRE l'opération
Pour lire les enregistrements déjà existants, nous utilisons un rappel pour capturer les résultats comme suit -
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, "foobar")');
tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "logmsg")');
});
db.transaction(function (tx) {
tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) {
var len = results.rows.length, i;
msg = "<p>Found rows: " + len + "</p>";
document.querySelector('#status').innerHTML += msg;
for (i = 0; i < len; i++) {
alert(results.rows.item(i).log );
}
}, null);
});
Exemple final
Alors enfin, gardons cet exemple dans un document HTML5 à part entière comme suit et essayons de l'exécuter avec le navigateur Safari.
<!DOCTYPE HTML>
<html>
<head>
<script type = "text/javascript">
var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);
var msg;
db.transaction(function (tx) {
tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)');
tx.executeSql('INSERT INTO LOGS (id, log) VALUES (1, "foobar")');
tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "logmsg")');
msg = '<p>Log message created and row inserted.</p>';
document.querySelector('#status').innerHTML = msg;
})
db.transaction(function (tx) {
tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) {
var len = results.rows.length, i;
msg = "<p>Found rows: " + len + "</p>";
document.querySelector('#status').innerHTML += msg;
for (i = 0; i < len; i++) {
msg = "<p><b>" + results.rows.item(i).log + "</b></p>";
document.querySelector('#status').innerHTML += msg;
}
}, null);
});
</script>
</head>
<body>
<div id = "status" name = "status">Status Message</div>
</body>
</html>
Cela produira le résultat suivant -