mysql用sql怎么用 mysql怎么使用数据库

MySQL SQL的基础应用SQL 基础应用及information_schema
1.SQL(结构化查询语句)介绍
SQL标准:SQL 92SQL99
5.7版本后启用SQL_Mode 严格模式
2.SQL作用
SQL 用来管理和操作MySQL内部的对象
SQL对象:
库:库名,库属性
表:表名 , 表属性,列名 , 记录,数据类型,列属性和约束
3.SQL语句的类型
DDL:数据定义语言data definition language
DCL:数据控制语言data control language
DML:数据操作语言data manipulation language
DQL:数据查询语言data query language
4.数据类型
4.1 作用:
控制数据的规范性,让数据有具体含义,在列上进行控制
4.2.种类
4.2.1 字符串
char(32)
定长长度为32的字符串 。存储数据时 , 一次性提供32字符长度的存储空间,存不满,用空格填充 。
varchar(32):
可变长度的字符串类型 。存数据时,首先进行字符串长度判断,按需分配存储空间
会单独占用一个字节来记录此次的字符长度
超过255之后,需要两个字节长度记录字符长度 。
面试题:
1. char 和varchar的区别?
(1) 25565535
(2) 定长(固定存储空间)变长(按需)
2. char和varchar 如何选择?
(1) char类型 , 固定长度的字符串列,比如手机号,身份证号,银行卡号,性别等
(2) varchar类型,不确定长度的字符串 , 可以使用 。
3. enum 枚举类型
enum('bj','sh','sz','cq','hb',......)
数据行较多时,会影响到索引的应用
注意:数字类禁止使用enum类型
4.2.2 数字
1. tinyint
2. int
4.2.3 时间
1. timestamp
2. datetime
4.2.4 二进制
5. 表属性
存储引擎 :engine =InnoDB
字符集:charset = utf8mb4
utf8中文三个字节长度
utf8mb4 中文四个字节长度才是真正的utf8
支持emoji字符
排序规则(校对规则) collation
针对英文字符串大小写问题
6. 列的属性和约束
6.1 主键: primary key (PK)
说明:
唯一
非空
数字列,整数列,无关列,自增的.
聚集索引列?
是一种约束 , 也是一种索引类型 , 在一张表中只能有一个主键 。
6.2 非空: Not NULL
说明:
我们建议 , 对于普通列来讲,尽量设置not null
默认值 default : 数字列的默认值使用0 ,字符串类型,设置为一个nil null
6.3 唯一:unique
不能重复
6.4 自增 auto_increment
针对数字列,自动生成顺序值
6.5 无符号 unsigned
针对数字列
6.6 注释 comment
7. SQL语句应用
7.1 DDL:数据定义语言
7.1.1 库
(1)建库
mysql create database oldguo charset utf8mb4;
mysql show databases;
mysql show create database oldguo;
(2)改库
mysql alter database oldguo1 charset utf8mb4;
(3)删库
mysql drop database oldguo1;
7.1.2 表
(0)建表建库规范:
1、库名和表名是小写字母
为啥?
开发和生产平台可能会出现问题 。
2、不能以数字开头
3、不支持-支持_
4、内部函数名不能使用
5、名字和业务功能有关(his,jf,yz,oss,erp,crm...)
(1)建表
create table oldguo (
ID int not null primary key AUTO_INCREMENT comment '学号',
name varchar(255) not null comment '姓名',
age tinyint unsigned not null default 0 comment '年龄',
gender enum('m','f','n') NOT null default 'n' comment '性别'

推荐阅读