MySql数据库varchar和java字符串length()长度的区别?

Java 中字符串以 Unicode 方式编码的, 其长度通常计算的是字符数,一个中文也算一个字符。

MySql中 varchar(n)类型字段,n所表示的也是字符数,并非字节数,所以字段可以插入<=n个字符。一个字符占用多少字节取决于所使用的字符编码,通常我使用UTF-8,Mysql中一个UTF-8编码的字符占3字节。

CREATE TABLE `group_space` (
  `GROUP_ID` decimal(16,0) NOT NULL,
  `USER_FILE_ID` decimal(18,0) DEFAULT NULL,
  `USER_ID` decimal(20,0) DEFAULT NULL,
  `GROUP_SIZE` decimal(10,0) DEFAULT NULL,
  `CREATE_TIME` timestamp NULL DEFAULT NULL,
  `REVIEW_STATUS` decimal(1,0) DEFAULT NULL,
  `GROUP_NAME` varchar(5) DEFAULT NULL,
  `LAST_OPTIME` timestamp NULL DEFAULT NULL,
  `PUBLIC_LEVEL` decimal(1,0) DEFAULT NULL,
  `ENTER_LEVEL` decimal(1,0) DEFAULT NULL,
  `GROUP_NUMBER` varchar(20) DEFAULT NULL,
  `GROUP_MODEL` decimal(3,0) DEFAULT NULL,
  `GROUP_STATUS` decimal(1,0) DEFAULT NULL,
  `UNI_CONTACT_ID` decimal(20,0) DEFAULT NULL,
  PRIMARY KEY (`GROUP_ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


其中GROUP_NAME字段,长度为5,即可以插入5个字符,utf8编码最长存入15字节。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL中,可以通过内置函数CHAR_LENGTH()和LENGTH()来查看字符串长度。其中,CHAR_LENGTH()函数可以返回字符串的字符个数,而LENGTH()函数可以返回字符串的字节数。 需要注意的是,字符串的最大长度取决于字符编码、储存长度和单行最大长度限制等因素。对于字符编码不同的情况下,字符所占用的字节数会有所变化。例如,在UTF8编码中,一个字符占用3个字节,所以字符串的最大长度为21845。而对于VARCHAR类型,它会占用1到2个字节来储存字符本身的长度长度小于等于255时占用1个字节,超过255时占用2个字节。此外,一张表中所有字段设置的长度之和不能超过65535字节,如果超过了这个限制,建表时会报错。如果需要储存更长的字符串,可以使用TEXT或BLOB类型。 举个例子,假设有一张名为user的表,其中的age字段存储了字符串类型的数据。通过查询该表,可以得到输出结果如下: ``` mysql> select * from user; ---- -------- | id | age | ---- -------- | 1 | 000002 | | 2 | 000033 | ---- -------- ``` 从输出结果可以看出,age字段的值为字符串类型,并且长度为6个字符。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [关于MySQL中的字段长度以及占用空间总结](https://blog.csdn.net/qq_45333238/article/details/125092611)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [【MySQL】常用字符类型长度和使用](https://blog.csdn.net/qq_36418453/article/details/105965408)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值