MySql的简单使用,所有的代码基于MAC

时间:2022-02-03 03:11:04

基础

安装mysql

brew install mysql

 查看mysql安装路径

ps -ef|grep mysql

 查看mysql的配置文件

mysql --verbose --help | grep my.cnf

 启动

mysql.server start

 登录mysql,可以在my.cnf的配置文件中加入skip-grant-table

mysql -u root -p 

 当前时间

select now();

 显示版本

select version();

 查询数据库

show databases;

 创建数据库

create database test_db;
create database test_db charset=utf8;//设置数据库的编码格式
create database test_db character set utf8;

 显示创建的语句

show create database test_db;

 删除数据库

drop database test_db;

切换数据库

use test_db;

当前选择的数据库

select database();

查看当前数据库的表

show tables;

创建一个数据表 primary key主键 not null不能为空 auto_increment自动增长

Create table students(id int unsigned not null auto_increment primary key,name varchar(20),age tinyint unsigned,hight decimal(5,2),gender enum(‘男‘,‘女‘,‘未知‘) default ‘未知‘);

删除表

drop table test;

给表添加字段

alter table students add birthday datetime;

修改表的字段类型

alter table students modify birthday date;

修改表的字段名字和类型

alter table students change birthday birth date default "1990-01-01";

删除一个字段

alter table students drop birth;

查看数据表结构

desc students;

插入数据

insert into students values (0,‘刘‘,18,1.72,‘男‘);
insert into students values (0,‘刘‘,18,1.72,‘男‘),(0,‘刘‘,18,1.72,‘男‘);
insert into students (name,hight) values ("测试",1.77);
insert into students (name,hight) values ("测试",1.77),("测试",1.77);

查询数据

select * from students;
select name,age from students;
select name as 姓名,age as 年龄 from students;
select s.name,s.age from students as s;

 修改数据

update students set age = 30,name = "老王" where id = 1;
update students set hight = hight  1 where id = 30;

 

删除数据

delete from students where id = 6

 

进阶
查询去重

select distinct gender from students;

 where使用

select * from students where gender <> "男";
select * from students where id > 3;
select * from students where id = 3;
select * from students where age>18 and age<40;
select * from students where age>30 or age < 20;
select * from students where not (age > 30);
select * from students where (not age > 30) and name="刘";
select * from students where name like "测%";//查询以测开头的
select * from students where name like "__";//查询名字有两个字符的
select * from students where name rlike "^测.*";//正则
select * from students where age in (30,18);//年龄30,或者18的
select * from students where age not in (30,18);//
select * from students where age between 18 and 30;//年龄18<=age<=30
select * from students where age not between 18 and 30;//年龄18<=age<=30
select * from students where age is NULL;
select * from students where age is not NULL;

 排序

select * from students order by age;
select * from students where age is not NULL order by age;//asc 升序
select * from students where age is not NULL order by age desc;//降序

分组、统计

select count(*) from students where age = 18;//统计18岁的人数
select count(*) as 18岁人数 from students where age = 18
select max(age) from students ;//最大年龄
select min(age) from students ;//最小年龄
select sum(age) from students;//所有年龄总和
select avg(age) from students;//平均年龄
select sum(age)/count(*) from students;//平均年龄
select round( sum(age)/count(*),2) from students;//2代表保留两位小数
select gender from students group by gender;//分组
select gender, count(*) from students group by gender;//分组统计
select gender,group_concat(name) from students group by gender;//根据性别统计姓名
select gender,group_concat(name,age) from students where gender="女";
select gender,group_concat(name,"_",age) from students where gender="女";
select gender,group_concat(name) from students group by gender having count(*)>3;//分组的数大于3条记录
select gender,group_concat(name) from students group by gender having avg(age)>20;//分组的平均年龄大于20

分页

select * from students limit 2;//限制查询出来的个数,最多两条
select * from students limit 0,5;//从数据里面第0条开始查5条
select * from students limit 5,5;//从第五条开始查5条
select * from students limit 5,5;//从第五条开始查5条
select name from students where gender="未知" limit 2;

 

联合查询

if not exists的使用

 

Create table cls(id int unsigned not null auto_increment primary key,name varchar(20));
alter table students add cls_id int default 0;
Create table if not exists  cls(id int unsigned not null auto_increment primary key,name varchar(20));

 

 

内连接,取交集

select * from students inner join cls ;//结果是count(students)*count(cls)
select * from students inner join cls on  students.cls_id = cls.id;//查出学生所在的班级对应的班级
select students.id,students.name,cls.name from students inner join cls on  students.cls_id = cls.id;//显示指定的列
select s.*,c.name from students as s inner join cls as c on  s.cls_id = c.id;//显示学生所有字段,给表设置别名
select s.*,c.name from students as s inner join cls as c on  s.cls_id = c.id order by c.name,s.id;//排序
select * from students as s left join cls as c on s.cls_id = c.id ;//用students为基础,查cls,等价下面
select * from cls as c right join students as s on s.cls_id = c.id ;
select * from students as s left join cls as c on s.cls_id = c.id having c.name is null;//查询没有班级的学生
select * from students as s left join cls as c on s.cls_id = c.id where c.name is null;//这个不建议
select s.id,s.name,c.name from students as s,cls as c where s.cls_id = c.id;//不建议

自关联,需要的数据

 create table areas(aid int primary key,atitle varchar(20),pid int);

 

source aaa.sql;//如果aaa.sql是一个sql文件,可以使用这个,前提是ls必须路径里面必须有aaa.sql

 

Select areas.atitle from areas inner join areas as city on city.pid = areas.aid having areas.atitle="北京市区";

 子查询

select * from students where hight = (select max(hight) from students where gender=‘男‘);//查询最高的男生信息
select * from students inner join (select max(hight) as hight from students group by cls_id) as stu on students.hight = stu.hight;//查询每个班最高的学生信息
select * from (select cls_id,  max(hight) as hight from students group by cls_id) as stu left join students as s on stu.cls_id = s.cls_id and stu.hight = s.hight;//同上
select * from students inner join (select max(hight) as hight from students group by cls_id) as stu on students.hight = stu.hight having students.gender="女";//查询每个班最高的女学生信息
select * from students left join (select max(hight) as hight from students group by cls_id) as stu on students.hight = stu.hight having students.gender="女";//同上

 

//视图,主要是为了方便查询

select s.id,s.name,s.age,s.hight,s.gender,c.name from students as s inner join cls as c on  s.cls_id = c.id;

 删除

drop view students_cls_view;

事务:

start transaction;//或者begin
update students set name="好人3" where id = 28;
commit;//提交 rollback;//可以回滚

 

索引

set profiling=1;//开启时间运行监测
select * from students;
show profiles;//查看查询的时间
set profiling=1;
create index id_index on students(id);//如果是字符串,需要把id改成name(10)  删除 drop index  id_index
show profiles;