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,一经查实,立即删除!

相关文章

python qt开发_Python 使用Qt进行开发(三)

下面我们实现日期时间框的添加,表示日期时间的文本框可以使用QtWidgets控件下的 QDateEdit() , QTimeEdit() , QDateTime() 三个方法实现。1,使用QDateEdit() 我们可以得到一个只显示日期的文本框,在文本框中我们可以手动输入日期&#xff0c…

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语言编程基础视频_网络编程-5_ Python系列视频(一)——Python语言基础_Python视频-51CTO学院...

通过学习&#xff0c;对Python有一定的了解&#xff0c;学习Python语法&#xff0c;可以使用Python原生语言开发项目。对于Python的应用于开发有一个系统的认知&#xff0c;对于未来的发展方向有清晰的认识。主要知识点包括基本语法、文件操作、库、面向对象、进程线程协程、网…

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

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

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

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

arp miss攻击_网络应用华为S9300核心交换机ARP安全配置

ARP安全简介ARP 安全通过过滤不信任的ARP 报文以及对某些ARP 报文进行时间戳抑制来保证网络设备的安全性和健壮性。网络中有很多针对ARP 表项的攻击&#xff0c;攻击者通过发送大量伪造的ARP 请求、应答报文攻击网络设备&#xff0c;主要有ARP 缓冲区溢出攻击和ARP 拒绝服务攻击…

python实现二分查找算法_两种方法实现Python二分查找算法

一. arr[1,3,6,9,10,20,30] def findnumber(l,h,number): mid(lh)//2 if arr[mid]number: print("找到了"str(mid)) elif arr[mid] l mid return findnumber(mid1,h,number) elif arr[mid]>number: h mid return findnumber(0,mid-1,number) else: print("…

python 动态规划 回溯_回溯算法 - 全排列算法实现(pythondart)

回溯算法 , 就是 穷举解决一个回溯问题,实际上就是一个决策树的遍历过程.路径: 也就是已经做出的选择选择列表: 也就是你当前可以做的选择结束条件: 也就是到达决策树底层,无法再做选择的条件.回溯算法的一个特点: 它不像动态规划存在重叠子问题可以优化,回溯算法就是纯暴力穷举…

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

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

华为简易压缩算法python_Python(9) --实现一个简单的压缩软件/解压软件的功能

#压缩软件#导入所需模块&#xff0c;设置界面import osimport zipfileimport tkinterimport tkinter.messageboximport tkinter.filedialogroot tkinter.Tk()root.title(我的压缩软件)root.minsize(300,400)#设置需要压缩文件的路径变量filenames []#添加文件的函数def addfi…

python from import什么意思_Python 引用From import介绍

一. 模块的定义与分类模块是什么&#xff1f;​ 这几天&#xff0c;我们进入模块的学习。在学习模块之前&#xff0c;我们首先要知道&#xff0c;什么是模块&#xff1f;​ 一个函数封装一个功能&#xff0c;你使用的软件可能就是由n多个函数组成的(先不考虑面向对象)。比如抖音…

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

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

层次聚类python实现_Python机器学习——Agglomerative层次聚类

层次聚类(hierarchical clustering)可在不同层次上对数据集进行划分&#xff0c;形成树状的聚类结构。AggregativeClustering是一种常用的层次聚类算法。其原理是&#xff1a;最初将每个对象看成一个簇&#xff0c;然后将这些簇根据某种规则被一步步合并&#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…