MySQL数据类型 (1)数值类型 1、整数型 2、浮点型 3、定点型 (2)日期时间类型 (3)字符串类型 MySQL字段属性 1、空\不为空值:NULL、NOT NULL 2、主键:primary...,因为涉及记录长度问题 : MySQL中规定任何一条数据最长不能超过65535个字节 如果有任何一个字段允许为空,那么系统会自动从整个记录中保存一个字节来存储NULL; text文本不占用记录长度,额外存储...主键的用途:主键的主要用途是用来唯一标识每一条记录,比如我们想将两个表(学生表跟老师表)的多对多关系封装到一个表中,这个抽取的映射字段一般都是各自的主键。...;并且由于主键的数据的不可重复性,也用来约束数据的唯一性。 唯一键:unique key 唯一键的功能与主键有点类型,但不同的是主键只能有一个,唯一键可以有多个,而且唯一键的字段的数据允许为空。...(不给这个字段插入数据的情况下) 自增长的前提是这个字段必须是一个“索引”,比如主键、唯一键 自增长的前提这个字段的数据类型是一个数值型的,(如果给了float,也不会增长成小数,而仅仅是整数) 一个表只能有一个自增长
MySQL之字符集 字符集介绍 gbk/gb2312 gbk/gb2312 采用双字节字符集,不论中、英文字符均使用双字符来表示,为了区分中文,将其最高位都设定成1 gb2312是gbk的子集,gbk...是gb18030的子集,gb2312仅能存储简体中文字符 gbk包括中日韩字符的大字符集 通常使用gbk字符集足够 国际通用性比utf8差,不过utf8占用的数据库比gbk大(utf8是三字节字符集)...(server) char类型 char(N):N代表的是字符个数(也叫字符长度)、而非bytes char(N):是固定长存储,占用定长的存储空间,不足的部分用空格填充;MySQL处理char(N)类型时...存储机制:在不够N长度时,MySQL在存储数据时,需要用填充特殊的空格,而非十六进制的20 思考: char(30),在不同的字符集中最多能存放多少个字母、汉字,以及占用空间情况 gbk: 可以存放...(长度小于255字节,使用一个字节来表示长度;大于255字节使用两个字节来表示长度) 修改数据库实例字符集 临时生效 mysql> set character_set = 'gbk'; mysql> set
MySQL 服务器默认字符集和排序规则分别是 utf8mb4 和 utf8mb4_0900_ai_ci,但是您可以在服务器、数据库、表、列和字符串字面量级别指定字符集。...2.支持的字符集 MySQL 支持多种字符集,包括多个 Unicode 字符集。...使用 SHOW CREATE TABLE 语句可以查看表中字段的字符集和排序规则。 7.字符串常量字符集 另外,MySQL 中的字符串常量也有字符集和排序规则。...在这个过程中,还会涉及到以下字符集设置: 客户端语句使用的字符集,MySQL 使用 character_set_client 的设置作为客户端字符集。...服务器接收到语句之后需要将其转换为哪种字符集,MySQL 使用 character_set_connection 的值作为转换的目标字符集。同时它也是字符串常量默认的字符集。
MySQL 添加列,修改列,删除列 示例:ALTER TABLE tb_financial MODIFY CREATE_TIME DATETIME(3) DEFAULT NULL COMMENT '录入时间...'; ALTER TABLE:添加,修改,删除表的列,约束等表的定义。...); 删除列:alter table 表名 drop column 列名; 修改列名MySQL: alter table bbb change nnnnn hh int; 修改列名SQLServer...---- MySQL 查看约束,添加约束,删除约束 添加列,修改列,删除列 查看表的字段信息:desc 表名; 查看表的所有信息:show create table 表名; 添加主键约束:...alter table 表名 add column 列名 varchar(30); 删除列:alter table 表名 drop column 列名; 修改列名MySQL: alter table
在mysql中查看字符集: show variables like ‘%char%’; 如果database和server都不是utf8,则需要配置mysql的配置文件。...在 /etc/mysql/my.cnf 中,[mysqld]的配置下,添加: character_set_server=utf8 init_connect='SET NAMES utf8' 重启mysql...database时: CREATE DATABASE IF NOT EXISTS xxxx DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; 在java中连接mysql...时这样设置: datasources.url=jdbc:mysql://192.168.1.1:3306/xxxx?
首先是查看字符集格式 show variables where variable_name like '%character%' 然后是存储过程,用于修改表内所有字段的字符集 DROP PROCEDURE...DELIMITER $$ CREATE PROCEDURE addColumn () BEGIN -- 定义表名变量 DECLARE s_tablename VARCHAR ( 100 ); /*显示表的数据库中的所有表...s_tablename; END WHILE; CLOSE cur_table_structure; END; $$ #执行存储过程 CALL addColumn (); 然后还可以修改mysql
到底是什么原因导致出现查询结果为乱码呢,本文主要通过演示来理解乱码产生的原因,以及如何解决字符集乱码,供大家参考。...– 在my.cnf中未配置客户端字符集,如果配置后,则使用配置文件中设定的字符集 [root@centos7 ~]# export LANG=en_US.UTF-8 [root@centos7...character_set_connection: 告诉字符集转换器,转换成什么编码? character_set_results: 查询的结果用什么编码?...如果以上三者都为字符集N,可简写为set names ‘N’; 乱码产生的原因如下: a、插入或读取时对应编码环节发生转换导致数据丢失。...大于等于数据存入的字符集,否则会丢失数据 比如:如存储的字符为utf8,而返回character_set_results为gbk,数据被截断 3、所有变量使用统一的字符编码,如utf8或者utf8mb4
哈喽大家好,拖更很久了,之前在忙好多公司的事情,年底啦,我们会坚持继续更新,来帮助大年年初找到更好的机会。...mysql不管是互联网还是传统it,我们都是必会的技术之一,那我们会从浅入深进行mysql的全部讲解。好啦,不多说,上货。...字符集 我们使用mysql时,不管是库还是表,我们都要设置字符集,而我们常用的字符集都有什么呢? utf8 也就是utf8mb3,用1到3个字节表示一个字符。...比较规则 一个字符集可以有多个比较规则,其中有一个默认的比较规则;一个比较规则必须对应一个字符集。...规则是比较字符的16进制字节码。 字符集与比较规则的级别 字符集级别有4种。 服务器级别 数据库级别 表级别 列级别
一、MySQL字符集编码简单介绍 在使用MySQL时要注意6个需要编码的地方:系统的编码、客户端、服务端、库、表、列。...字符集编码不仅影响数据存储,还影响client程序和数据库之间的交互.在mysql中输入命令show session variables like '%char%'能够看到例如以下一些字符集(下面是以win10...,通常就是utf8,不要去改动它. character_sets_dir:这是mysql字符集编码存储文件夹. character_set_filesystem:这是文件系统字符集编码,主要用于解析用于文件名称的字符串字面值...二、MySQL字符集编码层次 第一部分主要是归纳了MySQL文档中关于字符集编码的说明。这部分主要说明下MySQL中字符集编码层次:服务端-->数据库-->表-->字段。 ...三、MySQL连接字符集 前面谈到的编码内容基本都不会产生乱码问题,mysql中容易产生乱码的地方在character_set_client, character_set_connection, character_set_results
一看都是utf-8编码的,但是库里还是报错,就很奇怪。 表字符集: ? 将表字符集都改成utf8,运行起来还是报错。...可以在客户端工具上直接修改,也可以使用以下语句修改: alter table medicine_product default character set utf8; 库字符集: ?...将库字符集也改成utf8,还是报错,吐血!!!但是还得继续。...最后查看表创建时设置的字符集 SHOW CREATE TABLE medicine_order_total; CREATE TABLE `medicine_order_total` ( `id` bigint...table medicine_order_total change medicine_order_total medicine_name varchar(50) character utf8; 其他的字段也这样处理
对数据库来说,字符集更加重要,因为数据库存储的数据大部分都是各种文字,字符集对数据库的存储,处理性能,以及日后系统的移植,推广都会有影响。...MySQL5.6目前支持几十种字符集,包括UCS-2,UTF-16,UTF-16LE,UTF-32,UTF-8和utf8mb4等Unicode字符集。 根据应用的需求,考虑以下几方面的因素。...对MySQL来说,目前就是UTF-8 如果应用中涉及已有数据的导入,就要充分考虑数据库字符集对已有数据的兼容性。...如果数据库需要做大量的字符运算,如比较,排序等,那么选择定长字符集可能更好,因为定长字符集的处理速度要比变长字符集的处理速度快。...如果所有客户端程序都支持相同的字符集,则应该优先选择该字符集作为数据库字符集,这样可以避免因字符集转换带来的性能开销和数据损失。
墨墨导读:字符集是一组符号和编码。collation是一组用于比较字符集中的字符的规则。 MySQL的字符集从latin1经过utf8 到utf8mb4 ,算是经历曲折的路线。...特别是从使用一个字符集变更另一个字符集时,实践当中都非常无奈,不是没办法,而是麻烦。到了MySQL8.0多出了一个字符集utf8mb4_0900_*的字符集,有必要了解一下。 1....字符集基础 先了解下MySQL字符集都有哪些地方使用,进入数据库VARIABLES参数一目了然: mysql> SHOW VARIABLES WHERE variable_name LIKE '%character...MySQL8.0 utf8mb4 Unicode字符集一个新的通用排序归类,被命名为utf8mb4_0900_ai_ci。...字符集配置 mysql字符集如何设置,更改操作: 1)my.cnf配置文件信息,建议初始化时就设置好。
标签:Excel技巧 有时候,我们使用Excel建立了大的数据库,但其中的某些列是隐藏的。现在,想将所有列(未隐藏列和隐藏列)的宽度进行更改,例如改为5。...然而,如果选择工作表中的所有列,然后使用功能区“开始”选项卡“单元格”组中的“格式——列宽”命令来修改列宽,此时隐藏的列将会被取消隐藏。...解决上述问题的一个方法是:使用功能区“开始”选项卡“单元格”组中的“格式——默认列宽”命令,如下图1所示。 图1 单击“默认列宽”命令后,会弹出一个名为“标准列宽”的对话框,如下图2所示。 图2
的字符集转换为connection的字符集, MySQL将编码转换后的数据存储到MySQL表的列上, 在存储时, 会再判断编码是否与列字符集上的编码是否一致, 如果不一致需要再次转换....查询流程字符集转换过程 表(列)字符集-->character_set_result 结果转换为与客户端相同的字符集再传递给客户端....只修改库的字符集, 影响以后创建的表的默认定义;对于已创建的表的字符集不受影响.一般在数据库修改字符集即可, 表和列都默认采用数据库的字符集. mysql> alter database database_name...character set xxx; (4) 修改表的字符集 只修改表的字符集, 影响后续该表新增列的默认定义, 已有列的字符集不受影响. mysql> alter table table_name...mysql> alter table table_name convert to character set xxx; (6) 修改列字符集 mysql> alter table table_name
上面提到的mysql连接,缓存,解析,优化都数据mysql service,他们都会调用各式各样的api来访问最后说的存储引擎。...(所以在排序的时候,如果排序没有区分大小写或者有异常,可以看看他的比较级是什么) Mysql字符集的比较规则和字符集分为四个模块:服务器级别、数据库级别、表级别、列级别。...表级别:和数据库设置一样,如果表级别没有指定字符集和比较级,则继承数据库的字符集和比较级所在规则。 列级别:和表级别设置一样,如果列级别没有指定字符集和比较级,则继承表的字符集和比较级所在规则。...这上面有一个共同的特点,当修改了字符集,则自动变成当前字符集对应的比较级,如果修改了比较级,则自动变成对应的字符集。...Mysql中字符集的转换 如果存入的是utf-8的编码,然后解析的是gbk的,这时候就会解码失败,于是我们看到的就是一堆乱码。
本期的文章源于工作中,需要固定label的位置,便于在spark模型中添加或删除特征,而不影响模型的框架或代码。...spark的jupyter下使用sql 这是我的工作环境的下情况,对你读者的情况,需要具体分析。...sql = ''' select * from tables_names -- hdfs下的表名 where 条件判断 ''' Data = DB.impala_query(sql...) -- 是DataFrame格式 **注意:**DB是自己写的脚本文件 改变列的位置 前面生成了DataFrame mid = df['Mid'] df.drop(labels=['Mid'], axis...=1,inplace = True) df.insert(0, 'Mid', mid) # 插在第一列后面,即为第二列 df 缺失值填充 df.fillna(0) 未完待补充完善。
# 理解MySql字符集 # 字符集 字符集即为字符编码的集合。...# MySql中的字符集 MySql是一款关系型数据库,它存储的数据不应该受限于特定的语言文字,所以它支持不同字符集。...,列才是我们真正存储数据的地方:要储存必然离不开编码的问题。...# 设置修改MySql中的字符集 MySql默认字符集 在安装MySql的时候我们可以通过源码编译的方式设置字符集,当然这种安装方式比较难就不做说明了,真实的环境中这么做的好处并不明显。...[table] 查看列字符集 show full columns from [table]
将字符映射成二进制数据的过程叫编码,将二进制数据映射到字符的过程叫做解码 ASCII字符集: 有128个字符。包括空格/标点符号/数字/大小写字母和不可见字符。...UTF-8字符集:收录了当今世界各个国家地区使用的字符,并且还在扩充。它兼容ASCII字符集。采用变长编码方式,编码一个字符时需要使用1到4字节。 mysql 不区分字符集和编码方案的概念。...mysql utf8mb3: "阉割"过的utf-8字符集,只使用1-3个字节表示字符。 mysql utf8mb4: 正宗的utf-8字符集,使用1-4个字节表示字符。...mysql 中utf8是 utf8mb3的别名。...字符集与比较规则有四个级别:服务器级别/数据库级别/表级别/列级别 mysql> SHOW variables like "%character_set_server%"; +-------------
Mysql中的列类型: 数字类型 字符串类型 布尔型 日期时间类型 数字类型: 1个字节=8比特,但数字里有一个比特用于符号占位 TINYINT 占用1个字节,表示范围:-128~127 SMALLINT...支持的范围是1000-01-01 ~ 9999-12-31 TIME 支持的范围是00:00:00 ~ 23:59:59 DATETIME 支持的范围是1000-01-01 00:00:00 ~ 9999...-12-31 23:59:59 列上的约束: Constraint:约束,列上的值往往是有限制的,如: 性别:只能取男或女 政治面貌:只能取党员、团员、群众 高考成绩:FLOADT(4,1) 取值有规则...表中所有的记录行会自动按照主键列上的值进行排序。 一个表至多只能有一个主键列。 唯一约束: 列名 类型 UNIQUE 声明为“唯一”的列上不能出现重复值,但可以出现多个NULL值。...非空约束: 列名 类型 NOT NULL 声明为“非空”约束的列上不能出现NULL,但可以重复 检查约束对于Mysql不支持 默认值约束 列名 类型 Default 值 声明为“默认值”约束的列上没有值的将会默认采用默认设置的值
领取专属 10元无门槛券
手把手带您无忧上云