【Leecode】175. 组合两个表

解答:由于是组合两个表的信息,很容易想到连接查询,这里使用左连接

select p.Firstname,p.Lastname,q.City,q.State from Person as p left join Address as q on p.PersonId=q.PersonId;

【Leecode】176. 第二高的薪水

解答:

第一种解法: 我们很容易知道第一高的薪水(max函数),所以,除去第一高的薪水再找最高的薪水,就是第二高的薪水了

select max(Salary) as SecondHighestSalary from Employee where Salary not in (select max(Salary) from Employee);

第二种解法:按薪水从高到低排序,再找第二条数据就是第二高薪水了。limit 1表示读取一行数据, offset 1 表示从表的第二行开始读取

select Salary as SecondHighestSalary from Employee order by Salary desc limit 1 offset 1;

【Leecode】181. 超过经理收入的员工

解答:

这里涉及到同一个表中的字段值的比较,所以可以为这张表建两个别名(当作两张表)。

第一种解法:直接找出员工的薪水和对应的经理的薪水,进行比较

select e1.Name as Employee from Employee as e1 where e1.Salary>(select e2.Salary from Employee as e2 where e1.ManagerId=e2.Id)

第二种解法:使用join连接查询,相当于把表划分为员工表和经理表,再对各自的薪水进行比较

select e1.Name as Employee from Employee as e1 join Employee as e2 where e1.ManagerId=e2.Id and e1.Salary>e2.Salary

【Leecode】182. 查找重复的电子邮箱

解答:首先想到应该就是根据 Email 分组,再计算每个分组的行数是否大于1.

select Email from Person group by Email having count(Email)>1

【Leecode】183. 从不订购的客户

解答:

第一种解法:直接查找用户表的Id不在订单表中出现过的用户即可

select Name as Customers from Customers where Id not in (select CustomerId from Orders)

第二种解法:左连接查找。以用户表为基准,连接订单表,查找CustomerId为空的数据

select c.Name as Customers from Customers as c left join Orders as o on o.CustomersId=c.Id and o.CustomerId is null

【Leecode】196. 删除重复的电子邮箱

解答:这里涉及到同一个表中的字段值 Id 的比较,所以可以为这张表建两个别名(当作两张表)。

delete p1 from Person as p1, Person as p2 where (p1.Email=p2.Email) and (p1.Id>p2.Id) 

【Leecode】197. 上升的温度

解答:涉及到同一张表中的字段值比较,所以可以为这张表建两个别名(当作两张表),这里关键是判断日期的连续性

第一种解法:DATEDIFF函数来判断日期

select w1.Id from Weather as w1, Weather as w2 where (w1.Temperature>w2.Temperature) and DATEDIFF(w1.RecordDate, w2.RecordDate)=1;

第二种解法:TO_DATE函数来判断日期

select w1.Id from Weather as w1, Weather as w2 where w1.Temperature>w2.Temperature and TO_DAYS(w1.RecordDate)=TO_DAYS(w2.RecordDate)+1;

第三种解法:SUBDATE函数来判断日期

select w1.Id from Weather as w1, Weather as w2 where w1.Temperature>w2.Temperature and SUBDATE(w1.RecordDate,1)=w2.RecordDate;

【Leecode】595. 大的国家

解答:这里使用 or 即可

select name, population, area from World where (area>3000000) or (population>25000000)

【Leecode】596. 超过5名学生的课

解答:对 class 分组,计算分组的数据是否大于等于5即可,还要使用 distinct 去重

select class from courses group by class having count(distinct student)>=5

【Leecode】620. 有趣的电影

解答:这里关键是找出奇数 Id,可以巧妙使用 & 运算,奇数&1为1(True),偶数&1为0(False)

select * from cinema where description!='boring' and id&1 order by rating desc;

【Leecode】627. 交换工资

解答:可以使用 if 语句来做判断

update salary set sex=if(sex='f', 'm', 'f')

(三)MySQL学习笔记的更多相关文章

  1. Mysql学习笔记(三)对表数据的增删改查。

    正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...

  2. MYSQL学习笔记三:日期和时间函数

    MYSQL学习笔记三:日期和时间函数 1. 获取当前日期的函数和获取当前时间的函数 /*获取当前日期的函数和获取当前时间的函数.将日期以'YYYY-MM-DD'或者'YYYYMMDD'格式返回 */ ...

  3. MySql学习笔记三

    MySql学习笔记三 4.DML(数据操作语言) 插入:insert 修改:update 删除:delete 4.1.插入语句 语法: insert into 表名 (列名1,列名2,...) val ...

  4. MySQL学习笔记一

    MySQL 学习笔记 一 一.数据库简单介绍 1. 按照数据库的发展时间顺序,主要出现了以下类型数据库系统: Ø 网状型数据库 Ø 层次型数据库 Ø 关系型数据库 Ø 面向对象数据库 上面4中数据库系 ...

  5. Mysql学习笔记(二)数据类型 补充

    原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求 String类型: i.char与 ...

  6. Mysql学习笔记(一)数据类型

    原文:Mysql学习笔记(一)数据类型 学习内容: Mysql基本数据类型. 1.数字类型.. i.整型     Mysql数据类型             含义(有符号)     tinyint(m ...

  7. 初识mysql学习笔记

    使用VMVirtualBox导入Ubuntu后,可以通过sudo apt-get install mysql-server命令下载mysql. 在学习过程中,我遇到了连接不上Xshell的问题.最终在 ...

  8. MySQL学习笔记-锁相关话题

    在事务相关话题中,已经提到事务隔离性依靠锁机制实现的.在本篇中围绕着InnoDB与MyISAM锁机制的不同展开,进而描述锁的实现方式,多种锁的概念,以及死锁产生的原因.   Mysql常用存储引擎的锁 ...

  9. MySQL学习笔记-大纲

    软件程序性能测试在之前<品味性能之道>系列中已经大量提到,讲解了很多测试方法.测试观念.测试思想等等.最近准备深入MySQL进行学习并总结.分别查阅<MySQL性能调优与架构设计&g ...

  10. 【mysql学习笔记整理】

    /*mysql学习笔记整理*/ /*常用的数据库操作对象*/ #库的操作#创建#数据库的创建USE mysql;CREATE DATABASE db_x;#删除#删除数据库DROP DATABASE ...

随机推荐

  1. 洛谷P2464 [SDOJ2008]郁闷的小J

    洛谷P2464 [SDOJ2008]郁闷的小J 题目描述 小J是国家图书馆的一位图书管理员,他的工作是管理一个巨大的书架.虽然他很能吃苦耐劳,但是由于这个书架十分巨大,所以他的工作效率总是很低,以致他 ...

  2. pyhon3.0 day01 变量、输入、输出、循环

    pyhon3.0 基础01 1 python解释器 Python的解释器很多,但使用最广泛的还是CPython.如果要和Java或.Net平台交互,最好的办法不是用Jython或IronPython, ...

  3. mac生成ssh公私匙

    1. cd ~/.ssh/ 2.ssh-keygen 3.id_rsa.pub文件放入git 4.私匙放进jenkins

  4. ython进阶06 循环对象

    这一讲的主要目的是为了大家在读Python程序的时候对循环对象有一个基本概念. 循环对象的并不是随着Python的诞生就存在的,但它的发展迅速,特别是Python 3x的时代,循环对象正在成为循环的标 ...

  5. Spring框架 之IOC容器 和AOP详解

    主要分析点: 一.Spring开源框架的简介  二.Spring下IOC容器和DI(依赖注入Dependency injection) 三.Spring下面向切面编程(AOP)和事务管理配置  一.S ...

  6. Python爬虫下载Bilibili番剧弹幕

    本文绍如何利用python爬虫下载bilibili番剧弹幕. 准备: python3环境 需要安装BeautifulSoup,selenium包 phantomjs 原理: 通过aid下载bilibi ...

  7. 优先队列(堆) -数据结构(C语言实现)

    数据结构与算法分析 优先队列 模型 Insert(插入) == Enqueue(入队) DeleteMin(删除最小者) == Dequeue(出队) 基本实现 简单链表:在表头插入,并遍历该链表以删 ...

  8. 《Cocos2d-x游戏开发实战精解》学习笔记2--在Cocos2d-x中显示一行文字

    在Cocos2d-x中要显示文字就需要用到Label控件.在3.x版本的Cocos2d中,舍弃了之前版本所使用的LabelTTF.LabelAtlas.LabelBMFont 3个用于显示文字的类,而 ...

  9. US Customs bond DDP 船运

    客户提供目的港门点地址,提供美国进口产品的关税税率基本上就可以了关于ISF信息到时候你发给老外让老外填填好就可以了BAND 货值*0.575%POA  货值*0.335%这二个费用如果国内付就付了,国 ...

  10. 团队Alpha冲刺(六)

    目录 组员情况 组员1(组长):胡绪佩 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:凯琳 组员6:翟丹丹 组员7:何家伟 组员8:政演 组员9:黄鸿杰 组员10:刘一好 组员11:何宇恒 展示 ...