日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

char和varchar的区别以及尾部空格问题 - sqlserver演示

發布時間:2025/4/14 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 char和varchar的区别以及尾部空格问题 - sqlserver演示 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

char是一個定長字段,假如申請了char(10)的空間,那么無論實際存儲多少內容.該字段都占用10個字符;
varchar是變長的,申請的只是最大長度,占用的空間為實際字符長度+1,最后一個字符存儲使用了多長的空間;

在檢索效率上來講,char > varchar;
因此在使用中,如果確定某個字段的值的長度,可以使用char,否則應該盡量使用varchar.例如存儲用戶MD5加密后的密碼,則應該使用char。

在char和varchar尾部加空格,檢索時char類型后的被刪掉,而varchar類型的保存。

以上是說的MySql;這個char和varchar的問題,各數據庫應該是一樣的;下面來在SqlServer看一下;

有一個學生表;先增加一個sex字段,類型char(5);

可能不好演示;再改為char(10);

編輯數據,在第一行sname列緊接文字后面手動敲三個空格;第一行和第二行sex列,緊接文字后面手動敲三個空格;

查看一下表的數據;

寫一段TSQL來看一下情況;

declare @name1 varchar(32),@name2 varchar(32)declare @sex1 char(10),@sex2 char(10)select @name1=sname from student where snum=1select @name2=sname from student where snum=2select @sex1=sex from student where snum=1select @sex2=sex from student where snum=2print @name1print @name2print @sex1print @sex2if @name1='張一'print 'true'elseprint 'false'if @name1='張一 'print 'true'elseprint 'false'if @sex2='女'print 'true'elseprint 'false'if @sex1='女 'print 'true'elseprint 'false'

?運行的情況如下;

if @name1='張一'
????? print 'true'
? else
????? print 'false'
? if @name1='張一?? '
????? print 'true'
? else
????? print 'false'

??? 這兩個if都輸出'true',說明TSQL自己處理了尾部空格;

if @sex2='女'
????? print 'true'
? else
????? print 'false'
? if @sex1='女?? '
????? print 'true'
? else
????? print 'false'

??? 這兩個if語句,第一個輸出'true',第二個輸出'false';如前所述:尾部加空格,檢索時char類型后的被刪掉;

打印出的字段內容如下;第一行sname列尾部加了空格,檢索出的內容帶尾部空格;sex列都是固定長度為10;

?

總結

以上是生活随笔為你收集整理的char和varchar的区别以及尾部空格问题 - sqlserver演示的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。