亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

SQL Server中的字符存儲的問題

添加時間:2014-2-28 16:59:26  添加: 思海網絡 

  數據庫中varchar和nvarchar以及字符串前綴'N'在實際應用中的問題,便做了一個小測試。測試的結論是我根據運行結果得出的。不完全正確,還請高手指點。

  測試環境:windows server 2003 sp2(32bit) + sqlserver 2008 rtm

  以下為測試的SQL語句:

-- Create Table
USE DBUser;
IF OBJECT_ID('dbo.Test','U') IS NOT NULL
DROP TABLE dbo.Test;
CREATE TABLE dbo.Test
(
nvarStr NVARCHAR(2) NULL,
varStr VARCHAR(2) NULL,
rowNum INT NULL
);
-- Get DataLength
SELECT length_DATALENGTH_1 = DATALENGTH('li');
SELECT length_DATALENGTH_2 = DATALENGTH('lili');
SELECT length_DATALENGTH_3 = DATALENGTH(N'li');
SELECT length_DATALENGTH_4 = DATALENGTH(N'lili');
SELECT length_DATALENGTH_5 = DATALENGTH('李培');
SELECT length_DATALENGTH_6 = DATALENGTH(N'李培');
-- INSERT Data
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES('li','li',1);
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES(N'li',N'li',2);
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES('lili','li',3);
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES(N'lili',N'li',4);
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES('li','李培',5);
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES(N'li',N'李培',6);
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES('李培','li',7);
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES(N'李培',N'li',8);
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES('李培','李培',9);
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES(N'李培',N'李培',10);
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES('李培','李',11);
INSERT INTO dbo.Test(nvarStr,varStr,rowNum) VALUES(N'李培',N'李',12);
-- Query Data
SELECT * FROM dbo.Test;

  ---------------------------------------------------------

  Get DataLength的結果為:

length_DATALENGTH_1:2
length_DATALENGTH_2:4
length_DATALENGTH_3:4
length_DATALENGTH_4:8
length_DATALENGTH_5:4
length_DATALENGTH_6:4

  由生成的結果可知:

  在SQLServer2008中,對于漢字和英文字母的存儲:

  漢字:無論字符串前面是否加有前綴'N',都將中文隱式轉換為有'N'的類型,即Unicode字符,因為只有UniCode字符才能表示中文,1個字符占2個字節(即1個漢字占2個字節)。

  字母:有無前綴'N'的情況不同。當沒有前綴'N'時,默認采用ASCII的方式編碼,1個字符占1個字節(即1個字母占1個字節);當有前綴'N'時,則采用Unicode的方式編碼,1個字符占2個字節(即1個字母占2個字節)。

  INSERT Data的結果為:

nvarStr varStr rowNum
li   li   1
li   li   2
李培   li   7
李培   li   8
李培   李   11
李培   李   12

  未插入行的報錯信息皆為“將截斷字符串或二進制數據”。

  由此可推論出:

  SQL Server對于插入數據庫中數據的長度在兩方面同時加以限制:一、設置的最大字符數;二、由最大字符數得到的相應類型的最大字節數。

  由第2條插入語句的成功執行可推測出:

  在某些情況下,即使英文字母前帶有前綴'N',數據庫引擎在執行插入時有可能將數據隱式轉換成ASCII格式,以能夠將數據插入到數據庫。

  因此,我們也可以知道,在創建表定義列時,為varchar和nvarchar指定的長度,既是在限定字符數,也是在限定字節數。

關鍵字:SQL Server、數據庫

分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站