SQLite3::exec

(PHP 5 >= 5.3.0, PHP 7, PHP 8)

SQLite3::execFührt eine ergebnislose Abfrage gegen den Datenbank-Server aus

Beschreibung

public SQLite3::exec ( string $query ) : bool

Führt eine ergebnislose Abfrage gegen den Datenbank-Server aus.

Hinweis: SQLite3 muss möglicherweise während der Ausführung von Abfragen » temporäre Dateien erzeugen, so dass die entsprechenden Verzeichnisse beschreibbar sein müssen.

Parameter-Liste

query

Die auszuführende SQL-Anfrage (normalerweise eine INSERT-, UPDATE- oder DELETE-Anweisung)

Rückgabewerte

Gibt true zurück, wenn die Anfrage erfolgreich war; anderenfalls false

Beispiele

Beispiel #1 SQLite3::exec()-Beispiel

<?php
$db 
= new SQLite3('mysqlitedb.db');

$db->exec('CREATE TABLE bar (bar STRING)');
?>

add a note add a note

User Contributed Notes 1 note

up
15
alexandre dot schmidt at gmail dot com
8 years ago
I was getting "database locked" all the time until I found out some features of sqlite3 must be set by using SQL special instructions (i.e. using PRAGMA keyword). For instance, what apparently solved my problem with "database locked" was to set journal_mode to 'wal' (it is defaulting to 'delete', as stated here: https://www.sqlite.org/wal.html (see Activating  And Configuring WAL Mode)).

So basically what I had to do was creating a connection to the database and setting journal_mode with the SQL statement. Example:

<?php
$db
= new SQLite3('/my/sqlite/file.sqlite3');
$db->busyTimeout(5000);
// WAL mode has better control over concurrency.
// Source: https://www.sqlite.org/wal.html
$db->exec('PRAGMA journal_mode = wal;');
?>

Hope that helps.
To Top