首页 > 编程技术 > php

php配置mysql与怎么测试配置数据库成功

发布时间:2016-11-25 16:36

php配置mysql与怎么测试配置数据库成功 有需要的朋友可参考一下。

如果你是初次配置 php mysql apache的话,我们要怎么测试php连接数据库成功了,只要创建一个test.php文件,然后把下面代码保存到文件。

 代码如下 复制代码

<?php
$link=mysql_connect("localhost","root","12345"); //12345改成你的mysql密码
if(!$link) echo "失败!";
else echo "成功!";
mysql_close();
?>

在浏览器打开 http://localhost/test.php

如果输入

成功就说明你的配置成功了,如果失败我们可以在mysql_connect("localhost","root","12345") or die( mysql_error());这样就会有错误提示哦。

如果提示mysql_connect函数未定义,我们可以在php.ini中如下图

;extension=php_mysql.dll
;extension=php_mysqli.dll

把前面的;去了

extension=php_mysql.dll
extension=php_mysqli.dll

然后重启apache即可

昨天在使用phpmyadmin连接mysql时出现了#2002 – 服务器没有响应 (或者本地 MySQL 服务器的套接字没有正确配置),但我利用php连接没有问题如

 代码如下 复制代码

<?php  
$link=mysql_connect("127.0.0.1","root","password");  
if (!$link) echo "connect error";  
else echo "connect ok";  
?>

后来想相MySQL数据库服务器的地址应该改成127.0.0.1,

具体方法:

打开我们刚才拷贝到phpMyAdmin目录下的config.inc.php 中

找到这句话:

 代码如下 复制代码

$cfg['Servers'][$i]['host'] = 'localhost';

改成

$cfg['Servers'][$i]['host'] = '127.0.0.1';

这样即可了 ,导致这个问题的原因我觉得应该是host文件解析有问题,大家处理一应该就好了。

php将可以正常的和apache结合,并且常见的诸如:PHP Warning: PHP Startup: Unable to load dynamic library……、Fatal error: Call to undefined function mysql_connect() 错误

不过今天在弄一个CMS时还是出现了一个不可饶恕的错误,无法连接mysql,写了一个测试mysql的php文件如下:

 代码如下 复制代码
<?php
$link=mysql_connect('localhost','root','root');
if(!$link) echo "失败!";
else echo "成功!";
mysql_close();
?>    

 

结果报错误:Fatal error: Call to undefined function mysql_connect(),明显没法找到mysql相应的库,百度了一大堆,又是什么复制mysql的lib库、又是复制到windows的system32目录,过于复杂,其实正确的配置应该是在apache的httpd.conf文件中加入下设置:

 代码如下 复制代码

LoadModule php5_module d:/tools/php-5.3.1/php5apache2_2.dll
AddType application/x-httpd-php .php
PHPIniDir d:/tools/php-5.3.1     

注意,最后一行是关键,告诉apache你的php配置文件在哪里,不然你就得把php.ini文件复制到windows的系统目录下了。一般我们通过这里配置就可以完成apache和php的结合。而在php.ini文件中只需要修改如下几个地方即可:

# 修改php的扩展库目录为你的实际路径

 代码如下 复制代码
extension_dir = "D:/tools/php-5.3.1/ext"

# 去掉前面的;

 代码如下 复制代码
extension=php_mysql.dll     

最后一个步骤就是在系统环境变量(注意是系统环境变量,而非用户环境变量)path中加入你的PHP安装路径,在设置成功后,通过phpinfo()应该可以在Apache Environment段的path中可以看到你的PHP安装目录,否则就是环境变量没有配置成功(注意,配置环境变量后重启下apache)。

完成这些步骤后就可以正确连接数据库了,不过前提是你的apache和php的整合是正常的,然后再考虑这个mysql配置,如果还不能够达到效果,你可以质问我,呵呵!


总结,windows平台下apache和php(包括mysql)整合的正确配置步骤如下:

1、安装apache,并保证apache可以单独正常运行

2、将php(如5.2.17或5.3.1)的zip包解压到一个目录,比如D:php-5.3.1

3、在apache的httpd.conf文件的最后加入如下段:

 代码如下 复制代码
# php5 supportLoadModule php5_module D:/php-5.3.1/php5apache2_2.dll
 代码如下 复制代码
AddType application/x-httpd-php .php
 代码如下 复制代码
PHPIniDir D:/php-5.3.14

、在操作系统的环境变量(必须是系统变量而非用户变量)的path中加入D:/php-5.3.1路径

5、将php安装目录下的php.ini-dist重命名为php.ini,并修改如下内容:

# 设置php的扩展文件目录

 代码如下 复制代码
extension_dir = "D:/php-5.3.17/ext"

 # 开启mysql扩展,去掉前面的;注释

 代码如下 复制代码
extension=php_mysql.dll


一、问题:

      数据库是MS SQLServer2000,要把SQLServer2000里的一张表的数据导入MySQL5,其中SQLServer2000表的字段以简体中文命名(强烈建议不要以中文做为字段名)。其实操作就是对SQLServer查询记录,插入到MySQL里。选择的脚本语言是PHP,PHP打开MSSQL和MySQL扩展,对这两个数据库操作都是很容易的问题。

    问题就出现在SQLServer中表的字段名是中文,写好的查询语句在SQLServe里测试是通过有记录返回,用PHP的MSSQL扩展查询就是报错。

    上网查了资料,网上相关的信息不太多,很多网友都认为是PHP的MSSQL扩展不支持SQL语句中有中文。查了一下资料,PHP的MSSQL是支持SQL中有中文的语句。出现报错问题大多是因为编码的问题,编码数据库和编码与查询语句编码不统一,查询语句到SQLServer里中文部分就成了乱码,造成查询失败。

 二、解决方法:

      知道了原因,接下来分析解决,确认是编码不统一的问题。解决分以下几步:

           1、确认SQLServer 数据库的编码,我的数据编码是GBK。

           2、确认当前PHP脚本文件的编码,我的编码是UTF-8。

           3、转换SQL查询语句的的编码。

           补充:有的网友提到要把PHP的脚本文件编码转成和数据库编码一致,其实这一步大可不必,只要确认你的SQL语句和数据库的编码一致就可以,这里建议不必转换的原因是如果你的PHP脚本文件里包含其它PHP脚本,那也得对所有include或require的脚本文件编码转换,不然PHP脚本编码不统一很容易出错,若互相关联的文件很多,这也是一件很麻烦的问题而且把事情复杂化了。

 

三、方案:

写一个转换函数,在把SQL操作前把SQL语句编码转换。下面贴出我的范例代码:

//编码转换函数

 代码如下 复制代码

function utf8togb($s) {

return iconv('utf-8', 'gbk//IGNORE', $s);  // IGNORE 参数是遇到不成转换的字符时忽略

}

//建议把所有中文字段用英文别名替换,方便下面操作还有编码转换等问题

$sql="SELECT [id], [栏目] as typeid, [正题] as title, [作者] as author, convert(text, [正文]) as body FROM [文章表];";

$sql = utf8togb($sql);

php的mysqli扩展被封装到一个类中,是一种面向对象的技术,执行速度更快,与传统的过程化方法相比更方便也更高效

默认情况下mysqli在php是未开启的我们需在
要在PHP中使用mysqli扩展,需要在配置文件php.ini中添加如下的设置:

 代码如下 复制代码
extension=php_mysqli.dll

如果配置文件中已有上述设置,确保extension前面没有“;”,否则将其去掉。下面开始介绍如何使用mysqli扩展来存取数据库,即可了.

 代码如下 复制代码
<?php
$db_host="localhost";                                           //连接的服务器地址
$db_user="root";                                                  //连接数据库的用户名
$db_psw="root";                                                  //连接数据库的密码
$db_name="sunyang";                                           //连接的数据库名称
$mysqli=new mysqli();
$mysqli->connect($db_host,$db_user,$db_psw,$db_name);
?>

关闭与MySQL服务器的连接通过mysqli对象调用close()方法即可,例如:
$mysqli->close();

 代码如下 复制代码

<?php
$connection = mysqli_connect("localhost","root","root","sunyang");
if ( $connection ) {
         echo "数据库连接成功";
}else {
         echo "数据库连接失败";
}
?>

数据查询

 代码如下 复制代码

<?php
$mysqli=new mysqli("localhost","root","root","sunyang");     //实例化mysqli
$query="select * from employee";
$result=$mysqli->query($query);
if ($result) {
         if($result->num_rows>0){                                               //判断结果集中行的数目是否大于0
                  while($row =$result->fetch_array() ){                        //循环输出结果集中的记录
                           echo ($row[0])."<br>";
                           echo ($row[1])."<br>";
                           echo ($row[2])."<br>";
                           echo ($row[3])."<br>";
                           echo "<hr>";
                  }
         }
}else {
         echo "查询失败";
}
$result->free();
$mysqli->close();
?>

其它的像数据保存等待


mysqli类中的成员方法

__construct():构造方法,用于创建一个mysqli对象,也可以建立一个连接。

autocommit():开启或关闭数据库修改自动提交。

change_user():改变数据库连接所指定的用户。

character_set_name():返回数据库连接默认字符集。

close():关闭先前打开的连接。

commit():提交当前的事物。

connect():打开一个新的连接到mysql数据库服务器。

debug():执行调试操作。

dump_debug_info():转储调试信息。

get_client_info():返回客户端版本。

get_host_info():返回一个字符串代表的连接使用类型,如:Localhost via UNIX socket

get_server_info():返回mysql服务器版本。

get_server_version():返回整数形式的mysql服务器版本。

init():初始化一个mysqli并返回一个资源。

info():检索有关最近执行的查询。

kill():杀死一个mysql线程。

multi_query():执行多个查询语句。

more_results():从多查询语句中检索是否有任何更多的查询结果。

next_result():从当前执行的多查询中读取下一个结果。

options():设置选项。

ping():如果没有连接,ping一台服务器连接或重新连接。

prepare():准备一个sql语句的执行,返回mysqli_stmt对象。

query():与数据库交互都是通过查询进行的,该方法向数据库发送查询来执行,执行失败返回FALSE。

real_connect():试图打开一个连接到mysql数据库服务器。

escape_string():转义特殊字符的字符串。

rollback():回滚当前的事务。

select_db():为数据库查询选择一个默认的数据库。

set_charset():设置默认客户端字符集。


ssl_set():使用ssl用于建立安全连接。

stat():获取当前的系统状态。

stmt_init():初始化一个声明,返回一个mysql_stmt对象。

store_result():从最后查询中转让结果集。

thread_safe():是否考虑返回安全的线程。

 


mysql类中的成员属性

$affected_rows:前一个mysql操作中影响的行数。

$client_info:mysql客户端版本(字符串)。

$client_version:mysql客户端版本(整数)。

$errno:最近函数调用的错误代码。

$error:最近函数调用的错误信息字符串。

$field_count():查询获取的列数。

$host_info:连接类型使用(字符串)。

$info:最近执行的查询。

$insert_id:最后查询自动生成的编号。

$protocol_version:mysql协议使用的版本。

$sqlstate:包含SQLSTATE错误码的最后一个错误。

$thread_id:当前连接线程ID。

$warning_count:前一个sql语句执行过程中产生的警告数量。

标签:[!--infotagslink--]

您可能感兴趣的文章: