php连接mssql(sql server)数据库的方法总结
一开始我下载的php版本是5.93的,下载下来添加环境变量等等搞了半天后,phpinfo()这个函数终于成功的运行在浏览器中了。然后当我在满世界的找php_mssql.dll,才发现在5.3以及以上版本的php中已经不是原生态的支持mssql了。
好不容易找到了微软Microsoft Drivers 3.0 for PHP for SQL Server,心想微软的东西应该做的可以,却无奈的发现SQLSRV30.EXE没有办法运行:“SQLSRV30.EXE 不是有效的win32程序”。
首先,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建立连接代码。
</>code
- $con = odbc_connect('odbc名称','用户名','密码');
</>code
- $con = mssql_connect('数据库地址','用户名','密码');
3、连接mssql2008
</>code
- $connectionInfo = array("UID"=>用户名,"PWD"=>密码,"Database"=>"数据库名称");
- $con = sqlsrv_connect( 数据库地址,$connectionInfo);
二、输入查询代码
这个都一样,可以直接写入,也可以从mssql中验证好后复制过来。简单点说就是把一个sql语句赋值给一个变量。
类似下面代码
</>code
- $query = "SELECT top 12 * 数据库名称 order by id desc";
1、odbc
</>code
- $result = odbc_do($con,$query);
- while(odbc_fetch_row($result))
- {
- $变量名称 = odbc_result($result, "字段名称");
- }
</>code
- $result = mssql_query($con, $query);
- while($row =mssql_fetch_array($result))
- {
- $变量名称 = $row["字段名称"];
- }
</>code
- $result = sqlsrv_query($con, $query);
- while($row = sqlsrv_fetch_array($result))
- {
- $变量名称 = $row["字段名称"];
- }
四、关闭连接
这个没有什么区别,分别是odbc_close();和mssql_close()和sqlsrv_close();
为了能让PHP连接MSSQL,系统需要安装MSSQL,PHP,且在PHP.ini中的配置中,将 ;extension=php_mssql.dll前面的;去掉
1.连接MSSQL
</>code
- $conn=mssql_connect("实例名或者服务器IP","用户名","密码");
- //测试连接
- if($conn)
- {
- echo "连接成功";
- }
2.选择要连接的数据库
</>code
- mssql_select_db("dbname");
3.执行查询
</>code
- $rs = mssql_query("select top 1 id,username from tbname",$conn);
- // 或者直接执行update,insert等语句,可以不用为返回结果赋值
- mssql_query("update tbname set username='niunv' where id=1");
4.获取记录集行数
</>code
- echo mssql_num_rows($rs);
5.获取记录集
</>code
- if($row=mssql_fetch_array($rs))
- {
- $id = $row[0];//获取ID字段值
- $username = $row[1];//获取username字段值
- }
6.获取新增记录的ID
将id字段设置为IDENTITY字段,执行insert语句以后,就会产生一个 @@IDENTITY 全局变量值,查询出来就是最后一条新增记录的ID了.
</>code
- mssql_query("insert into tbname(username) values ('nv')",$conn);
- $rs = mssql_query("select @@IDENTITY as id",$conn);
- if($row=mssql_fetch_array($rs))
- {
- echo $row[0];
- }
7.释放记录集
</>code
- mssql_free_result($rs);
8.关闭连接
</>code
- mssql_close($conn);
注:用PHP操作MSSQL比在ASP连接MYSQL要简单,所以,当需要MSSQL与MYSQL并存时,用PHP连接MSSQL来操作MYSQL与MSSQL并存比较简单好用.如果是ASP连接MYSQL,需要安装一个MYSQL驱动,默认windows的ODBC没有安装,很遗憾...
下面是我修改的 一个class
</>code
- <?php
- /**
- *mssql 数据库连接类
- **/
- class SQL{
- var $server;
- var $userName;
- var $passWord;
- var $dataBase;
- var $linkID = 0;
- var $queryResult;
- var $lastInsertID;
- var $pageNum = 0;//分页用---共有几条数据
- var $ER;
- /**
- *构造函数
- **/
- function SQL($Server='',$UserName='',$PassWord='',$DataBase=''){
- $this->server = $Server;
- $this->userName = $UserName;
- $this->passWord = $PassWord;
- $this->dataBase = $DataBase;
- }
- /**
- *数据库连接
- **/
- function db_connect(){
- $this->linkID = mssql_pconnect($this->server,$this->userName,$this->passWord);
- if(!$this->linkID){
- $this->ER = "db_connect($this->server,$this->userName,$this->passWord) error";
- return 0;
- }
- if (!mssql_select_db($this->dataBase,$this->linkID)) {
- $this->ER = "mssql_select_db($this->dataBase,$this->lastInsertID) error";
- return 0;
- }
- return $this->linkID;
- }
- /**public
- * function: Check the database, if exist then select
- * exist: return 1
- * not exist: return 0
- */
- function selectDatabase(){
- if(mssql_select_db($this->dataBase))
- return 1;
- else
- return 0;
- }
- /**
- *数据操作
- **/
- function query($Str){
- if ($this->linkID == 0) {
- $this->ER = "数据库还没有连接!!";
- }
- $this->queryResult = mssql_query($Str);
- //$this->queryResult = mssql_query($Str,$this->linkID);
- if (!$this->queryResult) {
- $this->ER = "$Str.没有操作成功,query error!!";
- return 0;//****************对于php 4.3.9以上版本的错误用1
- }
- return $this->queryResult;
- }
- /**
- *数据获取
- **/
- function fetch_array($result){
- if($result != "") $this->queryResult = $result;
- $rec =mssql_fetch_array($this->queryResult);
- if(is_array($rec)){
- return $rec;
- }
- //$this->ER = "没有获取数据!";
- return 0;
- }
- /**public
- * function: Free the Query Result
- * success return 1
- * failed: return 0
- */
- function freeResult($result=""){
- if($result != "") $this->queryResult = $result;
- return mssql_free_result($this->queryResult);
- }
- /**
- *获取影响的的行数
- *获取操作过的行数
- **/
- function num_rows($result=""){
- if ($result != "") {
- $this->queryResult = $result;
- $row = mssql_num_rows($this->queryResult);
- return $row;
- }
- }
- /**
- *获取查询结果---多个
- **/
- function result_ar($str=''){
- if (empty($str)) {
- return 0;
- }
- $back = array();
- $this->queryResult = $this->query($str);
- while ($row = $this->fetch_array($this->queryResult)) {
- $back[] = $row;
- }
- return $back;
- }
- /**
- *数据库信息分页
- *$Result 数据库操作
- *str ==sql语句
- *page ==第几页
- *showNum ==显示几页
- */
- function page($Str,$Page=0,$ShowNum=5){
- $back = array();//返回数据
- $maxNum = 0;
- if ($Str == "") {
- $this->ER = "没有数据";
- return 0;
- }
- $this->queryResult = $this->query($Str);
- if($this->queryResult){
- if($Page==""){
- $nopa=0;
- }else{
- $nopa = ($Page-1)*$ShowNum;
- if ($nopa<0) {
- $nopa = 0;
- }
- }
- $maxNum=$this->num_rows($this->queryResult);
- $k=0;
- $i=0;
- $dd=$this->fetch_array($this->queryResult);
- while($dd&&$nopa<=$maxNum&&$i<$ShowNum){
- if($nopa >= $maxNum) $nopa = $maxNum;
- mssql_data_seek($this->queryResult,$nopa);
- $row=$this->fetch_array($this->queryResult);
- $nopa++;
- $i++;
- $back[] = $row;
- if ($nopa >=$maxNum) {
- break;
- }
- }
- }
- $this->pageNum = $maxNum;
- return $back;
- }
- /**
- *分页的html页码
- */
- function page_html($DataNum=0,$Page=1,$ShowNum=3,$web,$Post=''){
- if ($DataNum == 0) {
- $back = "没有要查询的数据";
- }else {
- if ($ShowNum<=0) {
- $ShowNum = 3;
- }
- if ($Page<=0) {
- $Page = 1;
- }
- if (empty($web)) {
- $web = "#";
- }
- $pageNum = ceil($DataNum/$ShowNum);
- if ($Page <= 1) {
- $top = "首页<<";
- }else {
- $top = "<a href='".$web."?page=0&".$Post."' target='_self'>首页<< </a>";
- }
- if ($Page !==1) {
- $upPage = "<a href='".$web."?page=".($Page-1)."&".$Post."' target='_self'>上一页</a>";
- }else {
- $upPage = "上一页";
- }
- if ($Page < $pageNum) {
- $downPage = "<a href='".$web."?page=".($Page+1)."&".$Post."' target='_self'>下一页</a>";
- }else {
- $downPage = "下一页";
- }
- if ($Page == $pageNum) {
- $foot = ">>尾页";
- }else {
- $foot = "<a href='".$web."?page=".$pageNum."&".$Post."' target='_self'> >>尾页</a>";
- }
- $back = <<<EOT
- 共 $pageNum 页
- 第 $Page/$pageNum 页 $top $upPage $downPage $foot
- EOT;
- }
- return $back;
- }
- }//end class
- ?>
1、数据库连接失败的问题,提示 Fatal error: Call to undefined function mssql_connect() in。
首先要安装WAMP5(我安装在D:\wamp),该服务器默认是连接My Sql 数据库,所以要想连接SQL
Server2005数据库,必须修改php.ini。即去掉;extension=php_mssql.dll前的";",再设置
mssql.secure_connection = On。然后检查 D:/wamp/php/ext/ 中的ntwdblib.dll版本(版本
2000.2.8.0支持SQL Server2000,版本2000.80.194.0支持SQL Server2005)。修改完后记得重启整个
WAMP5。
2、PHP页面查询SQL Server2005中数据时,中文显示乱码。
这是因为SQL Server2005默认的是支持gb2312页面编码方式,而且php.ini配置与.php页面编码不一致,
所以修改两个地方:一是php.ini修改为default_charset = "gb2312";二是将.PHP页面的编码方式修改
过来即可,即<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />。(注:
Mysql 数据库既支持gb2312编码又支持utf-8编码)
3、jquery.js放在根目录下的inc文件夹中,但PHP页面无法引用。
WEB页面使用jquery技术不跳转页面实现后台数据库交互,必须引用jquery.js。写法是<script
type="text/javascript" src="/inc/jquery.js"></script>
4、PHP页面使用header("location:shopping_car.php")定向页面时出错,Warning: Cannot modify
header information - headers already sent by。
原因:setcookie函数必須在任何资料输出至浏览器前,就先送出。
解决办法:头部最前方设置ob_start(); 打开缓冲区;和尾部ob_end_flush();//输出全部内容到浏览器
。
5、如果PHP页面编码方式是utf-8,但是页面中没有<meta http-equiv="Content-Type"
content="text/html; charset=utf-8" />。用alert()时,中文显示乱码。
解决办法:一定要在网页中指定编码方式为UTF-8,即添加<meta http-equiv="Content-Type"
content="text/html; charset=utf-8" />,因为有alert()输出中文到浏览器。
Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 2611816
bytes)
今天要用php代码来处理一个580M的日志文件,总共有219万多行记录,因为是.log的文件,在windows下
面很难将文件按照条数来分割,于是在linux下用split -l 10000 filename 前缀名 将整个文件按10000
行一个分割成了200多个小文件,之后用php来循环处理这200多个文件,可是执行到后来就出现了题目上
面的错误:
Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 2611816
bytes)
去百度了一下,原来是php.ini中的内存分配的问题,默认php代码能够申请到的最大内存字节数就是
134217728 bytes,如果代码执行的时候再需要更多的内存,就会报错了,于是就将php.ini文件中的配
置改了一下:
memory_limit = 128M;//将128M改成了256M
但是之后一想,一个php脚本一次请求的内存空间就要超过128M,那不管你以后将memory_limit设置成多
大,以后肯定有出问题的时候。
如对本文有疑问,请提交到交流论坛,广大热心网友会为你解答!! 点击进入论坛