MySQL基础知识

MySQL基础知识

字段类型分类

char和varchar类型区别

char:底层会先留出所有空位

varchar:底层不会留空位,输入多少个字符就会计算多少个字符的空位

创建多种字段类型的表

create table husband
(
 id  int primary key auto_increment,
no char(12) unique,
  name char(20) ,
 age int
)ENGINE=InnoDB DEFAULT CHARSET=utf8;

create table wife
(
 id  int primary key auto_increment,
no char(12) unique,
  name char(20) ,
 age int,
`h_id` int,

FOREIGN KEY(`h_id`)  REFERENCES `husband` (`id`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
# FOREIGN KEY(`h_id`)创建wife表的外键值  REFERENCES `husband` (`id`)husband表的主键值
# drop table if exists `husband`  删除表格,如过有其他表格引用此表内容则无法删除

什么是主表,什么是从表

没有外键叫主表,有外键叫从表

增加:insert into 表(字段) values(值); 字符串和时间用引号引起来

insert into stu(id, name, sex, age) values (13,'小十三','男', 20);
insert into stu values (14,  '小十四',   '男',    20);
insert into stu(age)values (20);

删除:delete from 表 #where 后面加条件

delete from stu where id=1;

修改:update 表 set 属性1=值1,......,属性n=值n ,修改多个用逗号隔开 #where 后面加条件

update stu set sex='G' where sex='女';
update stu set sex='男' where id>5 and id<10;
update stu set name='小花',sex='G'  where sex='女';

查询

1.无序查找

2.有条件查找

* 多个条件是按照写的先后排序

select * from zystu order by sex , name;

order by 排序

desc:从大到小

asc: 从小到大(默认值)

select * from table ordery by字段 ---asc:默认升序 desc:降序

可以order by 字段1,字段2,......

select * from stu order by name desc, age desc

运算符 描述

= 等于

<> 不等于,该操作符可被写成 !=

> 大于

< 小于

>= 大于等于

in 多个可能值

not in 不个排除值

between...and... 数值型范围

is null 为空

is not null 不为空

and/&& 并且

or/|| 或

like 搜索某种模式

REGEXP 正则表达式

% 匹配0到多个字符

_ 匹配1个字符

select * from zystu where id=1 or id =2 ;
select * from zystu where id in(2,1,4) ; 
select * from zystu where name like '%王';

函数

标量函数:对表的计算

as:修改名字(起别名)

UCASE( )查出找后将字母改为大写

NGTH() - 返回某个文本字段的长度

ROUND() - 对某个数值字段进行指定小数位数的四舍五入

NOW() - 返回当前的系统日期和时间

FORMAT() - 格式化某个字段的显示方式         timestampdiff()-时间差

now() :

select now();

date_format(now);

select name ,sex, date_format(now(),'%Y') from zystu;
select name ,sex, date_format(now(),'%Y年 %m月%d日') from zystu;

# 结果 2020年 07月28日

格式

描述

%d

月的天,数值(00-31)

%Y

%H

小时 (00-23)

%h

小时 (01-12)

%i

分钟,数值(00-59)

%j

年的天 (001-366)

%M

月名

%m

月,数值(00-12)

%S

秒(00-59)

%u

周 (00-53) 星期一是一周的第一天

select * from stu where timestampdiff (year,brith,now())>20;
select * from stu order by rand();

#将顺序打乱--随机排序

分页查询:

limit a,b : 第一页a从索引0开始(每页首条索引),b每页显示的行数(此时一页两行)最多显示的行数

a=(页数-1)*b

select * from stu limit 0,2; 

聚合函数:对组的计算

分组查询:

having avg(age) >20;

avg() 聚合函数,统计平均值

where 前面必须是表,对符合条件的表进行筛选

having前面必须是组,对符合条件的组进行筛选

聚合函数:

AVG() - 返回平均值 

COUNT() - 返回行数

FIRST() - 返回第一个记录的值(mysql不支持)

LAST() - 返回最后一个记录的值(mysql不支持)

MAX() - 返回最大值

MIN() - 返回最小值

SUM() - 返回总和

分组查询步骤:

1.from

2.where

3.group

4.having

5.select

6.order by

7.limit