Non una soluzione specifica-PDO che può o non può essere sufficiente nel tuo caso:
- creare una: la memoria: banca dati
- Attach il file di database esistente
- CREATE TABLE ... AS SELECT * FROM ...
- Detach il file di database
edit: un esempio
primo un database di esempio memorizzato in mydb.sq3
<?php
$pdo = new PDO('sqlite:mydb.sq3');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$pdo->exec('CREATE TABLE foo(x INTEGER PRIMARY KEY ASC, y, z)');
$stmt = $pdo->prepare("INSERT INTO foo (x,y,z) VALUES (:x,:y,:z)");
$stmt->bindParam(':x', $x);
$stmt->bindParam(':y', $y);
$stmt->bindParam(':z', $z);
for($x=0; $x<100; $x++) {
$y = $x*2;
$z = $x*2+1;
$stmt->execute();
}
ora abbiamo una: la memoria: database e si desidera trasferire la tabella foo
<?php
$pdo = new PDO('sqlite::memory:');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$pdo->exec('ATTACH "mydb.sq3" as filedb');
$pdo->exec('CREATE TABLE bar AS SELECT * FROM filedb.foo');
$pdo->exec('DETACH filedb');
Fatto. Ma diamo uno sguardo al tavolo sqlite_master
foreach($pdo->query('SELECT sql FROM sqlite_master') as $row) {
echo $row['sql'];
}
questa stampa
CREATE TABLE bar(x INT,y,z)
Il dichiarazione INTEGER PRIMARY KEY ASC è perduto. Potrebbe essere sufficiente però ....
Sto anche cercando di fare questo per il mio test di unità. Il file db sqlite avrà tutti i dati di test. Ma non voglio che i test cambino, quindi voglio copiare il db in: memory: prima di eseguire i test su di esso. Solo dando una ragione qualcuno potrebbe voler fare questo. – andho