我的硬盘驱动器(file.db)上有一个带有5个表的sqlite3数据库.我想将这些表中的3个复制到内存数据库(:memory :).
有没有一种简单的方法可以使用PHP5的PDO格式?
Vol*_*erK 12
在您的情况下,不是特定于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();
}
Run Code Online (Sandbox Code Playgroud)
现在我们有一个:内存:数据库并希望转移表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');
Run Code Online (Sandbox Code Playgroud)
完成.但是让我们来看看sqlite_master表
foreach($pdo->query('SELECT sql FROM sqlite_master') as $row) {
echo $row['sql'];
}
Run Code Online (Sandbox Code Playgroud)
这打印
CREATE TABLE bar(x INT,y,z)
Run Code Online (Sandbox Code Playgroud)
在INTEGER PRIMARY KEY ASC声明都将丢失.可能足够......
| 归档时间: |
|
| 查看次数: |
8887 次 |
| 最近记录: |