zoukankan      html  css  js  c++  java
  • php 链接mssql问题 ntext不能读取

    原因可能是:php对mssql的ntext类型的支持问题;

    今天弄了半天,明明可以链接到数据库,却不能读取的数据。Google,百度一番之后终于知道了,原来是php读取mssql的 ntext字段反回值为空的,建议可以把ntext字段改成 text。

    如果是表里面没有ntext字段,可以用以下代码:

    // 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

    {这个方法不太实用,如果ntext内容 太长 转换之后会丢失数据,也就说过长的文章被截断了,而且在sql2008中 把ntext改成 nvarchar(max) 也不行}

    3.如果你是虚拟主机,可以使用adodb 组件来读取。如果你主机不支持,目前笔者也没办法了。

    include(“adodb/adodb.inc.php”); //包含adodb类库文件

    $conn=NewADOConnection(‘odbc_mssql’); //连接SQL Server数据库

    $conn-》Connect(“Driver={SQL Server};Server=localhost;Database=mydb;”,‘username’,‘password’);

    {使用adodb有一点要注意,使用adodbPHP连MSSQL的前提是驱动问题,5.2.10之前,PHP自带的驱动只支持MSSQL 7.0,如果要支持MSSQL 2000,需要将MSSQL 2000的ntwdblib.dll(2000.80.2039.0)复制到System32或者PHP目录下
    5.2.11才支持MSSQL 2000,如果需要支持MSSQL 2005和2008,需要安装微软提供的驱动

    所以如果是虚拟主机基本没办法

    }

    ?>

    还有如下方法

    转载  PHP 连接 MSSQL 2005/2008 以UTF8存取 并让ADODB支持的安装设置 收藏

    因系统大量使用AJAX,为避免编码转来转去的麻烦,把文件都设为了UTF8。但在操作MSSQL时遇到乱码问题,查阅一番后原来是MSSQL不支持UTF8,寒~~ 花了一天时间来处理这个问题,并最终解决:

    一、安装SQL Server Driver for PHP
        在微软官网上发现了这个东西,他提供了一套PHP对MS2005/2008操作的全新函数库,并且支持UTF8,作为PHP的扩展运行。看来MS对PHP 还比较亲善,PHP自带的mssql操作函数对MS2005/2008的一些新功能不支持,MS就自己提供了解决方法,赞一个!不过只支持PHP5.2 /5.3,MS说目前在PHP 5.2上测试过,低版本的是否支持就不清楚了。我的系统正好也用的是PHP5.2,其它版本也懒得去测了。
    下载地址:http://www.microsoft.com/downloads/details.aspx?familyid=CCDF728B-1EA0-48A8-A84A-5052214CAAD9&displaylang=en

    下载后是个.exe的压缩包,解开后有下列.dll文件:
    php_sqlsrv_52_nts_vc6.dll
    php_sqlsrv_52_ts_vc6.dll
    php_sqlsrv_53_nts_vc6.dll
    php_sqlsrv_53_nts_vc9.dll
    php_sqlsrv_53_ts_vc6.dll
    php_sqlsrv_53_ts_vc9.dll

    要根据自己的PHP环境选择一个合适的.dll,压缩包的说明文档给出了适用范围:
    Driver file PHP version Thread safe? Use with PHP .dll
    php_sqlsrv_53_nts_vc6.dll
    5.3
    no
    php5.dll
    php_sqlsrv_53_nts_vc9.dll
    5.3
    no
    php5.dll
    php_sqlsrv_53_ts_vc6.dll
    5.3
    yes
    php5ts.dll
    php_sqlsrv_53_ts_vc9.dll
    5.3
    yes
    php5ts.dll
    php_sqlsrv_52_nts_vc6.dll
    5.2
    no
    php5.dll
    php_sqlsrv_52_ts_vc6.dll
    5.2
    yes
    php5ts.dll

        DLL名字称中的_vc6/_vc9表示你使用的PHP为vc6或vc9编译,PHP version中确定适用版本,Thread safe为该版本安全性,Use with PHP .dll是你PHP的安装方式。更多说明请参考文档。

        我这里选择的是php_sqlsrv_52_ts_vc6.dll,拷贝到php/ext/下,然后在php.ini中添加一行 “extension=php_sqlsrv_52_ts_vc6.dll”,重启WEB服务。phpinfo();查看一下,如果有“sqlsrv”扩 展项,就表示安装成功了。

    二、安裝Microsoft SQL Server Native Client
        这个是MSSQL的客户端存取程序,它提供了ODBC、OLE DB、ADO 等方式连接 MSSQL。 如果已经安装了MSSQL2005/2008,则已经安装了对应版本的此程序,不用单独安装了。

        Microsoft SQL Server Native Client 2005支持SQL Server 7、2000、2005
    下载地址:http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=50b97994-8453-4998-8226-fa42ec403d17,找到对应项后根据自己机器情况(X86/X64)选择下载。

        Microsoft SQL Server Native Client 2008支持SQL Server 2000、2005、2008
    下载地址:http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=c6c3e9ef-ba29-4a43-8d69-a2bed18fe73c,找到对应项后根据自己机器情况(X86/X64/IA64)选择下载。

    三、至此已经可以使用UTF8进行存取了
        新建一个UTF8编码的文件,测试一下:
    $connstr = array("Database"=>"test","Uid"=>"sa","Pwd"=>"xxx","CharacterSet" => "UTF-8");
    $conn = sqlsrv_connect('127.0.0.1',$connstr);
    if($conn==false) print_r(sqlsrv_errors(),true);
    $sql = "SELECT TOP 10 * FROM table";
    if($data = sqlsrv_query($conn, $sql))
    {
        while($row = sqlsrv_fetch_array($data,SQLSRV_FETCH_ASSOC))
        {
            print_r($row);
        }
    }
    sqlsrv_close($conn);



    四、ADODB支持
        看到上例可能要抓狂了,因为提供了全新的一套操作函数,使用起来不习惯,跟现有系统也不兼容。去下载了个最新版的ADODB后惊喜的发现它已经封装了该系列函数,帮我们解决了此问题。只需作个简单的修改:
    找到/adodb/drivers/adodb-mssqlnative.inc.php,在_connect方法后有一行:
    “ $connectionInfo = array("Database"=>$argDatabasename,'UID'=>$argUsername,'PWD'=>$argPassword);”
    改为:
    “ $connectionInfo = array("Database"=>$argDatabasename,'UID'=>$argUsername,'PWD'=>$argPassword,"CharacterSet" => 'UTF-8');”
      ADODB下载:http://adodb.sourceforge.net

    OK了,测试代码:
    $conn = ADONewConnection('mssqlnative');
    $conn->Connect(DB_HOST,DB_USER,DB_PASS,DB_NAME);
    $ADODB_FETCH_MODE= ADODB_FETCH_ASSOC;
    $sql = "SELECT * FROM table";
    $data = $conn->GetAll($sql);
    print_r($data);
    
  • 相关阅读:
    使用express框架创建服务器
    搭建第一个node服务器
    Node 与JS的区别
    node学习之路
    【每天一个linux命令】read
    【每天一个linux命令】awk
    【每天一个linux命令】wc
    【每天一个linux命令】sed
    【每天一个linux命令】tee
    【每天一个linux命令】find
  • 原文地址:https://www.cnblogs.com/fslnet/p/2081729.html
Copyright © 2011-2022 走看看