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演示的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: VC++环境OpenSSL简单编程入门
- 下一篇: 把自己的文件做成ISO镜像文件