当前位置:  编程技术>php
本页文章导读:
    ▪php连接mssql数据库的几种方式      数据库查询不外乎4个步骤,1、建立连接。2、输入查询代码。3、建立查询并取出数据。4、关闭连接。 php连接mssql数据库有几个注意事项,尤其mssql的多个版本、32位、64位都有区别。 首先,p.........
    ▪apache和nginx的rewrite的区别      Nginx与Apache的Rewrite规则的区别 1. Nginx Rewrite规则相关指令 Nginx Rewrite规则相关指令有if、rewrite、set、return、break等,其中rewrite是最关键的指令。一个简单的Nginx Rewrite规则语法如下: re.........
    ▪PHP array_to_json      function array_to_json($array) { if (! is_array ( $array )) { return false; } $associative = count ( array_diff ( array_keys ( $array ), array_keys ( array_keys ( $array ) ) ) ); if ($associative) { $construct = array (); foreach ( $array as $key.........

[1]php连接mssql数据库的几种方式
    来源:    发布时间: 2013-11-07

数据库查询不外乎4个步骤,1、建立连接。2、输入查询代码。3、建立查询并取出数据。4、关闭连接。

php连接mssql数据库有几个注意事项,尤其mssql的多个版本、32位、64位都有区别。

首先,php.ini文件中;extension=php_pdo_mssql.dll ;extension=php_pdo_odbc.dll 前面的分号去掉,对应的使哪种方式连接mssql。注意要重启服务使其生效。

一、建立连接

1、odbc

首先,在php程序所在的服务器设置odbc。这里32位和64位操作系统有区别。32位的从控制面板中管理工具中的数据源(odbc)直接建立就可以了,64位的要运行C:\Windows\SysWOW64\odbcad32.exe

从这里面设置。注意:上面只的是数据库服务器为32为的,数据源设置服务器为32位和64位两种的情况。只要两个服务器建立的数据源位数一致就好。

下面是odbc建立连接代码。

$con = odbc_connect('odbc名称','用户名','密码');

2、连接mssql2000

$con = mssql_connect('数据库地址','用户名','密码');

3、连接mssql2008

$connectionInfo = array("UID"=>用户名,"PWD"=>密码,"Database"=>"数据库名称");
$con = sqlsrv_connect( 数据库地址,$connectionInfo);

 

二、输入查询代码

这个都一样,可以直接写入,也可以从mssql中验证好后复制过来。简单点说就是把一个sql语句赋值给一个变量。

类似下面代码

$query = "SELECT top 12 * 数据库名称 order by id desc";

 

三、建立查询并取出数据

1、odbc

$result = odbc_do($con,$query);
while(odbc_fetch_row($result))
{
$变量名称 = odbc_result($result, "字段名称");
}

2、连接mssql2000

$result = mssql_query($con, $query);
while($row =mssql_fetch_array($result))
{
$变量名称 = $row["字段名称"];
}

3、连接mssql2008

$result = sqlsrv_query($con, $query);
while($row = sqlsrv_fetch_array($result))
{
$变量名称 = $row["字段名称"];
}

在php5.3及以后的版本中不附带sqlsrv库了。所以要从微软这里下载。

四、关闭连接

这个没有什么区别,分别是odbc_close();和mssql_close()和sqlsrv_close();

最后体会:php连接mssql比连接mssql的函数少了一些,但是也够用了。具体函数可以参考php官方手册或者oschina的php中文文档。

本文链接


    
[2]apache和nginx的rewrite的区别
    来源:    发布时间: 2013-11-07

Nginx与Apache的Rewrite规则的区别

 
1. Nginx Rewrite规则相关指令 

Nginx Rewrite规则相关指令有if、rewrite、set、return、break等,其中rewrite是最关键的指令。一个简单的Nginx Rewrite规则语法如下:

 

rewrite ^/b/(.*)\.html /play.php?video=$1 break;

 

如果加上if语句,示例如下: 
if (!-f $request_filename)

{ rewrite ^/img/(.*)$ /site/$host/images/$1 last;      }



2. Nginx与Apache的Rewrite规则实例对比

    简单的Nginx和Apache 重写规则区别不大,基本上能够完全兼容。


 Apache Rewrite 规则: 

 

RewriteRule ^/(mianshi|xianjing)/$ /zl/index.php?name=$1 [L]

RewriteRule ^/ceshi/$ /zl/ceshi.php [L]

RewriteRule ^/(mianshi)_([a-zA-Z]+)/$ /zl/index.php?name=$1_$2 [L] RewriteRule ^/pingce([0-9]*)/$ /zl/pingce.php?id=$1 [L]

 

Nginx Rewrite 规则: 

rewrite ^/(mianshi|xianjing)/$ /zl/index.php?name=$1 last;

rewrite ^/ceshi/$ /zl/ceshi.php last;

rewrite ^/(mianshi)_([a-zA-Z]+)/$ /zl/index.php?name=$1_$2 last;

rewrite ^/pingce([0-9]*)/$ /zl/pingce.php?id=$1 last;



    不难发现Apache的Rewrite规则改为Nginx的Rewrite规则挺简单的,如果改完规则,使用"nginx -t"命令检查发现nginx.conf配置文件有语法错误,那么可以尝试给条件加上引号。例如一下的Nginx Rewrite规则会报语法错误: 

rewrite  ^/([0-9]{5}).html$ /x.jsp?id=$1  last;加上引号就正确了:   

rewrite  “^/([0-9]{5}).html$” /x.jsp?id=$1  last;

 

Apache与Nginx的Rewrite规则在URL跳转时有细微的区别: 

Apache Rewrite 规则: 
 

RewriteRule  ^/html/tagindex/([a-zA-Z]+)/.*$ /$1/ [R=301,L]
Nginx Rewrite 规则:

rewrite  ^/html/tagindex/([a-zA-Z]+)/.*$ http://$host/$1/  permanent;


以上示例中,我们注意到,Nginx Rewrite 规则的置换串中增加了“http://$host”,这是在Nginx中要求的。 
    
另外,Apache与Nginx的Rewrite规则在变量名称方面也有区别,例如: 
Apache Rewrite 规则: 

RewriteRule ^/user/login/$ /user/login.php?login=1&forward=http://%{HTTP_HOST}  [L]
    
Nginx Rewrite 规则: 

rewrite  ^/user/login/$ /user/login.php?login=1&forward=http://$host  last;
Apache与Nginx Rewrite 规则的一些功能相同或类似的指令、标记对应关系: 
Apache的RewriteCond指令对应Nginx的if指令; 
Apache的RewriteRule指令对应Nginx的rewrite指令; 
Apache的[R]标记对应Nginx的redirect标记; 
Apache的[P]标记对应Nginx的last标记; 
Apache的[R,L]标记对应Nginx的redirect标记; 
Apache的[P,L]标记对应Nginx的last标记; 
Apache的[PT,L]标记对应Nginx的last标记; 

允许指定的域名访问本站,其他域名一律跳转到http://www.aaa.com: 
 

Apache Rewrite 规则: 

RewriteCond %{HTTP_HOST}    ^(.*?)\.domain\.com$

RewriteCond %{HTTP_HOST}    !^qita\.domain\.com$ RewriteCond %{DOCUMENT_ROOT}/market/%1/index.htm -f

RewriteRule ^/wu/$ /market/%1/index.htm [L]
    
Nginx的if指令不支持嵌套,也不支持AND、OR等多条件匹配,相比于Apache的RewriteCond,显得麻烦一些,但是,我们可以通过下一页的Nginx配置写法来实现这个示例: 
    Nginx Rewrite 规则: 
 

if ($host ~* ^(.*?)\.domain\.com$)    

{

set $var_wupin_city $1;    

set $var_wupin ‘1′;    

}    

 

if ($host ~* ^qita\.domain\.com$)

{

set $var_wupin ‘0′;    

}    

 

if (!-f $document_root/market/$var_wupin_city/index.htm)    

{

set $var_wupin ‘0′;    

}    

 

if($var_wupin ~ ‘1′)    

{

rewrite ^/wu/$ /market/$var_wupin_city/index.htm last;    

}

 

备注学习:

rewrite ^/serach/(.*).html  http://www.xxx.com/search.action?keywords=$1 last; 

访问http://www.xxx.com/search/mp3.html,浏览器url重定向为http://www.xxx.com/search.action?keywords=mp3 

本文链接


    
[3]PHP array_to_json
    来源:    发布时间: 2013-11-07
function array_to_json($array) {
if (! is_array ( $array )) {
return false;
}

$associative = count ( array_diff ( array_keys ( $array ), array_keys ( array_keys ( $array ) ) ) );
if ($associative) {

$construct = array ();
foreach ( $array as $key => $value ) {

// We first copy each key/value pair into a staging array,
// formatting each key and value properly as we go.



// Format the key:
if (is_numeric ( $key )) {
$key = "key_$key";
}
$key = "\"" . addslashes ( $key ) . "\"";

// Format the value:
if (is_array ( $value )) {
$value = array_to_json ( $value );
} else if (! is_numeric ( $value ) || is_string ( $value )) {
$value = "\"" . addslashes ( $value ) . "\"";
}

// Add to staging array:
$construct [] = "$key: $value";
}

// Then we collapse the staging array into the JSON form:
$result = "{" . implode ( ",", $construct ) . "}";

} else { // If the array is a vector (not associative):



$construct = array ();
foreach ( $array as $value ) {

// Format the value:
if (is_array ( $value )) {
$value = array_to_json ( $value );
} else if (! is_numeric ( $value ) || is_string ( $value )) {
$value = "\"" . addslashes ( $value ) . "\"";
}

// Add to staging array:
$construct [] = $value;
}

// Then we collapse the staging array into the JSON form:
$result = "[" . implode ( ", ", $construct ) . "]";
}

return $result;
}

 

本文链接


    
最新技术文章:
▪PHP函数microtime()时间戳的定义与用法
▪PHP单一入口之apache配置内容
▪PHP数组排序方法总结(收藏)
▪php数组排序方法大全(脚本学堂整理奉献)
▪php数组排序的几个函数(附实例)
▪php二维数组排序(实例)
▪php根据键值对二维数组排序的小例子
▪php验证码(附截图)
▪php数组长度的获取方法(三个实例)
▪php获取数组长度的方法举例
▪判断php数组维度(php数组长度)的方法
▪php获取图片的exif信息的示例代码
▪PHP 数组key长度对性能的影响实例分析
▪php函数指定默认值的方法示例
▪php提交表单到当前页面、提交表单后页面重定...
▪php四舍五入的三种实现方法
▪php获得数组长度(元素个数)的方法
▪php日期函数的简单示例代码
▪php数学函数的简单示例代码
▪php字符串函数的简单示例代码
▪php文件下载代码(多浏览器兼容、支持中文文...
▪php实现文件下载、支持中文文件名的示例代码...
▪php文件下载(防止中文文件名乱码)的示例代码
▪解决PHP文件下载时中文文件名乱码的问题
▪php数组去重(一维、二维数组去重)的简单示例
▪php小数点后取两位的三种实现方法
▪php Redis 队列服务的简单示例
▪PHP导出excel时数字变为科学计数的解决方法
▪PHP数组根据值获取Key的简单示例
▪php数组去重的函数代码示例
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3