PHP/SQLite - 将表从磁盘复制到内存

9 php sqlite

我的硬盘驱动器(file.db)上有一个带有5个表的sqlite3数据库.我想将这些表中的3个复制到内存数据库(:memory :).

有没有一种简单的方法可以使用PHP5的PDO格式?

Vol*_*erK 12

在您的情况下,不是特定于pdo的解决方案可能或不充分:

  • 创建一个:内存:数据库
  • 附加现有数据库文件
  • CREATE TABLE ... AS SELECT*FROM ...
  • 分离数据库文件

编辑:示例
首先是存储在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声明都将丢失.可能足够......

  • 将添加一个例子 (3认同)