MySQL---通用语法及分类

目录

一、SQL通用语法 

二、 SQL分类

1.DDL

 1.1 DDL数据库操作

 1.2 DDL表操作---查询

 1.3 DDL表操作---创建​编辑

 1.4 DDL表操作---数据类型

 1.5 DDL表操作---修改

 1.6 DDL表操作---删除

 1.7 DDL总结

2. 图形化界面工具DataGrip

 2.1 创建

 2.2 使用

3. DML

 3.1 DML介绍 

 3.2 DML---添加数据 

 3.3 DML---修改数据

 3.4 DML---删除数据 

 3.5 DML总结

4. DQL 

4.1 DQL介绍

4.2 DQL语法

 4.2.1 基本查询

 4.2.2 条件查询 

 4.2.3 聚合函数

 4.2.4 分组查询

 4.2.5 排序查询

 4.2.6 分页查询 

4.3 DQL案例练习 

4.4 DQL---执行顺序  

4.5 DQL总结 

5. DCL 

 5.1 DCL介绍

 5.2 DCL---管理用户

 5.3 DCL---权限控制

 5.4  DCL总结

一、 SQL通用语法 

二、 SQL分类

1.DDL

1.1 DDL数据库操作

1.2 DDL表操作---查询

1.3 DDL表操作---创建

创建并查询如下所示: 

 

1.4 DDL表操作---数据类型

 char(50)-->性能好        用户名 username varchar(50)

varchar(50)-->性能较差        性别 gender char(1)

 

命令如下所示:  

create table emp (id int comment '编号',workno varchar(10) comment '工号',name varchar(10) comment '姓名',gender char(1) comment '性别',age tinyint unsigned comment '年龄',idcard char(18) comment '身份证号',entrydate date comment '入职时间'
)comment '员工表';

创建并查看输出如下: 

1.5 DDL表操作---修改

修改并查看如下所示: 

 

 

1.6 DDL表操作---删除

  

1.7 DDL总结

2. 图形化界面工具DataGrip

破解教程如下:

DataGrip 2024.1.2 最新激活码,破解版安装教程(亲测有效) - 犬小哈教程

2.1 创建

2.2 使用

3. DML

3.1 DML介绍 

3.2 DML---添加数据 

3.3 DML---修改数据

输出如下所示: 

3.4 DML---删除数据 

命令如下所示: 

 

3.5 DML总结

4. DQL 

4.1 DQL介绍

4.2 DQL语法

4.2.1 基本查询

创建表命令及输出如下所示:

--基本查询
--1.查询指定字段name,wonkno, age返回s
elect name, workno, age from emp;--2.查询所有字段返回
select id,workno,name,gender,age,idcard ,workaddress,entrydate from emp;
select * from emp;--3.查询所有员工的工作地址,起别名
slect workaddress as '工作地址' from emp;
select workaddress '工作地址' from emp;--4,查询公司员工的上班地址(不要重复)
select distinct workaddress '工作地址' from emp;
4.2.2 条件查询 

命令如下所示: 

--条件查询
-- 1,查询年龄等于88的员工
select * from emp where age = 88;--2.查询年龄小于20的员工信息
select * fron emp where age < 20;--3.查询年龄小于等于28的员工信息
select * from emp where age <= 20;--4,查询没有身份证号的员工信旦
select * from emp where idcard is null;-- 5.查询有身份证号的员工信息
select * from emp where idcard is not null;-- 6.查询年龄不等于88的员工信息
select * fron emp where age != 88;
select * from emp where age <> 88;--7,查询年龄在15岁(包含)到28岁(包含)之问的员工信息
select * from emp where age >= 15 && age <= 20;
select * from emp where age >= 15 and age <= 20;-- 8.查询性别为女且年龄小于25岁的员工信息
select * from emp where gender = ‘女’and age < 25;-- 9.查询年龄等于18或20或48的员工信息
select * from emp where age = 18 or age = 20 or age =40;
select * from emp where age in(18,28,40);-- 10.查询姓名为两个字的员工信息 _%
select * from emp where name like '__';-- 11.查询身份证号最后一位是X的员工信思
slect * from emp where idcard like '%X';
select * from emp where idcard like '_____________X';
4.2.3 聚合函数

命令如下所示:  

--聚合函数
--1.统计该企业员工数量
select count(*) from emp;
select count(idcard) from emp;-- 2.统计该企业员工的平均年龄
select avg(age) from emp;-- 3.统计该企业员工的最大年龄
select max(age) from emp;--4.统计该企业员工的最小年龄
select min(age) from emp;-- 5,统计西安地区员工的年龄之和
select sum(age) from emp where workaddress =‘西安";
4.2.4 分组查询

命令如下所示:  

--分组查询
--1.根据性别分组,统计男性员工和女性员工的数量
select gender,count(*) from emp group by gender ;--2.根据性别分组,统计男性员工和女性员工的平均年龄
select gender, avg(age) from emp group by gender ;--3.查询年龄小于45的员工,并根据工作地址分组,获取员工数量大于等于3的工作地址
select workaddress,count(x) address_count from emp where age < 45 group by wonkaddress having address_count >= 3;
4.2.5 排序查询

命令如下所示:  

--排序查询
-- 1.根据年龄对公司的员工进行升序排序
select * from emp order by age ase;
select * from emp order by age desc;
select * from emp order by age;-- 2.根据入职时问,对员工进行降序排序
select  from emp order by entrydate desc;--3,根据年龄对公司的员工进行升序排序,年龄相同,再按照入职时问进行降序排序
select * from emp order by ege ase , entrydate dese;
select * from emp order by age ase , entrydate asc;
4.2.6 分页查询 

命令如下所示:   

--分页查询
-- 1,查询第1负员工数据,每页展示10条记录
select * from emp linit 0,10;
select *fron emp linit 10;--2,查询第2页员工数据,每页展示10条记录-------->(页码-1)*页展示记录数
select * from emp limit 10,10;

4.3 DQL案例练习 

----------------- DQL语句练习---------- 
-- 1-查询年龄为20,21,22,23岁的女性员工信息
select  from emp where gender ='女' and age in(20,21,22,23);--2.查询性别为男,并且年龄在28-40岁(含)以内的姓名为三个字的员工
select * from emp where gender = '男' and age between 20 and 40 and name like '___';--3.统计员工表中,年龄小于60岁的,男性员工和女性员工的人数
select gender, count(*) from emp where age < 60 group by gender;--4.查询所有年龄小于等于35岁员工的姓名和年龄,并对查询结果按年龄升序排序,如果年龄相同按入职时间降序排序.
select name , age from emp where age <= 35 order by age asc , entrydate desc;--5.查询性别为男,且年龄在29-48岁(含)以内的前5个员工信恩,对查询的结果按年龄升序排序,年龄相同按入职时间升序排序。
select * from emp where gender = '男' and age between 20 and 40 order by age asc ,entrydate ase limit 5 ;

4.4 DQL---执行顺序  

 命令如下所示:   

--查询年龄大于15的员工的姓名、年龄,并根据年龄进行升序排序
select name,age from emp where age > 15 order by age ase;select name,age from emp e where e.age > 15 order by age ase;select e.name,e.age from emp e where e.age > 15 order by age ase;select e.name ename,e.age eage from emp e where eage > 15 order by age ase;#报错
select e.name ename,e.age eage from emp e where e.age > 15 order by age ase;select e.name ename,e.age eage from emp e where e.age > 15 order by eage ase;# from ...
# where ...
# select ...
# order by ...
# limit ...

4.5 DQL总结 

5. DCL 

5.1 DCL介绍

5.2 DCL---管理用户

 开发人员不必重点掌握,适合DBA(数据库管理员)

命令如下所示:    

--创建用户 itcast ,只能够在当前主机localhost访问,密码123456;
create user 'itcast'@'localhost" identified by "123456';--创建用户 heima ,可以在任意主机访问该数据库,密码123456 ;
create user "heima'@'%' identified by "123456";--修改用户heima的访问密码为1234;
alter user 'heima'@'%' identified with mysql_native_password by '1234";--修改用户heima的访问密码为1234;
drop user 'itcast'@'localhost";

5.3 DCL---权限控制

 命令如下所示:    

--查询权限
show grants for 'heima'@'%;
--授予权限
grant all on itcast.* to 'heina'@'%';
--撤销权限
revoke all on itcast.* from 'heima'@'%';

5.4  DCL总结

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/15592.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

521源码-免费源码下载-最新个人主页、个人引导页、网站导航页、引流页源码

这款源码采用HTML、CSS和JavaScript的组合&#xff0c;为您打造了一个既美观又实用的个人主页。通过简单的记事本工具打开源码文件&#xff0c;您可以轻松进行内容、文字以及样式上的修改&#xff0c;以满足您的个性化需求。 源码文件包含了完整的HTML结构、CSS样式表和JavaSc…

【深度学习实战—7】:基于Pytorch的多标签图像分类-Fashion-Product-Images

✨博客主页&#xff1a;王乐予&#x1f388; ✨年轻人要&#xff1a;Living for the moment&#xff08;活在当下&#xff09;&#xff01;&#x1f4aa; &#x1f3c6;推荐专栏&#xff1a;【图像处理】【千锤百炼Python】【深度学习】【排序算法】 目录 &#x1f63a;一、数据…

[Linux]Crond任务调度以及at任务调度

一.crond任务定时调度 crond是反复检测执行的&#xff0c;一个任务结束后&#xff0c;在所规定的时间之后会再次执行 crontab 指令可以给系统分配定时任务 crontab -e 进入编辑页面&#xff0c;设定任务 crontab -l 查看已有定时任务 crontab -r 删除所有任务 编辑时&#xff…

vue3全局封装table分页

1.封装element-plus table分页 <template><el-pagination:page-sizes"pageSizes"v-model:current-page"currentPage"v-model:page-size"pageSize":total"totals"size-change"handleSizeChange"current-change&quo…

MySQL - 信贷业务报表

表结构与字段解释 注册表 u_user id&#xff1a;自增主键&#xff0c;唯一标识用户。username&#xff1a;用户名。mobile&#xff1a;手机号。password&#xff1a;用户密码。nickname&#xff1a;用户昵称。role_type&#xff1a;角色类型&#xff08;-1&#xff1a;普通用…

FreeRTOS 源码概述

FreeRTOS 目录结构 使用 STM32CubeMX 创建的 FreeRTOS 工程中&#xff0c;FreeRTOS 相关的源码如下: 主要涉及2个目录&#xff1a; Core Inc 目录下的 FreeRTOSConfig.h 是配置文件 Src 目录下的 freertos.c 是 STM32CubeMX 创建的默认任务 Middlewares\Third_Party…

mac M3芯片 goland 2022.1 断点调试失败(frames are not available)问题,亲测有效

遇到如上问题&#xff0c;解法 步骤1&#xff1a;下载dlv文件 执行 go install github.com/go-delve/delve/cmd/dlvlatest 然后在 $GOPATH/bin里发现多了一个dlv文件 (找不到gopath? 执行 go env 可以看到) 步骤2&#xff1a;配置dlv 将这个dlv文件移到 /Applications/G…

go recover

recover 可以中止 panic 造成的程序崩溃。它是一个只能在 defer 中发挥作用的函数&#xff0c;在其他作用域中调用不会发挥作用。 // A _panic holds information about an active panic. // // A _panic value must only ever live on the stack. // // The argp and link fi…

【前端学习——react坑】useState使用

问题 使用useState 时&#xff0c;例如 const [selectedId, setSelectedId] useState([false,true,false]);这样直接利用&#xff0c;无法引发使用selectedId状态的组件的变化&#xff0c;但是selectedId是修改了的 let tempselectedId;temp[toggledId]selectedId[toggledId…

Cloudflare Worker 部署bingai

Cloudflare Worker 部署 1. 注册 Cloudflare 账号 2. 一键部署 登录账户后, 点击下面链接 https://deploy.workers.cloudflare.com/?urlhttps://github.com/Harry-zklcdc/go-proxy-bingai 点击「Authorize Workers」, 登录 Github 账号授权 Cloudflare 点击「I have a ac…

Flutter 中的 Tooltip 小部件:全面指南

Flutter 中的 Tooltip 小部件&#xff1a;全面指南 在用户界面设计中&#xff0c;提示信息是一种常见的交互元素&#xff0c;用于向用户提供额外的信息或对界面元素的说明。Flutter 的 Tooltip 小部件正是为此目的而设计&#xff0c;它在用户长按或悬停在某个元素上时显示一段…

React18+TypeScript搭建通用中后台项目实战03 自定义加载状态组件

拦截器 请求拦截器 修改 src/api/request.ts 核心代码&#xff1a; req.interceptors.request.use(// 拦截配置并更新配置config > {// 获取登录tokenconst token localStorage.getItem("token")// 使用 JWT Tokenif (token) {config.headers.Authorization …

kubernetes集群pod理论介绍

前言 在 Kubernetes 中&#xff0c;Pod 是最小的可部署单元&#xff0c;它是一个或多个容器的集合&#xff0c;这些容器共享网络和存储资源&#xff0c;并在同一主机上运行。在本文中&#xff0c;我们将进一步探讨 Kubernetes 集群中的 Pod&#xff0c;包括 Pod 的定义、调度管…

C++成员函数 - 析构函数

析构函数 析构函数 是特殊的成员函数&#xff0c;其 特征 如下&#xff1a; 1. 析构函数名是在类名前加上字符 ~ 。 2. 无参数无返回值类型。 3. 一个类只能有一个析构函数。若未显式定义&#xff0c;系统会自动生成默认的析构函数。注意&#xff1a;析构函数不能重 载 …

组成aim的方法数2(无限多张)

题目描述&#xff1a;arr是面值数组&#xff0c;其中的值都是正数且没有重复&#xff0c;再给定一个正数aim&#xff0c;每个值都认为是一种面值&#xff0c;且认为张数是无线的&#xff0c;返回组成aim的方法数。例如&#xff0c;arr[1,2]&#xff0c;aim4&#xff0c;方法有&…

Mysql基础(七)DQL之select 语句(二)

一 select 语句续 WHERE子句后面跟着的是一个或多个条件,用于指定需要检索的行COUNT(): 多少条数据 where 11 和 count(1) 与 count(*) count(1)、count(*)和count(指定字段)之间的区别 ① order by 排序 mysql 之数据排序扩展 1、使用 order by 语句来实现排序2、排序可…

洛谷P3574 [POI2014] FAR-FarmCraft(树形dp)

洛谷 P 3574 [ P O I 2014 ] F A R − F a r m C r a f t &#xff08;树形 d p &#xff09; \Huge{洛谷P3574 [POI2014] FAR-FarmCraft&#xff08;树形dp&#xff09;} 洛谷P3574[POI2014]FAR−FarmCraft&#xff08;树形dp&#xff09; 文章目录 题意题目说明 思路标程 题目…

nuxt: generate打包后访问资源404问题

现象 使用Nuxt.js开发的个人页面&#xff0c;部署到nginx服务器中&#xff0c;/_nuxt/*.js、/_nuxt/*.css等静态问题不能访问&#xff0c;提示404错误。 而我们的这些资源文件是存在的。 解决方法 加上此处代码进行上下文配置 baseURL: /nuxt/ 此时在nginx配置 /nuxt 代理 lo…

【Maven打包将resources/lib/下的jar也打包进jar包中】

Maven打包将resources/lib/下的jar也打包进jar包中 &#xff01;&#xff01;&#xff01;少走弯路 第一步 resources/lib/下引入jar ftp4j-1.7.2.jar替换为自己jar包的名称 <dependency><groupId>it.sauronsoftware.ftp4j</groupId><artifactId>ft…