亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

[Python]Python/PHP如何查詢sql server中NTEXT

系統 1793 0

[Python]Python/PHP 如何查詢 sql server中 NTEXT 類型數據

Version

Date

Creator

Description

1.0.0 .1

2006-11-23

鄭昀

草稿

?

繼續閱讀之前,我們假設您熟悉以下知識:

n ???????? Python /?PHP

n ???????? SQL Server 2000 SP4 以上版本的 Microsoft sql server

n ???????? pymssql

n ???????? NTEXT 類型

本文討論了在 Python 中,如果利用 pymssql 來連接 Microsft Sql server 2000 SP4 以上版本數據庫查詢 NTEXT 類型數據,如何成功返回數據。

在PHP中類似問題也可以這么解決。

?

pymssql - Simple MSSQL Python extension module ,當前我們使用的版本是

pymssql-0.7.4.win32-py2.4.exe

?

您可以遵循后文描述的執行步驟,在此之前,我們先描述一個常見的錯誤現象。

[ 常見錯誤現象 1]

關鍵詞 ????? Unicode data in a Unicode-only collation or ntext data

cannot be sent to clients using DB-Library

表象 ????????? 如果你的 sql server 2000 sp4以上版本的 數據庫中有一個字段是 NTEXT 類型,那么當你使用 pymssql 來做查詢的時候,您可能得到如下錯誤:

?

錯誤日志

MS SQL message: ntext data cannot be sent to clients using DB-Library (such as ISQL) or ODBC version 3.7 or earlier. (severity 16)

_mssql.error: SQL Server message 4004, severity 16, state 1, line 1:

Unicode data in a Unicode-only collation or ntext data cannot be sent

to clients using DB-Library (such as ISQL) or ODBC version 3.7 or earlier.

?

?

解釋 ?????????

這是因為我們的 pymssql 使用早期的 ODBC 函數集來獲取數據。而微軟后來引入了 ntext nvarchar 類型,而這是 Microsoft C-library 所不支持的。所以,連 pymssql 的說明檔里也這么建議:

注釋

It's the SQL Server complaining that it doesn't support pure Unicode

via TDS or older versions of ODBC. There's no fix for this error.

A workaround is to change the column type to NVARCHAR (it doesn't

exhibit this behaviour), or plain TEXT.

是不是真的要改變你的字段類型了呢?

可行的步驟:

只需要多執行一步即可。

      
        
          1
        
      
      
        
          
        
        
          
            
            
          
        
      
    
      
        
          聲明一句話:
        
        
          
          
        
      
    
      
        
          queryTEXTSIZE = str("SET TEXTSIZE 65536") 
    
          
          
        
      
    
      
        65536
      
      
        
          是我限定要返回
        
      
      
        NTEXT
      
      
        
          字段數據的最大長度,你可以設置的更大一點,比如
        
        
          
            1024000
          
            
            
          
        
      
    

2

然后執行這句 sql 語句:

oConn =

_mssql.connect(databaseHost, databaseUserName, databaseUserPwd)

ret = oConn.query(queryTEXTSIZE)

table = oConn.fetch_array()

3

然后,聲明你的原來的那個獲取 NTEXT 字段的 sql 語句如下所示:

修改的 sql 語句

SELECT cast ( field_name AS TEXT ) AS field_name

這個 field_name 所代表的字段本來類型是 NTEXT ,這里我們 CAST 它為 TEXT ,這就是一個技巧

4

接下來執行你的這個 sql 語句即可:

??? ret = oConn.query(query)

table = oConn.fetch_array()

?

[ 參考資料 ]

      
        
          
            1
          
          :《
        
      
      
        
          What means "Unicode data in a Unicode-only collation or ntext data cannot be sent to clients using DB-Library"?
        
      
      
        
            
            
          
        
      
    
?

Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1409306


[Python]Python/PHP如何查詢sql server中NTEXT類型數據


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 欧美黄色网页 | 精产网红自拍在线 | 亚洲欧美视频一区二区三区 | 久久精品国产400部免费看 | 四虎影院免费在线播放 | 老黄网站| 性感美女香蕉视频 | 在线看日本a毛片 | 亚洲最新在线 | 四虎视频网站 | 夜色福利视频 | 日韩毛片高清在线看 | 久久中文字幕久久久久91 | 亚欧免费视频 | 日韩精品中文字幕在线观看 | 久艾草国产成人综合在线视频 | 高清亚洲综合色成在线播放放 | 亚洲一区二区三区中文字幕 | 午夜a一级毛片一.成 | 天天干天天添 | 精品免费tv久久久久久久 | 美女日日日 | 欧美人与性动交α欧美精品图片 | 亚洲成av人片天堂网 | 99热在线精品免费播放6 | 久久久视频在线 | 欧美影院一区二区三区 | 国产人成久久久精品 | 国产一区二区在线 |播放 | 人人看人人鲁狠狠高清 | 欧美一区二区三区在线视频 | 深夜在线看片 | 午夜免费福利影院 | 久久99国产精品久久欧美 | 99久久精品国产综合一区 | 99热国产这里只有精品9九 | 超清波多野结衣精品一区 | 色综合欧美色综合七久久 | 国产精品成人扳一级aa毛片 | 99久久久精品免费观看国产 | 无遮挡一级毛片性视频不卡 |