问题代码如下:
出现的情况是使用 query 可以正确读取到数据,而使用m方法,,则无法读取,会报出 incorrect syntax near the keyword 'as'. 错误
原因是dbmssql.class.php驱动的查询语句有问题。
由于tp2.0 的 mssql 驱动是对sql 2005有效,但对2000版本则无效,原因是2000版本里没有 row_number 功能,2005才有这个功能作用好像是对数据分页提供便利和效能。
希望官方能够给tp2.0加一个2000的驱动吧,目前采用的临时处理方法是修改thinkphp\lib\think\db\driver\dbmssql.class.php ,将行 25 的 protected $selectsql 在前面加 '//'
并且第326行 的
public function parselimit($limit) {if(emptyempty($limit)) $limit=1;$limit = explode(',',$limit);if(count($limit)>1)$limitstr = '(t1.row_number between '.$limit[0].' + 1 and '.$limit[0].' + '.$limit[1].')';else$limitstr = '(t1.row_number between 1 and '.$limit[0].);return $limitstr; }
改为:
public function parselimit($limit) {return ''; }
这样更改后,基本可以满足一般的sql需求,但不能使用limit,因为 mssql 2000 的limit方法是以 top n
这样实现的;
如果觉得麻烦,那么就结合 adodb 类库吧,这个对mssql支持相对好很多。要结合 adodb 类库我的方法如下:
首先下载 adodb 类库并解压到 thinkphp 的 vendor 目录中,并把 adodb.inc.php 改名为 adodb.php
然后在项目的 lib 里建立一个 commonaction.class.php 内容为
在项目的其他文件中都要引用到这个 commonaction.class.php 文才能使用 adodb,例如:
这样既能使用 thinkphp 的模块进行简单的数据查询也能使用 adodb 进行分页数据的查询,实在是没办法中的办法了,这个是个笨办法哦,还是希望 thinkphp 能够出一个 mssql 2000 版本能用的完美驱动。
【相关教程推荐】
1. php编程从入门到精通全套视频教程
2. php从入门到精通
3. bootstrap教程
