首页 > 数据库 >MySQL语法

MySQL语法

时间:2023-01-05 01:44:43浏览次数:43  
标签:语法 studentNo studentResult result student MySQL where select

一、数据库引擎

#显示系统默认存储引擎
show variables like '%engine%';

二、数据库操作

#如果数据库存在先删除
drop database if exists myschool;
#创建数据库
create database myschool;
#查看数据库
show databases;
#使用数据库
use myschool;
#删除数据库
drop database myschool;
#刷新缓冲区,可以不用重启mysql服务
flush privileges;
#查看所有视图
select * from view/G;
#查看表
show tables;

三、表操作

#如果表存在先删除
drop table if exists `student`;
#创建表
create table `student`(`studentNo` int(4) primary key auto_increment comment '学号',`loginPwd` varchar(20) not null comment '密码',`studentName` varchar(50) not null comment '姓名',`sex` char(2) not null default '男' comment '性别',`gradeID` int(4) comment '年级编号',`phone` varchar(50) comment '电话',`address` varchar(255) default '地址不详' comment '地址',`bornDate` datetime comment '出生日期',`email` varchar(50) comment '电子邮箱',`identityCard` varchar(18) unique key comment '身份证号')comment '学生表';
#查看表
show table `student`;
#查看表定义
desc `student`;
#修改表名
alter table `demo01` rename `demo02`;
#添加字段
alter table `demo02` add `password` varchar(32) not null;
#为字段添加主键
alter table `demo02` add constraint 'pk_demo02_id' primary key `demo02`(`id`);
#为字段添加外键
alter table `demo02` add constraint `fk_demo02_id` foreign key`demo02`(`id`) references `demo01`(`id`);
#修改字段
alter table `demo02` change `name` `username` char(10) not null;
#删除字段
alter table `demo02` drop `password`;
1.删除
#删除数据
delete from `sutdent` where `studentNo`= ;
#删除表里的所有数据并重置自增id(重置索引)
truncate table `student`;
#删除表
drop table `student`;
2.插入
#插入数据
insert into `student` values();
#插入多条数据
insert into `student` values(),();
#指定字段添加
insert into `student`(`loginPwd`,`studentName`,`sex`) vlues() ;
#指定字段添加多条数据
insert into `student`(`loginPwd`,`studentName`,`sex`) vlues(),() ;
3.更新
#更新数据
update `student` set   where ; 
4.查询

完整语法([可选项])

SELECT < 字段名列表 > FROM < 表名或视图 > [WHERE < 查询条件 > ] [GROUP BY < 分组的字段名 > ] [HAVING < 筛选分组的条件 > [ 只能和 GROUP BY— 起用 ]] [ORDER BY < 排序的列名 > [ 默认ASC 或 DESC]] [ LIMIT [ 位置偏移量 ], [ 行数]]

#查询数据
select * from `student`;
#查询email为空
select studentName from student where email is null;
#查询email不为空
select studentName from student where email is not null;
#查询时插入列
select studentName,address,'昆明华信' as '学校名称' from student;
5.聚合函数

#平均分avg()
select avg(studentResult) as 'JavaBasic考试成绩平均分' from result where subjectNo = 1;
#总数量count()
select count(1) from student;
#最低分名min()
select min(studentResult) from result;
#最高分max()
select max(studentResult) from result;
#求和sum()
select sum(studentResult) from result;
6.时间日期函数

7.ORDER BY排序(ASC[默认升序],DESC[降序])

ORDER BY前不能加WHERE

#把成绩都降低 10 % 后加 5 分 , 再查询及格成绩 , 并按照成绩从高到低排序
select result.*,(studentResult*0.9+5) as 及格成绩 from result where (studentResult*0.9+5) >=60 order by 及格成绩 desc;
8.分页(LIMIT[开始数据行,分页数])
#查询所有年级编号为 1 的学员信息 , 按学号升序排序显示前 4 条记录
select * from student where gradeID = 1 order by studentNo limit 4;
#每页 4 条 ,显示第 2 页 ,即从第 5 条记录开始显示4 条数据
select * from student where gradeID = 1 order by studentNo limit 4,4;
9.子查询

子查询是一个嵌套在 SELECT 、 INSERT 、 UPDATE或 DELETE 语句或其他子查询中的查询(子查询 WHERE 语句中的一般用法)

#编写 SQL 语句 , 查看年龄比 “ 李斯文 ' 小的学生 , 要求显示这些学生的信息
select * from student where bornDate > (select bornDate from student where studentName = '李斯文');
#询参加最近一次Java Basic考试成绩的学生最高分和最低分
select max(studentResult),min(studentResult) FROM result where subjectNo = (select subjectNo from `subject` where subjectName = 'JavaBasic') and examDate = (select max(examDate) from result where subjectNo = (select subjectNo from `subject` where subjectName = 'JavaBasic'));
10.NOT IN/IN查询
#查询Java Basic课程成绩为 60 分的学生名单
select * from student where studentNo in (select studentNo from `result` where subjectNo = (select subjectNo from `subject` where subjectName = 'JavaBasic') and studentResult = 60);
#查询Java Basic课程成绩不为 60 分的学生名单
select * from student where studentNo not in (select studentNo from `result` where subjectNo = (select subjectNo from `subject` where subjectName = 'JavaBasic') and studentResult = 60);
11.NOT EXISTS/EXISTS子查询(相当于if)

SELECT · FROM 表名 WHERE EXISTS(子查询)

子查询有返回结果 :EXISTS 子查询结果为 TRUE 子查询无返回结果 :EXISTS 子查询结果为 FALSE, 外层查询不执行

#检查 "java Basic” 课程最近一次考试成绩如果有 10 分以上的成绩 , 显示分数排在前5名的学员学号和分数
select studentNo,studentResult from result where exists (select * from result where studentResult < 10 and examDate in (select max(examDate) from result where subjectNo in (select subjectNo from `subject` where subjectName = 'javaBasic'))) order by studentResult desc limit 5;
12.GROUP BY分组

SELECT 列表中只能包含:

GROUP BY前不能加WHERE

1.被分组的列 2.为每个分组返回一个值的表达式 , 如聚合函数

#统计每门课程平均分各是多少 ?
select subjectNo,avg(studentResult) from result group by subjectNo;
13.HAVING(与GROUP BY使用)分组筛选

image-20221207101947081

#如何获得课程平均分及格的课程编号 ?
select subjectNo,avg(studentResult) from result group by subjectNo having avg(studentResult) >= 60;
14.INNER JOIN · ON内连接
#查询学生表和成绩表,显示学生姓名 、 科目编号、考试成绩(双表连接)
select studentName,subjectNo,studentResult from student inner join result on student.studentNo = result.studentNo;
#三表联接查询显示学生姓名 、科目名称 、考试成绩
select studentName,subjectName,studentResult from student inner join `result` on student.studentNo = `result`.studentNo inner join `subject` on result.subjectNo = `subject`.subjectNo
15.外连接

image-20221207110850824

#LEFT JOIN · ON左外连接(主表 LEFT JION 从表 ON)
select * from student left join result on student.studentNo = result.studentNo;
#RIGHT JOIN · ON右外连接(从表 RIGHT JOIN 主表 ON)
select * from student right join result on student.studentNo = result.studentNo;
16.模糊查询LIKE
#查询学生表里性张的学生名单
select * from student where studentName like '张%';
17.区间BETWEEN · AND
#在查询成绩表里90-100分的学生学号
select studentNo from result where studentResult between 93 and 100;

四、事务处理

#什么是事务

image-20221207142614276

#事务的特性

操作原子、数据一致、事务隔离、数据持久

image-20221207142647230

#如何创建事务

image-20221207143115088

#语法
#开始
begin;
#事务
update bank set currentMoney = currentMoney -500 where customerName = '张三';
update bank set currentMoney = currentMoney +500 where customerName = '李四';
#提交
commit;
#回滚
rollback;
#结束
end;
#关闭事务(默认开启)

image-20221207144318171

五、视图(虚拟表)

image-20221207150422777

注意事项

image-20221207151832747

#创建视图,显示学生姓名 、科目名称 、考试成绩
create view view_student_result as (select studentName,subjectNo,studentResult from student inner join result on student.studentNo = result.studentNo);
select * from view_student_result;
#查看视图
select * from view_student_result;
#删除视图
drop view view_student_result;

六、索引

常见索引类型

image-20221207152347185

创建索引的原则

image-20221207153454844

注意事项

image-20221207153703094

#创建索引,给学生表里的学生姓名建一个普通索引
create index index_studentName on student(studentName);
#删除学生表里的index_studentName索引
drop index index_studentName on student;
#查看学生表里的索引
show index from student;
 

标签:语法,studentNo,studentResult,result,student,MySQL,where,select
From: https://www.cnblogs.com/ynxiyan/p/17026438.html

相关文章

  • Mysql的事务原理
    一、持久性依靠的是redolog,重做日志,记录的是事务提交时数据也的物理修改,是用来实现事务的持久性。该日志文件由两部分组成,重做日志缓冲,(redologbuffer)和重做日志......
  • MYSQL中MVCC是什么?
    基本概念MVCC:全称Multi-VersionConcurrencyControl,多版本并发控制。指维护一个数据的多个版本,使得读写操作没有冲突,快照读为MySQL实现MVCC提供了--个非阻塞读功......
  • MySQL中limit的用法
      mySql提供了limit ,主要用于提取前几条或者中间某几行数据。select*fromtablelimitm,n其中m是指记录开始的index,从0开始,表示第一条记录n是指从第m+1条开始,取n......
  • golang linux/windows下根据日期自动备份,恢复mysql数据表
    由于shell不熟,所以用golang进行自动化备份mysql备份某个数据库下指定日期的表。比如’tb_20221210'这样的表名1packagemain23import(4"fmt"5......
  • MySQL数据库更改密码
    当我们忘记本机MySQL登陆密码时1:首先打开MySQL的安装目录到bin(包含MySQL.exe和mysqld.exe的文件夹)   2:复制文件路径3:使用管理员打开cmd 4:输入mysqld--skip-......
  • mysql count(*) count(1)的区别
    COUNT(字段名)和COUNT(*)的查询结果有什么不同?COUNT(1)和COUNT(*)之间的效率哪个更高?你知道答案吗?很多人都认为COUNT(1)比COUNT(*)效率高,真的是这样吗?  1、认识COUN......
  • mysql 索引相关知识
    相信很多人对于MySQL的索引都不陌生,索引(Index)是帮助MySQL高效获取数据的数据结构。因为索引是MySQL中比较重点的知识,相信很多人都有一定的了解,尤其是在面试中出现的频率......
  • 5.JavaScript基础语法
    实验原理概念:JavaScript是世界上最流行的、轻量级的、脚本编程语言,可插入HTML页面,由浏览器执行。将这种脚本语言引入html,有三种方式:<script>与<script>标签,可被放置在HT......
  • 第2章:Java基本语法
    1、关键字和保留字关键字(keyword)的定义和特点:定义:被Java语言赋予了特殊含义,用做专门用途的字符串(或单词)。特点:关键字中所有字母都为小写字母。官方发布的所有关键字:......
  • ubuntu下安装mysql + qt编译mysql插件
    sudoapt-getinstallmysql-serverapt-getisntallmysql-clientsudoapt-getinstalllibmysqlclient-dev安装成功后可以看一下有没有进程在监听sudonetstat-tap......