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

时间:2012-07-16 21:10:45

标签: php pdo mysqli

我已尝试将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数据库权限的用户,它会按预期给我一个错误。如果我在var_dump($conn)之前mysqli_prepare($conn, $sql),那么它将打印为NULL。如何连接数据库?

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

更新:

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

2 个答案:

答案 0 :(得分:1)

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

答案 1 :(得分:0)

你的连接在最后的结果中没问题。如果您的连接不起作用,您将无法获得MySQL服务器信息。你在哪里获得与此调用相关的未定义变量错误?有更多的背景可能会有所帮助。