首頁 考試吧論壇 Exam8視線 考試商城 網絡課程 模擬考試 考友錄 實用文檔 求職招聘 論文下載 | ||
![]() |
2011中考 | 2011高考 | 2012考研 | 考研培訓 | 在職研 | 自學考試 | 成人高考 | 法律碩士 | MBA考試 MPA考試 | 中科院 |
|
![]() |
四六級 | 職稱英語 | 商務英語 | 公共英語 | 托福 | 雅思 | 專四專八 | 口譯筆譯 | 博思 | GRE GMAT 新概念英語 | 成人英語三級 | 申碩英語 | 攻碩英語 | 職稱日語 | 日語學習 | 法語 | 德語 | 韓語 |
|
![]() |
計算機等級考試 | 軟件水平考試 | 職稱計算機 | 微軟認證 | 思科認證 | Oracle認證 | Linux認證 華為認證 | Java認證 |
|
![]() |
公務員 | 報關員 | 銀行從業資格 | 證券從業資格 | 期貨從業資格 | 司法考試 | 法律顧問 | 導游資格 報檢員 | 教師資格 | 社會工作者 | 外銷員 | 國際商務師 | 跟單員 | 單證員 | 物流師 | 價格鑒證師 人力資源 | 管理咨詢師考試 | 秘書資格 | 心理咨詢師考試 | 出版專業資格 | 廣告師職業水平 駕駛員 | 網絡編輯 |
|
![]() |
衛生資格 | 執業醫師 | 執業藥師 | 執業護士 | |
![]() |
會計從業資格考試(會計證) | 經濟師 | 會計職稱 | 注冊會計師 | 審計師 | 注冊稅務師 注冊資產評估師 | 高級會計師 | ACCA | 統計師 | 精算師 | 理財規劃師 | 國際內審師 |
|
![]() |
一級建造師 | 二級建造師 | 造價工程師 | 造價員 | 咨詢工程師 | 監理工程師 | 安全工程師 質量工程師 | 物業管理師 | 招標師 | 結構工程師 | 建筑師 | 房地產估價師 | 土地估價師 | 巖土師 設備監理師 | 房地產經紀人 | 投資項目管理師 | 土地登記代理人 | 環境影響評價師 | 環保工程師 城市規劃師 | 公路監理師 | 公路造價師 | 安全評價師 | 電氣工程師 | 注冊測繪師 | 注冊計量師 |
|
![]() |
繽紛校園 | 實用文檔 | 英語學習 | 作文大全 | 求職招聘 | 論文下載 | 訪談 | 游戲 |
二、漢字亂碼問題
筆者曾經在使用ADO向SQL Server 6.5中追加或修改數據后,發現查詢出來的漢字都是亂碼,最初以為是客戶端的環境有問題,后來打開服務器端的數據庫,發現其中的漢字也都是亂碼,費了九牛二虎之力才找到原因:在追加和修改的過程中,ADO將字符進行了自動翻譯(AutoTranslate),翻譯后就成了亂碼(Microsoft給我們開了一個“小小”的玩笑),解決的辦法就是不讓它亂翻譯,具體操作如下:
如果ADO通過OLE DB直接連接到數據庫,則在Connection的ConnectionString中加入字符串:AutoTranslate=False;
如果ADO通過ODBC連接到數據庫,則在配置ODBC時,將“執行字符數據轉換”一項的勾去掉。
三、在SQL中處理含單引號的字符串
VB在寫SQL時,對字符串數據都用單引號引起來,如:
Select * from MyTable Where ID='FirstID'
若其中的FirstID為First'ID,即中間多出一個單引號,則上述寫法將導致錯誤,解決的辦法是將字符串中的每一個單引號用兩雙引號替換,下面的函數StrToSQL完成該功能,并用單引號將處理后的字符串引起來:
Private Function StrToSQL(ByVal strValue As String) As String
StrToSQL = "'" + Replace(strValue, "'", "'") + "'"
End Function
在寫SQL時如有字符串數據,不管其中有沒有單引號,都可以這樣使用:
strValue="First'Id"
strSQL="Select * from MyTable Where ID="+StrToSQL(strValue)
四、只返回查詢結果的前N個記錄
這是個老生常談的問題,稍有這方面經驗的人都會想到在SQL中用"Select Top"語句來完成此功能,如訪問Access數據庫時為:
Select top 50 * From MyTable
SQL Server 7.0和SQL Server 2000中都可以這樣,但在SQL Server 6.5中不行,它不支持"Select Top",筆者采用了一個折衷的辦法,使用SQL Server 6.5的"Set Rowcount"來限制記錄數,例如:
MyConnection.Execute "Set Rowcount 50"
......'執行查詢
MyConnection.Execute "Set rowcount 0"
最后一行表示取消記錄數據限制,這句千萬不能少,因為記錄數的限制在MyConnection的生存期都有效,所以其它的查詢也會受此限制,最多只返回50條記錄,筆者曾深受其害。
本文中涉及的內容的測試平臺為Visual Baisc 6.0 Enterprise+Service Pack 4。
相關推薦:北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |