Не специфичное для pdo решение, которое может быть или не быть достаточным в вашем случае:
- создать: память: база данных
- Прикрепить существующий файл базы данных
- СОЗДАТЬ ТАБЛИЦУ ... КАК ВЫБРАТЬ * ИЗ ...
- Отсоединение файла базы данных
редактировать: пример
Сначала пример базы данных, хранящейся в 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();
}
Теперь у нас есть: memory: база данных и мы хотим передать таблицу 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');
Готово. Но давайте посмотрим на таблицу sqlite_master
foreach($pdo->query('SELECT sql FROM sqlite_master') as $row) {
echo $row['sql'];
}
это печатает
CREATE TABLE bar(x INT,y,z)
Декларация INTEGER PRIMARY KEY ASC потеряна. Может быть достаточно, хотя ....