欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MySQL增删改查的基本操作讲解

程序员文章站 2022-03-08 21:04:10
mysql:众多关系型中的一种 仓库 --数据库 箱子 --表 数据库: 进入mysql 命令行: mysql -uroot -p 查看所有数据库: show databases; 创建数据库: c...

mysql:众多关系型中的一种

仓库 --数据库

箱子 --表

数据库:

进入mysql 命令行: mysql -uroot -p

查看所有数据库: show databases;

创建数据库: create database niu charset utf8;

删除数据库: drop database niu;

选择数据库: use databases;

查看所有表: show tables;

查看创建数据库的语句:show create database databasename;

查看创建表的语句:show create table tablename;

查看表结构:desc tablenmae;

表:

约束

#自增长

auto_increment

#非空

not null

#默认值

default 'xx'

#唯一

unique

#指定字符集

charset

#主键

primary key

#外键

增加两个表之间的联系

增:

#学生表

create table students(

id int auto_increment primary key,

name varchar(10) not null,

sex varchar(3) default '女',

address varchar(50),

phone int not null unique,

age,

);

#成绩表

create table scores(

id int auto_increnent primary key,

s_id int not null,

grade float not null,

);

删:

drop table tablename;

truncate tablename;#快速删除表

改:

alter table oldtable rename newtable; #改表名

alter table tablename modify name varchar(20);#改表结构

alter table tablename change name newname varchar(20);#改表结构

alter (table tablename add age float

after name;#新增字段的位置

查:

show create table tablename ;#查看新建表语句

desc table;#查看表结构

show tables ;#查看所有表

数据:

insert into student (name,money,sex,phone) values ('hk',10000,'男',188);

insert into student values('','小明',100,'',120);

turncate tablename; #删除整表数据,自增长id从头再来,快速,从磁盘直接删除,不可恢复

delete from student;

#删除整个表的数据,自增长继续

update student set money=100;#不指定条件,修改所有

update student set money=110 where name='hk';#只改hk

自动提交

取消自动提交 ? set @@autocommitt=0;

? ? ? ? ? ? ? ? select @@autocommitt=0;

#自动提交取消后,当前会话显示已经成功执行,其实后台并没有执行

查:

select * from students limit 1,5; #从第几条开始,下面的x条,不包含开始的那一条

select * from students limit 5;查询5条

select id,stu_name,sex,money,phone from students;#指定查询的字段

select * from students;#查询所有的数据

select * from students where sex='男';#指定条件

select * from students where sex='男' and money>100; #多个条件,必须同时满足

select * from students where sex='男' or sex='未知' ; #多个条件,有一个满足即可

select * from students where sex !='男'; #<>也是不等于

select * from students where addr like '%东京%';#模糊匹配,%代表的是通配符,必须得用like

select * from students a where a.stu_name like '姚_';#_通配符表示任意一个单字符,姚字后面只能跟一个字

select a.stu_name '学生名称',a.phone '学生电话' from students as a where a.stu_name='姚远';#给表起别名,as可以省略

select * from students a where a.stu_name in ('牛牛','林倩','林远');# in

select * from students a where a.money between 1000 and 10000;#在什么什么之间的数据

select * from students order by money desc;

#order by xxx desc,根据哪个字段继续排序,默认是升序,

降序是desc,升序asc

select * from students a where a.addr = '' or a.addr is null; #查询字段为空的数据

select distinct a.money from students a ;#去重

select count(*) '学生人数' from students where sex='女'; #统计行数

select max(a.money) 钱最多 from students a; #最大值

select min(money) 钱最少 from students;#最小值

select avg(a.money) 平均多少钱 from students a; #平均数

select sum(a.money) 总共多少钱 from students a;#总和

select sex 性别,count(*) 人数 from students group by sex; #分组

select

sex 性别,

count(*) 人数,

a.stu_name 名字

from

students a??where?a.money > 300?group by?a.id?having?a.stu_name like '姚%';

#如果group by后面有条件的话,必须得用having子句,having子句里面用到的字段必须出现在select后面,如果group by和order by一起用的话,order by必须写在group by后面

select *,count(*) from students group by sex,class; #多个字段进行分组

select id,stu_name from students union select id,t_name from teacher;

#用来合并两条select语句的结果,两条select语句字段数量要一致,并且数据类型也要一致

union和union all的区别就是一个会去重一个不会

多表关联:

select?*?from?user a,?accounts b?where

a.id = b.user_id

and a.username = 'niuhy';

-- select * from students a ,scores b where a.id=b.s_id; -- 多表关联

-- 两个表里面都存在的数据查出来

select * from students a left join scores b on a.id=b.s_id;

-- left join会把左边表所有的数据都查出来,右边表有匹配的就查出来

select * from students a right join scores b on a.id=b.s_id;

-- right join会把右边表所有的数据都查出来,左边表有匹配的就查出来

select * from students a inner join scores b on a.id=b.s_id;

-- inner join两边表里都匹配的数据才查到

子查询:

把一条sql的结果,作为另一条sql的条件

select * from scores a where a.s_id = (select id from students where stu_name='牛牛');

把子查询当成一个表

select

a.grade 成绩,

b.stu_name 学生名称,

b.id 学号

from

scores a,

(?select?id,stu_name?from?students?where?stu_name = '牛牛') b

where

a.s_id = b.id;

数据库权限:

mysql数据的权限实质上都是在user表里控制的

1、grant

#所有的权限 所有数据库下面的所有表 用户 用户ip

grant all on *.* to 'andashu'@'localhost' identified by '123456' with grant option;

密码 #有执行grant语句的权限

grant all on *.* to 'andashu'@'%' identified by '123456' with grant option;

取消授权:

revoke select on *.* from dba@localhost;

revoke all on *.* from andashu@localhost;

2、修改user表的数据

对user表进行增加、修改和删除

flush privileges;#刷新权限

备份数据库:

mysqldump -uroot -p123456 db > db.sql

mysqldump -uroot -p123456 -a > all.sql

恢复数据:

mysql -uroot -p123456 db < db.sql

存储过程:

批量的造数据

delimiter $$; #为了改结束符

create procedure big_data1(num int)#代表要造多少条数据 100

begin

declare i int;

set i=0;

while i insert into students (stu_name,money) values (concat('小明',i),20000);

#concat的作用是连接不同类型的数据

#把字符串和数字拼接到一起

set i=i+1;

end while;

end

$$;

delimiter;

call big_data1(500); #调用