0x01

mysql的两种方向:

  开发DBA:数据库设计(E-R关系图)、sql开发、内置函数、存储历程(存储过程和存储函数)、触发器、时间调度器(event scheduler)
  运维---->管理DBA:安装、升级、备份、恢复、用户管理、权限管理、监控、分析、基准测试,语句优化(SQL语句)、数据字典,按需要配置服务器(服务器变量:MyISAM,InnoDB,缓存,日志)
SQL 语言组成部分:
DDL:数据定义语言
DML:数据操作语言
完整性定义语言,DDL的一部分功能
主键约束、外键约束、唯一键约束、条件约束、非空约束、事务约束
视图定义:虚表,存储下来的select语句
事务控制:
嵌入式SQL和动态SQL:
DCL:数据授权语言

数据类型的功用:
1.存储的值类型
2.占据的存储空间大小
3.定长,变长
4.如何被索引及排序
5.是否能够被索引

数据字典:依赖系统目录(花名册)(system catalog)
保存数据库服务器上的元数据
元数据:
关系的名字
每个关系的各字段的名字
各字段的数据类型和长度
约束
每个关系上的视图的名字及视图的定义
授权用户的名字
用户的授权和账户信息

统计类的数据
每个关系字段的个数
每个关系中行数
每个关系的存储方法

保存元数据的数据库
information_schema
mysql
performance_schema

数据类型:
字符型
数值型
精确数值型
整型

十进制数据:decimal
近似数值型
单精度浮点型
双精度浮点型
日期时间型
日期型
时间型
日期时间型
时间戳
year
布尔型
内建类型
enum(枚举)
set(集合)

数值型:TINYINT          SMALLINT          MEDIUMINT        INT        BIGINT       DECIMAL      FLOAT     DOUBAL

字符型:CHAR 255个字符          VARCHAR 65535个字符            TINYTEXT          TEXT            MEDIUMTEXT         LONGTEXT         BINARY        VARBINARY     TINYBLOB

BLOB        MENDIUMBLOB        LONGBLOB        ENUM          SET

日期时间型:DATE      TIME       DATETIME      TIMESTAMP     YEAR

0x02

字符型(char、varchar和text)常用的属性修饰符:
NOT NULL:非空约束
NULL:允许为空
default ‘string’:默认值,不适用于text类型
CHARACTER SET 字符集

show variables like '%char%' 查看默认的字符集
show character set 查看数据库支持的字符集

show collation 排序规则
collation '规则':修改排序规则

binary,varbinaray和blob字符常用的属性修饰符
NOT NULL
NULL
default 不适用与blob

整形的常用属性修饰符
AUTO_INCREMENT:自动增长
前提:非空,且唯一,支持索引
LAST_INSERT_ID():可以查看上次增长的数值,当插入多行时,只记录第一行 select last_insert_id();
UNSIGNED:无符号
NULL
NOT NULL
DEFAULT

TRUNCATE 用来清空表中数据    truncate

浮点型常用修饰符:
NULL
NOT NULL
UNSIGNSD
DEFAULT
使用g,f来定义总共有多少数字和小数点后有多少数字

日期时间型常用的修饰符
NULL
NOT NULL
DEFAULT

ENUM和SET的修饰符
NULL
NOT NULL
DEFAULT ‘’

0x03

MySQL有内置的SQL模式SQL_MODE:用来定义字符超出的操作和模仿别的数据库的类型,通过修改全局变量
mysql的默认模式 对超过字符类型的数据截取掉 char(3) 插入 hello ---最终结果是 hel 后面被截取掉
sql_mode 的三种常用的模式有:
TRADITIONAL 使用传统模式
STRICT_TRANS_TABLES 仅对支持事务的表的严格模式
STRICT_ALL_TABLES 对所有表使用严格模式
show global variables like 'sql_mode';

设定服务器变量的值:通常仅用于支持动态的变量
支持修改的服务器变量
动态变量:可以在MySQL运行时修改
静态变量:与配置文件中修改其值,并重启后方能生效
服务器变量从其生效范围来讲,分两类
全局变量:服务器级别,修改之后仅对新建立的会话生效
回话变量:会话级别,仅对当前会话有效
会话建立时,从全局继承各变量
查看服务器变量

格式:
mysql> show [{global|session}] variables [like ''];
mysql> select @@{globa|session}.variable_name

实例:
mysql> mysql> select * from information_schema.GLOBAL_VARIABLES where VARIABLE_NAME='SOME_VARIABLE_NAME'; 查看全局变量
mysql> mysql> select * from information_schema.SESSION_VARIABLES where VARIABLE_NAME='SOME_VARIABLE_NAME'; 查看会话变量

修改变量:
前提:默认仅管理员有权限修改全局变量
mysql> set {global|session} variable_name='value';
set session sql_mode='STRICT_ALL_TABLES';     ------更改sql_mode的模式为  STRICT_ALL_TABLES
更改为上面模式, 对有超过字符类型的数据直接拒绝写入,
select @@session.sql_mode;

查看:
select * from information_schema.SESSION_VARIABLES where VARIABLE_NAME='sql_mode';
select * from information_schema.GLOBAL_VARIABLES where VARIABLE_NAME='sql_mode';

注意:无论是全局还是会话级别的动态变量修改,在重启mysql后都会失效,想永久有效,可以定义在配置文件中的响应段中[mysqld]

查看mysql服务器变量有哪些命令行参数有哪些 mysqld --help --verbose

mysql基础-数据类型和sql模式-学习之(三)的更多相关文章

  1. MySQL(2)-数据类型和Schema

    一.数据类型 只介绍基本的数据类型. MySQL中选择合适的数据类型还是很有必要的,下面是一些通用原则: 小的就是好的 一般情况下,应该尽量使用可以正确存储数据的最小数据类型.更小的数据类型通常更快, ...

  2. P4语法(1)基础数据类型和Header

    文章学习自:P4语言编程详解 由于原文有一点的年份,所以也继续阅读了相关的最新规范. P4语言规范 基础数据类型 布尔型(bool) 运算符 描述 and 双目运算符,结果为布尔型 or 双目运算符, ...

  3. 在C#项目中需要用double类型操作MSSQL float类型数据(附C#数据类型和SQL数据类型对照)

    C#操作SQL Float类型,数据会多很多小数,原来是C#的float和sql的float类型不一致.以下是数据库中与C#中的数据类型对照. /// <summary> /// 数据库中 ...

  4. C#数据类型和SQL数据类型对照

    C#操作SQL Float类型,数据会多很多小数,原来是C#的float和sql的float类型不一致        /// <summary>        /// 数据库中与C#中的数 ...

  5. 《Python》 基础数据类型和for循环

    一.基础数据类型 总览 int:用于计算,计数,运算等.1.2.3.100... str:‘这些内容’,用于少量数据的存储,便于操作. bool:True,False,两种状态,机器反馈给用户的对,错 ...

  6. Sql Server中的数据类型和Mysql中的数据类型的对应关系(转)

    Sql Server中的数据类型和Mysql中的数据类型的对应关系(转):https://blog.csdn.net/lilong329329/article/details/78899477 一.S ...

  7. Java数据类型和MySql数据类型对应一览

    类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述             VARCHAR L+N VARCHAR java.lang.String 12   CHAR N ...

  8. MySql数据类型和Java数据类型对应一览

    类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述             VARCHAR L+N VARCHAR java.lang.String 12   CHAR N ...

  9. Java数据类型和MySql数据类型对应一览 [转]

    类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述             VARCHAR L+N VARCHAR java.lang.String 12   CHAR N ...

随机推荐

  1. VST的安装

    对需要使用VST的用户,你可以到http://www.soft-gems.net/去免费下载没有使用限制.没有广告的VST.包括例子程序以及说明文档也可以下载到,下载完成后,就是安装,以前版本的VST ...

  2. POJ3693 Maximum repetition substring 后缀数组

    POJ - 3693 Maximum repetition substring 题意 输入一个串,求重复次数最多的连续重复字串,如果有次数相同的,则输出字典序最小的 Sample input ccab ...

  3. 14.4 Go Xorm

    14.4 Go Xorm 获取xorm go get -u -v github.com/go-xorm/xorm xorm增删改查 /** * 应用程序 * 同目录下多文件引用的问题解决方法: * h ...

  4. MongoDB启动闪退问题完美解决

    如果你看到这篇文章,说明你也遇到了启动MongoDB闪退的情况.由于只是学习MongoDB,所以很多人不想使用MongoDB的安装版,而使用免安装版.但是在启动mongod.exe 的时候,就会出现闪 ...

  5. Hyperledger Fabric——balance transfer(二)注册用户

    详细分析blance transfer示例的用户注册(register)与登录(enroll)功能. 源码分析 1.首先分析项目根目录的app.js文件中关于用户注册和登录的路由函数.注意这里的tok ...

  6. 牛客网挑战赛19 B,C,F

    链接:https://www.nowcoder.com/acm/contest/131/B来源:牛客网 矩阵 M 包含 R 行 C 列,第 i 行第 j 列的值为 Mi,j. 请寻找一个子矩阵,使得这 ...

  7. SPL基础接口

    Iterator 迭代器接口 SPL规定,所有实现了Iterator接口的class,都可以用在foreach Loop中.Iterator接口中包含5个必须实现的方法: interface Iter ...

  8. ubuntu18.04.4安装k8s

    k8s部署 1.集群所有主机关闭swap sudo swapoff -a sudo sed -i 's/.*swap.*/#&/' /etc/fstab 如果重启后swap还是自动挂载执行sy ...

  9. MAC 下SFT环境搭建及使用

    基本环境的搭建就不说了,网上一搜就是一堆 记录下正常的使用过程,主机-服务器是MAC机,从机-Windows机子 1.STF服务启动(挂后台的服务,启动后输入 exit退出进程即可) 后台启动DB:n ...

  10. Python面向对象的特征跟私有属性

     面向对象的三大特征 继成.封装.多态: 继承:一个类可以继承一个或多个类,被继承的类叫做父类,继承的类叫做子类 封装:将数据和方法放在了一个类中就构成了封装 多态:指的一类事物有多重形态,一个抽象类 ...