1. > 电脑手机 >

char和varchar(char和varchar哪个效率高)

char 和varchar的区别

最好的解释就是看SQL

Server自带的联机丛书,这是我从上面摘录的:

char和varchar都是字符串类型的>>>>

char:

固定长度的非

Unicode

字符数据,最大长度为

8,000

个字符。

varchar:

可变长度的非

Unicode

数据,最长为

8,000

个字符。

nchar是Unicode

字符串类型的>>>>

nchar

固定长度的

Unicode

数据,最大长度为

4,000

个字符。

用Unicode编码的字符串,结果是字符的整数值.

参考资料:SQL

Server联机丛书

char和varchar的区别

区别:

1.CHAR的长度是固定的,而VARCHAR2的长度是可以变化的,

比如,存储字符串“abc",对于CHAR

(10),表示你存储的字符将占10个字节(包括7个空字符),而同样的VARCHAR2

(10)则只占用3个字节的长度,10只是最大值,当你存储的字符小于10时,按实际长度存储。

2.CHAR的效率比VARCHAR2的效率稍高。

3.目前VARCHAR是VARCHAR2的同义词。工业标准的VARCHAR类型可以存储空字符串,但是oracle不这样做,尽管它保留以后这样做的权利。Oracle自己开发了一个数据类型VARCHAR2,这个类型不是一个标准的VARCHAR,它将在数据库中varchar列可以存储空字符串的特性改为存储NULL值。如果你想有向后兼容的能力,Oracle建议使用VARCHAR2而不是VARCHAR。

varchar和char有什么区别,举例说明

区别:

1.char的长度是固定的,而varchar2的长度是可以变化的,

比如,存储字符串“abc",对于char

(10),表示你存储的字符将占10个字节(包括7个空字符),而同样的varchar2

(10)则只占用3个字节的长度,10只是最大值,当你存储的字符小于10时

Java语言中char和varchar有何区别?

1、最大长度

char最大长度是255字符,varchar最大长度是65535个字节。

2、定长

char是定长的,不足的部分用隐藏空格填充,varchar是不定长的。

3、空间使用

char会浪费空间,varchar会更加节省空间。

4、查找效率

char查找效率会很高,varchar查找效率会更低。

5、尾部空格

char插入时可省略,vaechar插入时不会省略,查找时省略。

char和varchar(char和varchar哪个效率高)char和varchar(char和varchar哪个效率高)


varchar和char的区别

varchar和char的区别:

1、储存长度的不同

char和varchar是mysql中的两个相似的列,都可以存储字符和字符串。但是char存储的列的长度是不可变的,varchar存储的列的长度是可变的。

2、定义的不同

当定义列为varchar(2)时,存入比2个字符以上的数据时,会出现两种情况:

①sql mode为严格模式时,插入2个字符以上的数据就会报错。

②sql mode为非严格模式时,MySql会自动将超出的字符截取,保留符合的字符。

3、开启sql mode的方式不同

①先执行select @@sql_mode,复制查询出来的值并将其中的NO_ZERO_IN_DATE,NO_ZERO_DATE删除,然后执行set sql_mode = '修改后的值'或者

set session sql_mode='修改后的值';,例如:set session sql_mode='STRICT_TRANS_TABLES';改为严格模式此方法只在当前会话中生效,关闭当前会话就不生效了。

②先执行select @@global.sql_mode,复制查询出来的值并将其中的NO_ZERO_IN_DATE,NO_ZERO_DATE删除,然后执行set global sql_mode = '修改后的值'。

此方法在当前服务中生效,重新MySQL服务后失效

③在mysql的安装目录下,或my.cnf文件(windows系统是my.ini文件),新增sql_mode = ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,

ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

添加my.cnf如下:

[mysqld]sql_mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER

然后重启mysql。

此方法永久生效.当然生产环境上是禁止重启MySQL服务的,所以采用方式二加方式三来解决线上的问题,那么即便是有一天真的重启了MySQL服务,也会永久生效了

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, website.service08@gmail.com 举报,一经查实,本站将立刻删除。

联系我们

工作日:9:30-18:30,节假日休息