MariaDB 数据类型
MariaDB数据类型可以分为数字,日期和时间以及字符串值。
使用数据类型的原则:够用就行, 尽量使用范围小的,而不用大的
- 常用的数据类型
- 整数:int, bit
- 小数:decimal #decimal(5,2)
- 字符串:varchar, char
- 日期时间:date, time, datetime
- 枚举类型(enum)
- 约束
- 主键primary key:物理上存储的顺序 #不能为空,不能重复,可连外键,支持索引,一般自增
- 非空not null:此字段不能为空
- 唯一unique:此字段不允许重复
- 默认default:当不填写此值时会使用默认值,如果填写则已填写为准
- 外键foreign key:对关系字段进行约束,当为关系字段填写值时,会到关联的表中查询此值是否存在,如果存在则填写成功,如果不存在则填写失败并抛出异常
引擎 InnoDB与MyISAM
InnoDB:支持事务,支持高并发,安全 #为MariaDB默认引擎
MyISAM:压缩数据,读取性好,速度快
对表命令
创建表
create table zzzz(
id int primary key not null auto_increment,
name varchar(),
age int
);
删除表
drop table name; #慎用
改表名
alter table name rename newname;
查表
--查看所有表
show tables; --查看表结构
desc 表名; --查看表创建
show create table 表名;
对字段命令
添加字段
alter table 表名 add 字段名 字段类型;
删除字段
alter table 表名 drop 字段名;
改字段
alter table 表名 modify 字段名 修改后的类型;
#只能改数据类型 alter table 表名 change 字段名 改后的字段名 改后的类型;
#字段名字与类型都可以改
对表中内容
插入信息
--全部插入
insert into 表名 values (字段 字符类型);
--部分插入
insert into 表名(字段1,字段2,...) values(字段 字符类型);
删除
#物理删除
delete from 表名 where 条件(id=); #逻辑删除(用一条字段来表示,这条信息是否还可用)
alter table 表名 add is_delete bit default ;
update 表名 set is delete= where (条件);
修改
update 表名 set 字段1=新值1,字段2=新值2,...where 条件;
查询
--查询基本使用(条件,排序,聚合函数,分组,分页) --创建学生表
create table students (
id int unsigned not null auto_increment primary key,
name varchar() default '',
age tinyint unsigned default ,
high decimal(,),
gender enum('男', '女', '中性', '保密') default '保密',
cls_id int unsigned default ,
is_delete bit default
); --创建班级表
create table classes(
id int unsigned auto_increment primary key not null,
name varchar() not null
); --往students表里插入数据
insert into students values
(,'小明',,180.00,,,),
(,'小月月',,180.00,,,),
(,'彭于晏',,185.00,,,),
(,'刘德华',,175.00,,,),
(,'黄蓉',,160.00,,,),
(,'凤姐',,150.00,,,),
(,'王祖贤',,170.00,,,),
(,'周杰伦儿',,null,,,),
(,'程坤',,181.00,,,),
(,'和珅',,166.00,,,),
(,'刘亦菲',,162.00,,,),
(,'金星',,180.00,,,),
(,'静香',,170.00,,,),
(,'郭靖',,167.00,,,),
(,'周杰',,178.00,,,),
(,'钱小豪',,178.00,,,),
(,'谢霆锋',,175.00,,,),
(,'陈冠希',,175.00,,,); --查询
-- 查询所有列
--select * from 表名
select * from students; --一定条件查询(where)
select * from where id=; -- 查询指定列
select id,name from students; -- 使用as给字段起别名
select id,name as '姓名', age, high, gender from students; -- 通过表名字段查询
select students.name from students; -- 给表起别名查询
select s.id,s.name,s.age from students as s; --消除重复行
-- distinct
select distinct age from students; --条件查询
--比较运算符
-- 查询年纪大于18岁的信息
select * from students where age > ; --18岁到28岁之间(and)
select * from students where age >= and age =< ;
select * from students where age between and
--在18岁以上或者身高180以上的人(or)
select * from students where age > or high > ; -- 模糊查询
-- like
-- % 替代1个或者多个甚至是没有
-- 查询姓名中有‘小’的所有名字
select * from students where name like '%小%'; -- 查询两个字人的名字
select * from students where name like '__'; -- 查询至少有2个字的名字
select * from students where name like '%__%'; --范围查询
-- in (,,)表示在一个非连续的范围内
-- 查询 年纪为18和34的人
select * from students where age in (, ); --查询 年龄在17岁到34岁之间的信息
select * from students where age between and ; --查询 年纪不在18到34岁的信息
select * from students where age not between and ; -- 空判断
-- 判断is null
-- 查询身高为空的信息
select * from students where high is null; -- 判断非空is not null
select * from students where high is not null; -- 排序
-- order by 字段
-- asc从小到大排列,即升序 默认即asc
-- desc从大到小排序,即降序 -- 查询年纪在18到34岁之间的男性,按照年纪从小到大
select * from students where gender= and age between and order by age; -- 查询年纪在18到34岁之间的女性,身高从高到矮
select * from students where gender= and age between and order by high desc; -- order by 多字段
-- 查询年纪在18到34岁的女性,身高从高到矮排序,如果身高相同的情况下按照年纪从小到大排序
select * from students where age between and and gender= order by high desc; -- 查询年纪在18到34岁的男性,身高从高到矮排序,如果身高相同的情况下按照年纪从小到大排序,如果年龄也相等那么按照id从小到大排序;
select * from students where age between and and gender= order by high desc, age, id desc; --聚合函数
-- 总数
-- count
-- 查询男性有多少人
select count(*) from students where gender=; -- 最大值
-- max
-- 查询最大的年纪
select max(age) from students; -- 查询女性的最高 身高
select max(high) from students where gender=; -- 最小值
-- min
select min(high) from students; -- 求和
-- sum
-- 计算所有人的年龄总和
select sum(age) from students; -- 平均值
-- avg
-- 计算平均年纪
-- 计算平均年纪 sum(age)/count(*)
select sum(age)/count(*) from students;
select avg(age), from students;
-- 保留2位小数
select round(avg(age),) from students; -- 分组
-- group by
-- 按照性别分组,查询所有的性别
select gender from students group by gender; -- 计算每组性别的人数
select gender, count(*) from students group by gender; -- 查询男性组中的姓名 group_concat
select gender,group_concat(name) from students where gender= group by gender; -- having
-- 查询每个性别平均年纪超过30岁的性别,以及姓名 having avg(age) >
select gender, group_concat(name) from students group by gender having avg(age) > ; -- 查询每种性别中的人数多于4个的组的信息
select gender,group_concat(name) from students group by gender having count(*)>;
-- 分页
-- 显示5页
select * from students limit ; -- 分页显示,每页显示2条数据
select * from students limit , ; -- 按照身高从高到矮排序,查找出所有女性,并且分页显示,每页显示2条数据
select * from students where gender= order by high desc limit ,;
关联查询
g--创建学生表
create table students (
id int unsigned not null auto_increment primary key,
name varchar() default '',
age tinyint unsigned default ,
high decimal(,),
gender enum('男', '女', '中性', '保密') default '保密',
cls_id int unsigned default ,
is_delete bit default
); --创建班级表
create table classes(
id int unsigned auto_increment primary key not null,
name varchar() not null
); --往students表里插入数据
insert into students values
(,'小明',,180.00,,,),
(,'小月月',,180.00,,,),
(,'彭于晏',,185.00,,,),
(,'刘德华',,175.00,,,),
(,'黄蓉',,160.00,,,),
(,'凤姐',,150.00,,,),
(,'王祖贤',,170.00,,,),
(,'周杰伦儿',,null,,,),
(,'程坤',,181.00,,,),
(,'和珅',,166.00,,,),
(,'刘亦菲',,162.00,,,),
(,'金星',,180.00,,,),
(,'静香',,170.00,,,),
(,'郭静',,167.00,,,),
(,'周杰',,178.00,,,),
(,'钱小豪',,178.00,,,),
(,'谢霆锋',,175.00,,,); --向classes表里插入数据
insert into classes values (, '云唯_01期'),(, '云唯_02期'); -- 连接查询(内关联)
-- inner join ... on
-- 两个表连接查询
select * from students inner join classes
-- 查询能够对应班级的学生以及班级信息
select * from students inner join classes on students.cls_id=classes.id;
-- 按照要求显示姓名,班级
select students.*, classes.name from students inner join classes on students.cls_id=classes.id; -- 给数据表起名字
select s.name, c.name from students as s inner join classes as c on s.cls_id=c.id; -- 查询 有能够对应班级的学生以及班级信息,显示学生的所有信息,只显示班级名称
select students.*, classes.name from students inner join classes on students.cls_id=classes.id; -- 在以上查询中将班级姓名显示在第一列
select classes.name,students.* from students inner join classes on students.cls_id=classes.id; -- 查询有能够对应班级的学生以及班级信息,按照班级进行排序
select classes.id, students.* from students inner join classes on students.cls_id=classes.id order by classes.id; -- 当是同一个班级的时候,按照学生的id从小到大
select classes.id, students.* from students inner join classes on students.cls_id=classes.id order by classes.id, students.id; --连接查询(左关联,右关联)
--左关联,以左边表为基准,条件对应不上的显示null
select * from students left join classes on students.cls_id=classes.id; --右关联,以后边为基准,条件对应不上的显示null
select * from classes left join students on students.cls_id=classes.id; -- 自关联 #只有当表结构相同时,才可以使用自关联
create table areas(
aid int primary key auto_increment,
name varchar(),
pid int
);
-- 查询出河北省所有市
select * from areas as province inner join areas as city on province.aid=city.pid having name='河北省'; select province.name,city.name from areas as province inner join areas as city on province.aid=city.pid having province.name='河北省'; -- 子查询
-- 标量子查询
-- 查询出北京市所有区的信息
select * from areas where pid=(select aid from areas where name='北京市'); select * from areas where pid in (select aid from areas where name='北京市');