首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > PHP >

php连接Mysql不成功,可以使用Mysqli和PDO连接成功。该如何解决

2012-03-14 
php连接Mysql不成功,可以使用Mysqli和PDO连接成功。环境是win7下面自己手动搭建的apache2.2+php5.3+mysql5,

php连接Mysql不成功,可以使用Mysqli和PDO连接成功。
环境是win7下面自己手动搭建的apache2.2+php5.3+mysql5,各项环境搭建均成功,phpinfo上面看到的Mysql和Mysqli都是对的,但是使用php连接Mysql不成功,但是可以成功使用Mysqli和PDO,而且连接错误的是很不显示错误信息,直接跳转到不能访问的页面。请求帮助!!!!!!!!


[解决办法]

PHP code
function connect($servername, $username, $password, $dbname){ echo "进入链接";    $con = mysql_connect($servername, $username, $password);    $con = mysql_select_db($dbname, $con); return $con;}
[解决办法]
mysql_connect

(PHP 4, PHP 5)

mysql_connect — 打开一个到 MySQL 服务器的连接

说明

resource mysql_connect ([ string $server [, string $username [, string $password [, bool $new_link [, int $client_flags ]]]]] )
打开或重复使用一个到 MySQL 服务器的连接。

参数

server
MySQL 服务器。可以包括端口号,例如 "hostname:port",或者到本地套接字的路径,例如对于 localhost 的 ":/path/to/socket"。

如果 PHP 指令 mysql.default_host 未定义(默认情况),则默认值是 'localhost:3306'。

username
用户名。默认值是服务器进程所有者的用户名。

password
密码。默认值是空密码。

new_link
如果用同样的参数第二次调用 mysql_connect(),将不会建立新连接,而将返回已经打开的连接标识。参数 new_link 改变此行为并使 mysql_connect() 总是打开新的连接,甚至当 mysql_connect() 曾在前面被用同样的参数调用过。

client_flags
client_flags 参数可以是以下常量的组合:MYSQL_CLIENT_SSL,MYSQL_CLIENT_COMPRESS,MYSQL_CLIENT_IGNORE_SPACE 或 MYSQL_CLIENT_INTERACTIVE。进一步信息见MySQL 客户端常量。

返回值

如果成功则返回一个 MySQL 连接标识,失败则返回 FALSE。

更新日志

版本说明
4.3.0 添加 client_flags 参数。
4.2.0 添加 new_link 参数。
3.0.10 对 server 添加 ":/path/to/socket" 支持。
3.0.0 对 server 添加 ":port" 支持。
范例

Example #1 mysql_connect() 例子
<?php
$link = mysql_connect('localhost', 'mysql_user', 'mysql_password');
if (!$link) {
die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully';
mysql_close($link);
?>
Example #2 mysql_connect() 例子:使用 hostname:port 语法
<?php
// we connect to example.com and port 3307
$link = mysql_connect('example.com:3307', 'mysql_user', 'mysql_password');
if (!$link) {
die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully';
mysql_close($link);

// we connect to localhost at port 3307
$link = mysql_connect('127.0.0.1:3307', 'mysql_user', 'mysql_password');
if (!$link) {
die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully';
mysql_close($link);
?>
Example #3 mysql_connect() 例子:使用 ":/path/to/socket" 语法
<?php
// we connect to localhost and socket e.g. /tmp/mysql.sock

//variant 1: ommit localhost
$link = mysql_connect('/tmp/mysql', 'mysql_user', 'mysql_password');
if (!$link) {
die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully';
mysql_close($link);


// variant 2: with localhost
$link = mysql_connect('localhost:/tmp/mysql.sock', 'mysql_user', 'mysql_password');
if (!$link) {
die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully';
mysql_close($link);
?>
注释

Note:

只要将 server 指定为 "localhost" 或 "localhost:port",MySQL 客户端库会越过此值并尝试连接到本地套接字(Windows 中的名字管道)。如果想用 TCP/IP,应该用 "127.0.0.1" 代替 "localhost"。如果 MySQL 客户端库试图连接到一个错误的本地套接字,则应该在 PHP 配置中设定 的正确路径并把 server 留空。

Note:

脚本一结束,到服务器的连接就被关闭,除非之前已经明确调用 mysql_close() 关闭了。

Note:

可以在函数名前加上一个 @ 来抑制出错时的错误信息。

参见

mysql_pconnect() - 打开一个到 MySQL 服务器的持久连接
mysql_close() - 关闭 MySQL 连接
[解决办法]
你的连接服务器名称用的是localhost或者是127.0.0.1吗,换成你的计算机名称试一下,以前碰到过这样的问题
------解决方案--------------------


我知道你懂 我说了 那个错误明显是浏览器的行为
看下你的php.ini 中的display_errors = On 有没有开启
你的代码没看出错误 有报错信息比较好解决 如
$lnk = mysql_connect('localhost', 'mysql_user', 'mysql_password')
or die ('Not connected : ' . mysql_error());
[解决办法]
不对 准确的讲应该是 那个错误的页面 是浏览器比较友好的界面
[解决办法]

探讨

不对 准确的讲应该是 那个错误的页面 是浏览器比较友好的界面

[解决办法]
探讨

引用:

不对 准确的讲应该是 那个错误的页面 是浏览器比较友好的界面


嗯,ie有个打开错误显示的选项.忘记是怎么操作的了.不打开的话就是这个友好的界面

[解决办法]
php.ini 中 display_errors = On 有没有开启报错 不行再看 php_error.log找相对应的错误

热点排行