欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【php能链接到MSSQL 但读取不到表的原因】,下面是详细的分享!
php能链接到MSSQL 但读取不到表的原因
原因可能是:php对mssql的ntext类型的支持问题;
今天弄了半天,明明可以链接到数据库,却不能读取的数据。Google,百度一番之后终于知道了,原来是php读取mssql的 ntext字段反回值为空的,建议可以把ntext字段改成 text。
如果是表里面没有ntext字段,可以用以下代码:
<?php // Connect to MSSQL $link=mssql_connect('KALLESPC\SQLEXPRESS', 'sa', 'phpfi'); if(!$link || !mssql_select_db('php', $link)) { die('Unable to connect or select database!'); } // Do a simple query, select the version of // MSSQL and print it. $version=mssql_query('SELECT @@VERSION'); $row=mssql_fetch_array($version); echo $row[0]; // Clean up mssql_free_result($version); ?> |
如果表里面有ntext军字段,且不好修改回text字段, 可以如下:
1.修改 php.ini
打开php.ini
找到:
| ;mssql.textlimit=4096 |
改为
| mssql.textlimit=2147483647 |
找到:
| ;mssql.textsize=4096 |
改为
| mssql.textsize=2147483647 |
2.可以使用修改字段,由于sql server中,ntext和nvarchar字段是用unicode编码存储内容的,因此php通过mssql扩展读取带ntext和nvarchar类型字段的时候会抱错。
如果 title 字段类型为 nvarchar,content 字段类型为 ntext ,那么下面的sql语句会报错:
错的:
| select title,content from article |
正确的:
| select convert(varchar(255),title) as title, convert(text,content) as content from article |
3.如果你是虚拟主机,可以使用adodb 组件来读取。如果你主机不支持,目前笔者也没办法了。
<?php include("adodb/adodb.inc.php"); //包含adodb类库文件 $conn=NewADOConnection('odbc_mssql'); //连接SQL Server数据库 $conn->Connect("Driver={SQL Server};Server=localhost;Database=mydb;",'username','password'); ?> |
以上所分享的是关于php能链接到MSSQL 但读取不到表的原因,下面是编辑为你推荐的有价值的用户互动:
相关问题:php在本地测试正常,上传到空间数据库有些表的数据...
答:数据库配置文件正常吗? 你看看数据库连接正确吗? >>详细
相关问题:php配置文件读取不到信息错误的原因
答:貌似是不是得先定义一下global啊 。 global $_CFG 或者 $_GLOBALS >>详细
相关问题:phpexcel ,读取不到数据
答:在TP中需要对类名进行修改,请看下图路径和命名,PHPExcel,Excel5,类名都要修改 以下是参考代码 import("Org.Util.PHPExcel.Reader.Excel5"); import("Org.Util.PHPExcel.IOFactory"); import("Org.Util.PHPExcel.Worksheet.MemoryDrawing"); i... >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
