SQL牛客网刷题(八)——13、14、34、35、36题解析

  • SQL13. 从titles表获取按照title进行分组
  • SQL14. 从titles表获取按照title进行分组,注意对于重复的emp_no进行忽略
  • SQL34. 对于表actor批量插入数据
  • SQL35. 批量插入数据,如果数据已经存在,请忽略
  • SQL36. 创建一个actor_name表,并且将actor表中的所有first_name以及last_name导入该表

SQL13. 从titles表获取按照title进行分组

题目描述

从titles表获取按照title进行分组,每组个数大于等于2,给出title以及对应的数目t。 CREATE TABLE IF NOT
EXISTS “titles” ( emp_no int(11) NOT NULL, title varchar(50) NOT
NULL, from_date date NOT NULL, to_date date DEFAULT NULL);

代码

select title, count(1) as t
from titles
group by title
having count(1)>=2;

思路

这题重点要区分的还是having和where的区别,这里只能用having

SQL14. 从titles表获取按照title进行分组,注意对于重复的emp_no进行忽略

题目描述

从titles表获取按照title进行分组,每组个数大于等于2,给出title以及对应的数目t。
注意对于重复的emp_no进行忽略(即emp_no重复的title不计算,title对应的数目t不增加)。
CREATE TABLE IF NOT EXISTS titles (
emp_no int(11) NOT NULL,
title varchar(50) NOT NULL,
from_date date NOT NULL,
to_date date DEFAULT NULL);

代码

select title, count(distinct emp_no) as t
from titles
group by title
having count(distinct emp_no)>=2;

思路

这题较上题唯一的区别就在于本题需要对emp_no的重复值忽略,因此只需要一个distinct保留唯一值就可以了

SQL34. 对于表actor批量插入数据

题目描述

对于表actor批量插入如下数据(不能有2条insert语句哦!) CREATE TABLE IF NOT EXISTS actor (
actor_id smallint(5) NOT NULL PRIMARY KEY, first_name varchar(45) NOT
NULL, last_name varchar(45) NOT NULL, last_update timestamp NOT NULL
DEFAULT (datetime(‘now’,‘localtime’)))
在这里插入图片描述

代码

insert into actor values
(1,'PENELOPE','GUINESS','2006-02-15 12:34:33'),
(2,'NICK','WAHLBERG','2006-02-15 12:34:33');

思路

这题没啥难度,简单地insert语句,不过说实在的,作为数据分析师而言,重点需掌握的还是查(select),增删改涉及不多。

SQL35. 批量插入数据,如果数据已经存在,请忽略

题目描述

对于表actor批量插入如下数据,如果数据已经存在,请忽略(不支持使用replace操作) CREATE TABLE IF NOT
EXISTS actor ( actor_id smallint(5) NOT NULL PRIMARY KEY, first_name
varchar(45) NOT NULL, last_name varchar(45) NOT NULL, last_update
timestamp NOT NULL DEFAULT (datetime(‘now’,‘localtime’)))
在这里插入图片描述

代码

insert or ignore into actor values
('3','ED','CHASE','2006-02-15 12:34:33');

思路

这题报错了几次,原因是题目环境是SQLlite,因此ignore前面需要加上or,如果是mysql的话不需要or,其他的和上题一样,没什么难度

SQL36. 创建一个actor_name表,并且将actor表中的所有first_name以及last_name导入该表

题目描述

请你创建一个actor_name表,并且将actor表中的所有first_name以及last_name导入该表.
actor_name表结构如下:
在这里插入图片描述

代码

create table actor_name(
first_name varchar(45) not null,
last_name varchar(45) not null
);
insert into actor_name select first_name, last_name from actor;

思路

这个题我的思路首先是创表,思路和SQL33题没什么区别,然后就是查询actor表中需要的字段,再insert into到新表中,值得注意的就是insert into后面不用加values

以上,欢迎指正

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值