日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

發布時間:2025/4/14 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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演示的全部內容,希望文章能夠幫你解決所遇到的問題。

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