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

您好,歡迎來(lái)到思海網(wǎng)絡(luò),我們將竭誠(chéng)為您提供優(yōu)質(zhì)的服務(wù)! 誠(chéng)征網(wǎng)絡(luò)推廣 | 網(wǎng)站備案 | 幫助中心 | 軟件下載 | 購(gòu)買流程 | 付款方式 | 聯(lián)系我們 [ 會(huì)員登錄/注冊(cè) ]
促銷推廣
客服中心
業(yè)務(wù)咨詢
有事點(diǎn)擊這里…  531199185
有事點(diǎn)擊這里…  61352289
點(diǎn)擊這里給我發(fā)消息  81721488
有事點(diǎn)擊這里…  376585780
有事點(diǎn)擊這里…  872642803
有事點(diǎn)擊這里…  459248018
有事點(diǎn)擊這里…  61352288
有事點(diǎn)擊這里…  380791050
技術(shù)支持
有事點(diǎn)擊這里…  714236853
有事點(diǎn)擊這里…  719304487
有事點(diǎn)擊這里…  1208894568
有事點(diǎn)擊這里…  61352289
在線客服
有事點(diǎn)擊這里…  531199185
有事點(diǎn)擊這里…  61352288
有事點(diǎn)擊這里…  983054746
有事點(diǎn)擊這里…  893984210
當(dāng)前位置:首頁(yè) >> 技術(shù)文章 >> 文章瀏覽
技術(shù)文章

SQL Server中的字符存儲(chǔ)的問(wèn)題

添加時(shí)間:2014-2-28 16:59:26  添加: 思海網(wǎng)絡(luò) 

  數(shù)據(jù)庫(kù)中varchar和nvarchar以及字符串前綴'N'在實(shí)際應(yīng)用中的問(wèn)題,便做了一個(gè)小測(cè)試。測(cè)試的結(jié)論是我根據(jù)運(yùn)行結(jié)果得出的。不完全正確,還請(qǐng)高手指點(diǎn)。

  測(cè)試環(huán)境:windows server 2003 sp2(32bit) + sqlserver 2008 rtm

  以下為測(cè)試的SQL語(yǔ)句:

-- 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的結(jié)果為:

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

  由生成的結(jié)果可知:

  在SQLServer2008中,對(duì)于漢字和英文字母的存儲(chǔ):

  漢字:無(wú)論字符串前面是否加有前綴'N',都將中文隱式轉(zhuǎn)換為有'N'的類型,即Unicode字符,因?yàn)橹挥蠻niCode字符才能表示中文,1個(gè)字符占2個(gè)字節(jié)(即1個(gè)漢字占2個(gè)字節(jié))。

  字母:有無(wú)前綴'N'的情況不同。當(dāng)沒有前綴'N'時(shí),默認(rèn)采用ASCII的方式編碼,1個(gè)字符占1個(gè)字節(jié)(即1個(gè)字母占1個(gè)字節(jié));當(dāng)有前綴'N'時(shí),則采用Unicode的方式編碼,1個(gè)字符占2個(gè)字節(jié)(即1個(gè)字母占2個(gè)字節(jié))。

  INSERT Data的結(jié)果為:

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

  未插入行的報(bào)錯(cuò)信息皆為“將截?cái)嘧址蚨M(jìn)制數(shù)據(jù)”。

  由此可推論出:

  SQL Server對(duì)于插入數(shù)據(jù)庫(kù)中數(shù)據(jù)的長(zhǎng)度在兩方面同時(shí)加以限制:一、設(shè)置的最大字符數(shù);二、由最大字符數(shù)得到的相應(yīng)類型的最大字節(jié)數(shù)。

  由第2條插入語(yǔ)句的成功執(zhí)行可推測(cè)出:

  在某些情況下,即使英文字母前帶有前綴'N',數(shù)據(jù)庫(kù)引擎在執(zhí)行插入時(shí)有可能將數(shù)據(jù)隱式轉(zhuǎn)換成ASCII格式,以能夠?qū)?shù)據(jù)插入到數(shù)據(jù)庫(kù)。

  因此,我們也可以知道,在創(chuàng)建表定義列時(shí),為varchar和nvarchar指定的長(zhǎng)度,既是在限定字符數(shù),也是在限定字節(jié)數(shù)。

關(guān)鍵字:SQL Server、數(shù)據(jù)庫(kù)

分享到:

頂部 】 【 關(guān)閉
版權(quán)所有:佛山思海電腦網(wǎng)絡(luò)有限公司 ©1998-2024 All Rights Reserved.
聯(lián)系電話:(0757)22630313、22633833
中華人民共和國(guó)增值電信業(yè)務(wù)經(jīng)營(yíng)許可證: 粵B1.B2-20030321 備案號(hào):粵B2-20030321-1
網(wǎng)站公安備案編號(hào):44060602000007 交互式欄目專項(xiàng)備案編號(hào):200303DD003  
察察 工商 網(wǎng)安 舉報(bào)有獎(jiǎng)  警警  手機(jī)打開網(wǎng)站