繁体   English   中英

无法使用mysqli,mysqli_connect或PDO连接到数据库

[英]Cannot connect to Database with mysqli, mysqli_connect, or PDO

我曾尝试用php连接到我的数据库,但完全失败了;(我一直收到类似的信息:“ PHP注意:未定义的变量:conn”我尝试了以下每种方法:

$conn = new PDO("mysql:host=localhost;dbname=ar_data", 'login', 'pass');
$conn = mysqli('localhost', 'login', 'pass', 'dbname') or die("error" :.mysqli_connect_error());
$conn = mysqli_connect('localhost', 'login', 'pass', 'ar_data') or die("error" :.mysqli_connect_error());

在我尝试了最后一个之后,我在var_dump($conn)上得到了这个:

object(mysqli)#17 (18) { ["affected_rows"]=> int(0) ["client_info"]=> string(78) 
"mysqlnd 5.0.8-dev - 20102224 - $Id: SOME_VALUE_I_AM_CENSORING $" 
["client_version"]=> int(50008) ["connect_errno"]=> int(0) ["connect_error"]=> NULL 
["errno"]=> int(0) ["error"]=> string(0) "" ["field_count"]=> int(0) ["host_info"]=> 
string(20) "localhost via TCP/IP" ["info"]=> NULL ["insert_id"]=> int(0) ["server_info"]=>
string(6) "5.5.25" ["server_version"]=> int(50525) ["stat"]=> string(140) "Uptime: 477847 
Threads: 6 Questions: 202259 Slow queries: 1 Opens: 1454 Flush tables: 1 Open tables: 10 
Queries per second avg: 0.423" ["sqlstate"]=> string(5) "00000" 
["protocol_version"]=> int(10)
["thread_id"]=> int(1506) ["warning_count"]=> int(0) }

另外,我尝试使用不具有ar_data数据库特权的用户,这将给我一个预期的错误。 如果我在mysqli_prepare($conn, $sql)之前执行var_dump($conn) mysqli_prepare($conn, $sql)则它将输出NULL。 如何连接到数据库?

注意:我已经将名称从conn更改为其他var,以防它被更改但行为仍然相同。 我还安装了Drupal 7和Wordpress(我想他们只是在使用基本的msql进行连接)

更新:

整个文件: https : //dl.dropbox.com/u/6688861/phpconn.txt

最后一个var_dump表示连接正常。 您的问题是您在ValidateForm()函数中引用$conn而不在该函数中声明global $conn

在最后结果中,您的连接很好。 如果您的连接不起作用,您将无法获得MySQL服务器信息。 与该调用有关的未定义变量错误在哪里出现? 拥有更多上下文可能会有所帮助。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM