如何在PHP中选择与PDO一起使用的MySQL数据库?
我想在创建PHP PDO对象之后选择要使用的MySQL数据库。我该怎么做呢?
// create PDO object and connect to MySQL$dbh = new PDO( 'mysql:host=localhost;', 'name', 'pass' );
// create a database named 'database_name'
// select the database we just created ( this does not work )
$dbh->select_db( 'database_name' );
有等于mysqli :: select_db的PDO吗?
也许我试图不当使用PDO?请帮助或解释。
我不应该使用PDO创建新数据库吗?我知道使用PDO的大部分好处会因为很少使用的操作而丢失,该操作不会插入数据,例如CREATE
DATABASE,但是不得不使用其他连接创建数据库,然后创建PDO连接进行其他调用似乎很奇怪。
回答:
通常,您在连接时会在DSN中指定数据库。但是,如果您要创建一个新数据库,则显然您不能在创建该数据库之前将其指定为DSN。
您可以使用以下USE
语句更改默认数据库:
$dbh = new PDO("mysql:host=...;dbname=mysql", ...);$dbh->query("create database newdatabase");
$dbh->query("use newdatabase");
随后的CREATE TABLE
语句将在您的新数据库中创建。
来自@Mike的评论:
当您像这样切换数据库时,似乎会强制PDO模拟准备好的语句。将PDO ::
ATTR_EMULATE_PREPARES设置为false,然后尝试使用另一个数据库将失败。
我只是做了一些测试,但我看不到这种情况。更改数据库仅在服务器上进行,并且不会更改客户端中PDO的配置。这是一个例子:
<?php// connect to database
try {
$pdo = new PDO('mysql:host=huey;dbname=test', 'root', 'root');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
} catch(PDOException $err) {
die($err->getMessage());
}
$stmt = $pdo->prepare("select * from foo WHERE i = :i");
$result = $stmt->execute(array("i"=>123));
print_r($stmt->fetchAll(PDO::FETCH_ASSOC));
$pdo->exec("use test2");
$stmt = $pdo->prepare("select * from foo2 WHERE i = :i AND i = :i");
$result = $stmt->execute(array("i"=>456));
print_r($stmt->fetchAll(PDO::FETCH_ASSOC));
如果您说的是真的,那么这应该可以正常工作。仅当PDO ::
ATTR_EMULATE_PREPARES为true时,PDO才能多次使用给定的命名参数。因此,如果您说将此属性设置为true作为更改数据库的副作用,那么它应该可以工作。
但这不起作用-会收到错误消息“无效的参数号”,该错误指示未模拟的准备好的语句仍然有效。
以上是 如何在PHP中选择与PDO一起使用的MySQL数据库? 的全部内容, 来源链接: utcz.com/qa/400828.html