sql 百分号_SQL思维导图和代码分享

本人SQL新手,五一期间自学了《SQL必知必会》一书,在此简要分享学习心得,若有差错,请各位大佬们多多指教呀!

本人的SQL学习计划是先根据《SQL必知必会》一书入门,了解SQL的整体框架,语法等,在闲暇时间刷题巩固。

首先奉上本人整理的SQL涉及的功能及语法的思维导图,思维导图中整理了各个SQL功能以及实现功能的代码和函数等,还在不断完善更新中~(本人新手,可能有部分功能理解有误,请大家不吝赐教,(●'◡'●))

另外,本着学以致用的心态,本人在SQL学习过程中,坚持码代码实现相关功能,文末也将奉上本人编写的SQL代码以及相关功能说明~(工具是SQLyog,思路依据的是《SQL必知必会》一书),老规矩,同学们觉得有问题或有优化空间的话,请多多留言指教哇!

2d17e8030b978d2f7bda804756a2c64e.png

=======================================================================

/* 检索固定位置和固定行数

SELECT *

FROM employees;

Select distinct employee_id

from employees;

select employee_id

from employees

limit 4,4

order by employee_id; */

/* 多列排序 第一个排序列的值不唯一,需要多列区分

select employee_id, first_name, last_name

from employees

order by first_name,last_name;

*/

/* 升序排序和降序排序

select first_name, last_name, salary

from employees

order by salary desc;

*/

/* 找到工资3000的员工;where 过滤指定的是行。

select first_name,last_name,salary

from employees

where salary >= 3000;

*/

/* 不匹配查询--字符串要用单引号引用

select

first_name,last_name,salary

from

employees

where job_id = 'AD_VP' ;

*/

/* 范围查询

select first_name,last_name,salary

from employees

where salary between 3000 and 5000

order by salary desc;

*/

/* 查询空值

select first_name,last_name,email

from employees

where email is null;

*/

/*逻辑操作符*/

/* AND 操作符

select first_name,last_name,salary,job_id

from employees

where job_id = 'IT_PROG' and salary >5000

order by salary;

*/

/* OR 操作符

select salary,first_name,last_name,job_id

from employees

where job_id ='IT_PROG'

or salary >=10000

order by salary;

*/

/* 求值顺序--AND的优先级更高,会优先和其它语句组合,类似数学运算的乘除;

OR类似加减,

可用圆括号(优先级更高)强制改变运算顺序

select job_id, first_name,last_name,salary

from employees

where (job_id = 'IT_PROG'

or job_id = 'AD_VP')

and salary > 6000;

*/

/* IN 的用法————类似“集合”概念;完成类似 ”OR“语句的操作,学会使用“IN”替代“OR”

select first_name,last_name,salary,job_id

from employees

where job_id in ('AD_VP','IT_PROG')

order by salary;

*/

/*

select first_name,last_name,salary,job_id

from employees

where not job_id in ('AD_VP','IT_PROG')

and salary > 10000

order by salary;

*/

/* 通配符% 匹配多个字符 搜百分号放字符前面表示以百分号后的字符结尾的量,放字符后面表示搜索以字符开头的量

select *

from jobs

where job_title like '%manager%'

order by min_salary;

*/

/*通配符 下划线 一个下划线只匹配单个字符而不是多个字符

select *

from jobs

where job_title like '__________ Manager';

*/

/*组合使用

select *

from employees

where first_name NOT like 'N%'

or first_name Not like 'L%'

order by salary desc;

*/

/* 使用concat拼接两列,并指定别名

select concat(first_name,'(',last_name,')')

from employees

as name

order by salary;

*/

/* 返回当前日期

select now()

*/

/* 文本处理,改变字符串首字母大小写

select first_name,lower(first_name)as first_name_locase

from employees

order by first_name_locase;

*/

/*搜索发音相同的字符

select first_name

from employees

where soundex(first_name)=soundex('vali');

*/

/* 提取时间 年

select first_name,last_name,salary

from employees

where year(hiredate)=2004

order by salary;

/* 提取时间 月

select first_name,last_name,salary

from employees

where month(hiredate)=3

order by salary;

*/

/* 提取时间 日

select first_name,last_name,salary

from employees

where day(hiredate)=3

order by salary;

*/

/* 求平均值,列名不是字符串

select avg(salary)

as avg_salary

from employees;

*/

/* 计数函数的使用,是否将NULL计算在内

select count(*)

from employees;

select count(manager_id)

from employees;

*/

/*最大值 最小值函数使用

select max(first_name)

from employees;

select min(first_name)

from employees;

*/

/*分组数据,Group by和Having*/

/* group by 使用

select job_id,count(*)as num_job

from employees

group by job_id

*/

/* having函数使用,对“列”过滤,再排序

select job_id,count(*)as num_job

from employees

group by job_id

having num_job>=10

order by num_job;

*/

/* 子查询

select first_name,last_name,salary

from employees

where department_id in (select department_id

from departments

where location_id = 1700);

*/

/*作为计算字段使用子查询

select department_name,

manager_id,

(select count(*)

from employees

where employees.department_id=departments.department_id) as depar

from departments

order by manager_id;

*/

/* 内联结 选定的列位于不同的表,如何选取?如何使用表名的缩写-表别名?

select d.`department_name`,e.first_name,e.last_name

from `departments` as d,employees as e

where d.`department_id` = e.`department_id`;

*/

/* 自联结 同一张表中寻找拥有同种属性的对象--问题:相同列会出现多次,下面代码结果同一个对象重复出现

select e1.`employee_id`,e1.first_name,e1.last_name,e1.department_id

from employees as e1,employees as e2

where e1.`department_id`=e2.`department_id`

and e2.`department_id`=100;

*/

/*自然联结--避免自联结结果项重复出现,重点在于采用另一张明确的表来联结

select e.`department_id`,e.`first_name`,e.`last_name`,e.`salary`

from employees as e,departments as d

where e.`department_id`=d.`department_id`

and d.`department_id`=100;

*/

/* 外联结-关键:可以显示没有关联行的行;注意:left outer join指出语句左边表(默认按左边表排序),right outer join指出语句右边表(默认按右边表排序)

select e.`employee_id`,e.`first_name`,e.`last_name`,d.`department_name`,e.`department_id`

from employees as e left outer join departments as d

on e.`department_id`=d.`department_id`;

*/

/*使用带聚集函数的联结。

select d.`department_name`,e.`employee_id`,

count(e.`department_id`) as num_emp

from employees as e inner join departments as d

on e.`department_id`=d.`department_id`

group by e.department_id;

*/

/* 组合查询,多个查询条件,类似OR的功能,在面对多个表调用时,采用这个语句,结构会清晰一些。

select e.`employee_id`,e.`first_name`,e.`last_name`,e.`email`,e.`department_id`

from employees as e

where e.`department_id` in (100,110,120)

union

select e.`employee_id`,e.`first_name`,e.`last_name`,e.`email`,e.`department_id`

from employees as e

where e.`first_name`='Steven'

order by e.`department_id`;

*/

/* 用OR语句替代上述组合查询语句,实现相同功能

select e.`employee_id`,e.`first_name`,e.`last_name`,e.`email`,e.`department_id`

from employees as e

where e.`department_id` in (100,110,120)

or e.`first_name`='Steven'

order by e.`department_id`;

*/

/* 插入

insert into employeess(*)

values(01,

'Lynn',

'Zheng',

'lingling66zh',

'1888',

'AD_VP',

17000,

null,

null,

100,

2020-08-25);

*/

/*插入检索的数据

insert into employees(*)

select(*)

from another_tbl;

select *

into custcopy

from customer

*/

/*更新数据

update employees

set employee_id =250

where employee_id =1;

*/

/*删除数据-注意:这里删除的是整行,部分删除要使用update

delete from employees

where employee_id = 250;

*/

/*创建表,必须给出三个项: 列名,数据类型,是否允许值为null;如何给定默认值

create table test.product250

(prod_id char(10) not null,

department_id int(4) default 1,

prod_name char(254) default 1);

*/

/*更改设定表,添加用add,删除用drop column 列名

alter table test.`product250`

add prod_price int(10) default 1;

*/

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

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

相关文章

java获取字符串第一位_Java程序员经典面试题集大全 (十一)

>>> 学习交流群 < < <111. Java中byte表示的数值范围是什么&#xff1f;答&#xff1a;范围是-128至127112.如何将日期类型格式化为&#xff1a;2013-02-18 10:53:10&#xff1f;public class TestDateFormat2 {public static void main(String[] args) thro…

django开源电子文档管理系统_Python实操技术分享:Django文件管理系统,Apple的学习思路...

一、客户端产品要求有一个更新状态按钮&#xff0c;点击更新数据后会弹出结果页面作用是检查本次读取的文档信息与数据库中文档数据的区别。同时对数据库进行对应的新增和删除操作。然后把最终的数据库信息按行显示出来&#xff0c;包括4列内容文件名&#xff0c;文件路径&…

python打包出现乱码_python解压zip包中文乱码解决方法

乱码得原因&#xff1a; 由于ZipFile模块导出遇到中文解码不对&#xff0c;windows上会出现&#xff0c;linux是否会出现不知道没测试过。 解决方式&#xff1a; 1. 搞个文件名引射表(不太方便&#xff0c;少量文件夹套用时候还可以) 2. 修改源码解码格式(不太方便&#xff0c;…

redis重启命令_请收下这份redis持久化详解

前言Redis支持RDB和AOF两种持久化机制&#xff0c; 持久化功能有效地避免因进程退出造成的数据丢失问题&#xff0c; 当下次重启时利用之前持久化的文件即可实现数据恢复。RDB介绍按指定时间间隔把数据生成快照保存到硬盘的过程,触发RDB持久化过程分为手动触发和自动触发。自动…

python 苹果id申请_如何申请百度机器翻译API的ID和Key,为Python调用做准备

1.打开以下页面&#xff1a; http://api.fanyi.baidu.com/api/trans/product/index 2. 在网页找到“立即使用”并点击&#xff0c;之后&#xff0c;如果要求你登录百度&#xff0c;那就用你已有的百度账号登录&#xff0c;如果没有百度账号&#xff0c;请先申请一个百度账号&am…

去掉窗口_Flink 基础——窗口(Window)理论篇

窗口是什么要知道 Flink 面对的是无限的数据流&#xff0c;而批处理只是流处理的一个特例&#xff0c;然而我们的计算只能基于一个有限的集合&#xff0c;这个时候窗口正好定义了这其中的概念。因此可以说了解窗口机制是学习 Flink 的基础也是关键。总结来说&#xff0c;窗口将…

开题报告方案论证_观点讨论研究方案、立项申报书、开题报告的联系和区别

点击蓝字获取更多精彩信息观点讨论┃研究方案、立项申报书、开题报告的联系和区别第一部分 开题报告与立项申报书的区别开题报告与立项申报书看似类似(一级目录大致相同)&#xff0c;但相比之下&#xff0c;重点和详略有明显变化&#xff0c;主要有以下实际区别&#xff1a;1…

resnet50能用cpu跑吗_2020年12月1日更新。性价比最高入门游戏CPU--intel 10100F装机配置推荐。...

牙膏厂终于发布了入门级性价比最高的十代CPU&#xff0c;inte i3 10100F。10100F采用LGA1200芯片接口,四核八线程,主频3.6GHz&#xff0c;睿频可以到4.3Ghz。TDP功耗65w&#xff0c;支持双通道DDR4 2666内存。可以搭配H410或B460主板。首发价格为699元&#xff0c;性价比非常的…

匹配正则_程序员入门基础:python正则表达式贪婪匹配和非贪婪匹配

此文为python正则表达式的高阶入门&#xff0c;正则基础入门请参考程序员入门基础&#xff1a;python的正则表达式。一、贪婪匹配和非贪婪匹配举例说明概念&#xff1a;print(非贪婪匹配,re.search(el?, hello world,re.I))print(贪婪匹配,re.search(el, hello world,re.I))贪…

python数据结构与算法分析_数据结构和算法分析

问题引出假设有一道题目&#xff1a;有一组N个数而要确定其中第k个最大者&#xff0c;我们称之为选择问题&#xff0c;那么这个程序如何编写&#xff1f;最直观地&#xff0c;至少有两种思路&#xff1a;1、将N个数读入一个数组中&#xff0c;再通过某种简单的算法&#xff0c;…

单片机与树莓派蓝牙连接_用树莓派玩转蓝牙

作者&#xff1a;Vamei 出处&#xff1a;http://www.cnblogs.com/vamei 严禁转载。蓝牙是一个使用广泛的无线通信协议&#xff0c;这两年又随着物联网概念进一步推广。我将介绍蓝牙协议&#xff0c;特别是低功耗蓝牙&#xff0c;并用树莓派来实践。树莓派3中内置了蓝牙模块。树…

禁止更改计算机名_计算机改名、加域脚本集合

windows计算机改名、改密码、设置ip、加域脚本集合今天和大家分享一下&#xff0c;如何将前面的改名加域整合在一起&#xff0c;根据选择执行对应的命令。新建txt文档&#xff0c;输入一下代码&#xff0c;另存为“自动加域脚本.bat”。echo offcolor 1Fmode con cols100 lines…

加载文件流_jvm类加载的过程

一个类从加载到虚拟机到使用结束从虚拟机卸载包括了加载、验证、准备、解析、初始化、使用、卸载&#xff0c;即为一个类的生命周期下面来看一下类加载的过程&#xff0c;即加载、验证、准备、解析、初始化5个阶段都做了什么事&#xff1a;阶段1&#xff1a;加载加载阶段虚拟机…

php 消息队列_消息队列篇——windows本地搭建RabbitMQ Server

前言&#xff1a;最近的PHP项目中有使用AMQP&#xff0c;解耦一些业务性的功能模块。因为工作使用的是线上Linux搭建&#xff0c;为了方便测试所以我决定本地搭建一个MQ服务。RabbitMQ简介&#xff1a;MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法。…

小程序底部弹窗css_微信小程序之animation底部弹窗动画(两种方法)

简单分享一下常用的底部弹窗层或下拉框弹出层(代码需要修改)的内容弹窗的动画效果&#xff0c;这里分享的是点击按钮后底部弹窗的动画效果。第一种方式是动态设置显示区域的高度&#xff0c;第二种方法是动态设置显示区域的移动的位置(使用到 transform:translateY )&#xff1…

js cookie 存储checkbox_浏览器数据存储方式总结,网友:“精辟”!

今天主要来讲下前端的数据存储&#xff0c;说起数据存储&#xff0c;大家肯定第一时间想起cookie&#xff0c;localstorage&#xff0c;sessionstorage&#xff0c;而其实还有userData和IndexedDB这两种数据存储&#xff0c;接下来将对它们进行一个比较详细的总结一、为什么要进…

mysql获取一个表的数据作为值插入_请问如何在mysql中得到一个即将插入数据表中的那条数据的id值(id自增长)?...

我们在写数据库程序的时候,经常会需要获取某个表中的最大序号数,一般情况下获取刚插入的数据的id&#xff0c;使用select max(id) from table 是可以的。但在多线程情况下&#xff0c;就不行了。下面介绍三种方法(1) getGeneratedKeys()方法:程序片断:Connection conn ;Serial…

navigator工具_Javascript常用工具类

就算现今是以框架为主流的前端&#xff0c;依然离不开JS&#xff0c;因为他是框架底层的一部分。我先上传代码截图(截图显示会更好看点)&#xff0c;截图后面有带源码(源码方便大家复制)。/** * 文件描述:js项目开发中的常用方法工具 * *//** * 全局常量 */var DEFAULT_LINE_KE…

tail将输出的日志放到文件中_如何将Spring Boot应用中日志输出格式改为JSON?

作者&#xff1a;DEV出自&#xff1a;解道JDON原文&#xff1a;jdon.com/55006今天&#xff0c;我们有了一类称为日志聚合系统的应用程序。当我们拥有大量微服务并且我们希望跨微服务跟踪日志时&#xff0c;日志聚合很有用。传统的Java应用程序日志如下所示&#xff1a;2020-09…

造轮子是什么意思_程序员为什么热衷于造轮子,升职加薪吗?

作者&#xff1a;小傅哥博客&#xff1a; https://bugstack.cn-沉淀、分享、成长&#xff0c;让自己和他人都能有所收获&#xff01;一、前言哪个架构师没造过轮子&#xff1f;你想过这样一件事吗&#xff1f; 是先具备能力在安排职位&#xff0c;还是先安排职位在学习&#xf…