如何在PHP中选择与PDO一起使用的MySQL数据库?

如何在PHP中选择与PDO一起使用的MySQL数据库?,第1张

如何在PHP中选择与PDO一起使用的MySQL数据库

通常,您在连接时会在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 databasetry {    $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作为更改数据库的副作用,那么它应该可以工作。

但这不起作用-会收到错误消息“无效的参数号”,该错误指示未模拟的准备好的语句仍然有效。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5044380.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-15
下一篇 2022-11-15

发表评论

登录后才能评论

评论列表(0条)

保存