当前位置: 首页 > news >正文

闵行做网站公司如何建设网站赚钱

闵行做网站公司,如何建设网站赚钱,河南郑州哪里可以做公司网站,wordpress主题 好的一、关于UTF-8 UTF-8 Unicode Transformation Format-8bit。是用以解决国际上字符的一种多字节编码。 它对英文使用8位(即一个字节)#xff0c;中文使用24位(三个字节)来编码。 UTF-8包含全世界所有国家需要用到的字符#xff0c;是国际编码#xff0c;通用性强。 UTF-8编码…一、关于UTF-8 UTF-8 Unicode Transformation Format-8bit。是用以解决国际上字符的一种多字节编码。 它对英文使用8位(即一个字节)中文使用24位(三个字节)来编码。 UTF-8包含全世界所有国家需要用到的字符是国际编码通用性强。 UTF-8编码的文字可以在各国支持UTF8字符集额的浏览器上显示。 如果是UTF8编码则在外国人的英文IE也能显示中文他们无需下载IE的中文语言支持包。 二、关于GBK GBK 是国家标准GB2312基础上扩容后兼容GB2312的标准。 GBK的文字编码是用双字节来表示的即不论中、英文字符均使用双字节来表示为了区分中文将其最高位都设定成1。 GBK包含全部中文字符是国家编码通用性比UTF8差不过UTF8占用的数据库比GBK大。 三、关于utf8mb4 MySql 5.5 之前UTF8 编码只支持1-3个字节只支持BMP这部分的unicode编码区BMP是从哪到哪 戳这里 基本就是 0000 ~ FFFF 这一区。 从MySQL 5.5 开始可支持4个字节UTF编码utf8mb4一个字符最多能有4字节所以能支持更多的字符集。 utf8mb4 is a superset of utf8 tf8mb4兼容utf8且比utf8能表示更多的字符。 至于什么时候用看你做的什么项目了。。。 在做移动应用时会遇到IOS用户在文本的区域输入emoji表情如果不做一定处理就会导致插入数据库异常。 四、汉字长度与编码有关 MySql 5.0 以上的版本 1、一个汉字占多少长度与编码有关 UTF-8一个汉字 3个字节英文是一个字节 GBK 一个汉字 2个字节英文是一个字节 2、varchar(n) 表示n个字符无论汉字和英文MySql都能存入 n 个字符仅实际字节长度有所区别。 3、MySQL检查长度可用SQL语言 SELECT LENGTH(fieldname) FROM tablename 五、实际测试 1、首先使用utf8 创建 str_test 表。 CREATE TABLE str_test ( name_chn varchar(20) NOT NULL, name_en varchar(20) NOT NULL ) ENGINEInnoDB AUTO_INCREMENT62974 DEFAULT CHARSETutf8 然后插入值 mysql insert into str_test values (我爱Ruby, I Love Ruby!); Query OK, 1 row affected (0.02 sec) 打开irb 我爱Ruby.size 6 I Love Ruby!.size 12 从MySQL中查询出来的结果对比 mysql select * from str_test; -------------------------- | name_chn | name_en | -------------------------- | 我爱Ruby | I Love Ruby! | -------------------------- 1 row in set (0.02 sec) mysql select length(name_chn) from str_test; ------------------ | length(name_chn) | ------------------ | 10 | ------------------ 1 row in set (0.01 sec) 3[一个汉字一字节] * 2 1[一个英文一字节] * 4 10 mysql select length(name_en) from str_test; ----------------- | length(name_en) | ----------------- | 12 | ----------------- 1 row in set (0.00 sec) 10[一个英文一字节] * 1 2[空格一字节] * whitespace 12 2、使用 GBK 做测试 创建表 CREATE TABLE str_test ( name_chn varchar(20) NOT NULL, name_en varchar(20) NOT NULL ) ENGINEInnoDB AUTO_INCREMENT62974 DEFAULT CHARSETgbk 插入数据并且测试 mysql insert into str_test values (我爱Ruby, I Love Ruby!); Query OK, 1 row affected (0.00 sec) mysql select * from str_test; -------------------------- | name_chn | name_en | -------------------------- | 我爱Ruby | I Love Ruby! | -------------------------- 1 row in set (0.01 sec) GBK 中文是两个字节英文是一个字节。 mysql select length(name_chn) from str_test; ------------------ | length(name_chn) | ------------------ | 8 | ------------------ 1 row in set (0.00 sec) 2[中文两个字节] * 2 4[英文一个字节] * 1 8 mysql select length(name_en) from str_test; ----------------- | length(name_en) | ----------------- | 12 | ----------------- 1 row in set (0.00 sec) 10[英文一个字节] * 1 2[空格一个字节] * whitespace 12 六、关于varchar 最多能存多少值 mysql的记录行长度是有限制的不是无限长的这个长度是64K即65535个字节对所有的表都是一样的。 MySQL对于变长类型的字段会有1-2个字节来保存字符长度。 当字符数小于等于255时MySQL只用1个字节来记录因为2的8次方减1只能存到255。 当字符数多余255时就得用2个字节来存长度了。 在utf-8状态下的varchar最大只能到 (65535 - 2) / 3 21844 余 1。 在gbk状态下的varchar, 最大只能到 (65535 - 2) / 2 32766 余 1 使用 utf-8 创建 mysql CREATE TABLE str_test ( - id tinyint(1) NOT NULL, - name_chn varchar(21845) NOT NULL - ) ENGINEInnoDB AUTO_INCREMENT62974 DEFAULT CHARSETutf8 - ; ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBs mysql CREATE TABLE str_test ( - id tinyint(1) NOT NULL, - name_chn varchar(21844) NOT NULL - ) ENGINEInnoDB AUTO_INCREMENT62974 DEFAULT CHARSETutf8 - - - ; Query OK, 0 rows affected (0.06 sec) 使用gbk创建 当存储长度为 32768 失败~ mysql CREATE TABLE str_test ( - id tinyint(1) NOT NULL, - name_chn varchar(32768) NOT NULL - ) ENGINEInnoDB AUTO_INCREMENT62974 DEFAULT CHARSETgbk - ; ERROR 1074 (42000): Column length too big for column name_chn (max 32767); use BLOB or TEXT instead 当存储长度为 32767 失败~ mysql CREATE TABLE str_test ( - id tinyint(1) NOT NULL, - name_chn varchar(32767) NOT NULL - ) ENGINEInnoDB AUTO_INCREMENT62974 DEFAULT CHARSETgbk - ; ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBs 当存储长度为 32766 成功~ mysql CREATE TABLE str_test ( - id tinyint(1) NOT NULL, - name_chn varchar(32766) NOT NULL - ) ENGINEInnoDB AUTO_INCREMENT62974 DEFAULT CHARSETgbk - ; Query OK, 0 rows affected (0.03 sec) smallint 用两个字节存储所以 2[smallint] 32766 * 2[varchar存储长度] 2[2个字节来存长度] 65535 所以失败~ mysql CREATE TABLE str_test ( - id smallint(1) NOT NULL, - name_chn varchar(32766) NOT NULL - ) ENGINEInnoDB AUTO_INCREMENT62974 DEFAULT CHARSETgbk - ; ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBs 七、数值类型所占的字节 类型 所占字节 int 4 字节 smallint 2 字节 tinyint 1 字节 decimal 变长 官方关于decimal 的描述如下 Values for DECIMAL (and NUMERIC) columns are represented using a binary format that packs nine decimal (base 10) digits into four bytes. Storage for the integer and fractional parts of each value are determined separately. Each multiple of nine digits requires four bytes, and the “leftover” digits require some fraction of four bytes. The storage required for excess digits is given by the following table. 翻译为中文 使用二进制格式将9个十进制(基于10)数压缩为4个字节来表示DECIMAL列值。 每个值的整数和分数部分的存储分别确定。 每个9位数的倍数需要4个字节并且“剩余的”位需要4个字节的一部分。 下表给出了超出位数的存储需求 Leftover Digits Number Of Bytes 0 0 1 1 2 1 3 2 4 2 5 3 6 3 7 4 8 4 那decimal(10,2)占几个字节 1、首先 10 指的是整数与小数部分的总长度 2指的是小数部分的长度。那么整数部分就只有 10 - 2 8 位 2、因为整数与小数的存储市各自独立确定的所以他们各自所占用空间的综合就是所占的总空间了。 3、对表可知整数部分8位占了4个字节小数部分2位占了1个字节所以decimal(10,2)总共占了 4 1 5 个字节。 4、decimal(6,2) 整数部分(6 - 2 4) 位占2字节小数部分2位占1字节总共占3字节。 八、总结 varchar 字段是将实际内容单独存储在聚簇索引之外内容开头用1到2个字节表示实际长度(长度超过255时需要2个字节)因此最大长度不能超过65535。 UTF-8一个汉字 3个字节英文是一个字节 GBK 一个汉字 2个字节英文是一个字节 在utf-8状态下汉字最多可以存 21844个字符串, 英文也为 21844个字符串。 在gbk状态下汉字最多可以存32766个字符串英文也为21844个字符串。
http://wiki.neutronadmin.com/news/88393/

相关文章:

  • 网站制作 语言选择怎么做网页设计类型与风格
  • 优设网站广西建设工程质量安全监督网站
  • 12306网站为什么做那么差京东网上商城跟京东是一家吗
  • 去哪个网站做兼职教育培训机构网站模板
  • 爱站网关键词查询本地一键搭建wordpress
  • 郑州网站建设公司 艾特医学网站建设风格
  • 网站开发流程视频网络营销的营销方式
  • 昆明做网站的做网站一般有什么题目
  • 网站开发系统搭建四川网站建设设计公司哪家好
  • app网站开发重庆WordPress 发布文章 api
  • 东莞建筑建设网站建设wordpress搭建商城网站
  • 网站页面html静态化是什么意思做外贸怎么网站找客户信息
  • 官方网站撰写策划书百度竞价是什么工作
  • 建个网站做网络推广要花多少钱wordpress调用标签云
  • 外贸网站样式广东装修公司排名前十强
  • 建站公司技术服务费电子商务书城网站建设方案
  • 昆明c2c网站建设淄博电商网站建设
  • wordpress适合建什么网站吗京粉购物网站怎么做
  • o2o网站建设市场互联网建设发展
  • 专做茶叶的网站net112企业建站系统
  • 防内涵吧网站源码房地产店铺首页设计过程
  • 哪些网站是.net开发的企业微信下载
  • 做网站的广告词工商营业执照注册查询官网
  • 郑州网站建设找伟置免费搭建贴吧系统网站
  • 千图网cad免费素材图库北京网站建设 优化
  • 南通网站排名优化公司电子商务网站建设技巧
  • wordpress建站案例视频正规网站建设空间
  • 安徽企业网站建设wordpress跳转到外部链接
  • 网站使用流程图网站怎么提高收录
  • 国外素材设计欣赏网站建e网室内设计网图片