如果你是初次配置 php mysql apache的话,我们要怎么测试php连接数据库成功了,只要创建一个test.php文件,然后把下面代码保存到文件。
代码如下 | 复制代码 |
<?php |
在浏览器打开 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 |
后来想相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 |
注意,最后一行是关键,告诉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); |
默认情况下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 |
数据查询
代码如下 | 复制代码 |
<?php |
其它的像数据保存等待
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语句执行过程中产生的警告数量。