热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php连接mysql与mssql2005数据库代码

1,php连接mssql20051,下载以下两个文件,放入phpext目录及system32.php_sqlsrv_52_ts_vc6.dll(线程安全),php_sqlsrv_52_nt...
1,php连接mssql 2005 1,下载以下两个文件,放入php ext目录及system32.

php_sqlsrv_52_ts_vc6.dll(线程安全),php_sqlsrv_52_nts_vc6.dll(非线程安全).

vc6用于apache,vc9用于iis

2.修改php.ini

extension=php_sqlsrv_52_ts_vc6.dll

3.下载sqlncli.msi,微软官方可以下

安装的时候提示是sql server 2008的,不过2005也是可以用的.

4.测试代码

"testdb","uid"=>"test","pwd"=>"test"); 
$cOnn= sqlsrv_connect($servername, $connectioninfo); 
 
if($conn) { 
echo "connection established.
"; } else { echo "connection could not be established.
"; die(print_r(sqlsrv_errors(), true)); exit(); } $sql = "select * from t_employee"; $result = sqlsrv_query($conn,$sql); $data = array(); while($row=sqlsrv_fetch_array($result)) { $data[] = $row; } foreach($data as $p) { echo $p['name']."
"; } sqlsrv_close($conn); echo "
done
"; echo date("y-m-d h:i:s");

mysql连接类:

class db_handle { 
var $classname = "db_handle"; 
var $server; 
var $username; 
var $password; 
var $database; 
var $linkid = 0; 
var $queryresult = ""; 
var $lastinsertid = ""; 
/* private ignore=>ignore the error and continue, halt=>report the error and halt, report=>report the error and continue */ 
var $halt_on_error = "report"; 
var $error = ""; 
var $errno = 0; 
/**public 
 * remark: this is the db_mysql_class's structure 
 * function: set the server,username,password,database variable. 
 */ 
function db_handle($server = "", $username = "", $password = "", $database = "") { 
$this->server = $server; 
$this->username = $username; 
$this->password = $password; 
$this->database = $database; 
} 
/**public 
 * function: connect database and select database 
 * success: retun 1 
 * failed: return 0 
 */ 
function connect() { 
$this->linkid = @mssql_pconnect ( $this->server, $this->username, $this->password ); 
if (! $this->linkid) { 
$this->halt ( "mssql_pconnect($this->server,$this->username,$this->password): failed" ); 
return 0; 
} 
if (! @mssql_select_db ( $this->database )) { 
$this->halt ( "mssql_select_db($this->database) failed." ); 
return 0; 
} 
return 1; 
} 
/**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; 
} 
/**public 
 * function: execute sql instruction 
 * success: return sql result. 
 * failed: return 0; 
 */ 
function execquery($sql = "") { 
$this->connect(); 
if ($this->linkid == 0) { 
$this->halt ( "execute sql failed: have not valid database connect." ); 
return 0; 
} 
ob_start (); 
$this->queryresult = mssql_query ( $sql, $this->linkid ); 
$error = ob_get_contents (); 
ob_end_clean (); 
if ($error) { 
$this->halt ( "execute sql: mssql_query($sql,$this->linkid) failed." ); 
return 0; 
} 
$reg = "#insert into#"; 
if (preg_match ( $reg, $sql )) { 
$sql = "select @@identity as id"; 
$res = mssql_query ( $sql, $this->linkid ); 
$this->lastinsertid = mssql_result ( $res, 0, id ); 
} 
return $this->queryresult; 
} 
 
/**public 
 * function: get the query result's row number 
 * success: return the row fo the result 
 * failed: return 0 
 */ 
function gettotalrownum($result = "") { 
if ($result != "") 
$this->queryresult = $result; 
$row = @mssql_num_rows ( $this->queryresult ); 
if ($row >= 0) 
return $row; 
$this->halt ( "get a row of result failed: result $result is invalid." ); 
return 0; 
} 
 
/**public 
 * function: get the last insert record's id 
 * success: return id 
 * failed: return 0 
 */ 
function lastinsertid() { 
return $this->lastinsertid; 
} 
 
/**public 
 * function: get a field's value 
 * success: return value of the field 
 * failed: return 0 
 */ 
function getfield($result = "", $row = 0, $field = 0) { 
if ($result != "") 
$this->queryresult = $result; 
$fieldvalue = @mssql_result ( $this->queryresult, $row, $field ); 
if ($fieldvalue != "") 
return $fieldvalue; 
$this->halt ( "get field: mssql_result($this->queryresult,$row,$field) failed." ); 
return 0; 
 
//here should have error handle 
} 
 
/**public 
 * function: get next record 
 * success: return a array of the record's value 
 * failed: return 0 
 */ 
function nextrecord($result = "") { 
if ($result != "") 
$this->queryresult = $result; 
$record = @mssql_fetch_array ( $this->queryresult ); 
if (is_array ( $record )) 
return $record; 
//$this->halt("get the next record failed: the result $result is invalid."); 
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 ); 
} 
 
/**public 
 * function: set the halt_on_error's state 
 * success: return 1 
 * failed: return 0 
 */ 
function sethaltonerror($state = "ignore") { 
if (! ($state == "ignore" || $state == "report" || $state == "halt")) { 
$this->halt ( "set the halt_on_error fail: there is no state value $state" ); 
return 0; 
} 
$this->halt_on_error = $state; 
return 1; 
} 
 
/**public 
 * function: get the halt_on_error's state 
 */ 
function gethaltonerror() { 
return $this->halt_on_error; 
} 
 
/**public 
 * function: get the class's name 
 */ 
function tostring() { 
return $this->classname; 
} 
 
/**private 
 * function: error handle 
 */ 
function halt($msg) { 
$this->error = @mysql_error ( $this->linkid ); 
$this->errno = @mysql_errno ( $this->linkid ); 
if ($this->halt_on_error == "ignore") 
return; 
$this->makemsg ( $msg ); 
if ($this->halt_on_error == "halt") 
die ( "session halted" ); 
}//开源代码phprm.com 
 
/**private 
 * function: make error information and print 
 */ 
function makemsg($msg) { 
printf ( "database error: %sn", $msg ); 
printf ( "mysql error: %s (%s)n", $this->errno, $this->error ); 
} 
}

推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 本文介绍了关于apache、phpmyadmin、mysql、php、emacs、path等知识点,以及如何搭建php环境。文章提供了详细的安装步骤和所需软件列表,希望能帮助读者解决与LAMP相关的技术问题。 ... [详细]
  • 众筹商城与传统商城的区别及php众筹网站的程序源码
    本文介绍了众筹商城与传统商城的区别,包括所售产品和玩法不同以及运营方式不同。同时还提到了php众筹网站的程序源码和方维众筹的安装和环境问题。 ... [详细]
  • 如何在php中将mysql查询结果赋值给变量
    本文介绍了在php中将mysql查询结果赋值给变量的方法,包括从mysql表中查询count(学号)并赋值给一个变量,以及如何将sql中查询单条结果赋值给php页面的一个变量。同时还讨论了php调用mysql查询结果到变量的方法,并提供了示例代码。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
author-avatar
鸟鸟212
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有