牛客:数据库实战—2—查找各个部门当前(to_date='9999-01-01')领导当前薪水详情以及其对应部门编号dept_no

CREATE TABLE `dept_manager` (
`dept_no` char(4) NOT NULL,
`emp_no` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`dept_no`));
CREATE TABLE `salaries` (
`emp_no` int(11) NOT NULL,
`salary` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`from_date`));
SELECT s.emp_no,s.salary,s.from_date,s.to_date,dm.dept_no FROM
  salaries s,dept_manager dm WHERE
  s.to_date='9999-01-01' AND
  dm.to_date='9999-01-01' AND 
  dm.emp_no = s.emp_no;

做这个题目真是折腾,salaries是主表,dept_manager 是从表,

问题是在于dep_manager为主表的时候,会出现对应的salaries相应的列有null的情况。

因此From后面跟上顺序不能错。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这是一个统计留存率的问题,留存率的定义是指在某个时间段内,用户继续使用产品的比例。对于这个问题,我们需要计算新登录用户在第二天仍然登录的比例。具体步骤如下: 1. 找到所有新登录用户 新登录用户的定义是第一次登录牛客网的用户,因此我们需要找到第一次登录的记录,可以按日期升序排序,然后按用户分组,取每个用户的第一条记录即可。 2. 计算次日留存率 对于每个新登录用户,找到其第二天的登录记录,如果存在,则认为该用户次日成功留存,否则认为该用户次日未留存。最后将留存用户数除以总登录用户数即可得到留存率。 下面是具体的 SQL 语句实现: ``` SELECT COUNT(DISTINCT t1.user_id) AS login_users, COUNT(DISTINCT t2.user_id) AS retained_users, COUNT(DISTINCT t2.user_id) / COUNT(DISTINCT t1.user_id) AS retention_rate FROM login_records t1 LEFT JOIN login_records t2 ON t1.user_id = t2.user_id AND DATEDIFF(t2.date, t1.date) = 1 WHERE t1.date = (SELECT MIN(date) FROM login_records WHERE user_id = t1.user_id) ``` 解释一下这个 SQL 语句。首先,我们使用左连接将每个新登录用户的记录和其第二天的记录连接起来,连接条件是用户相同且日期相差1天。然后,我们使用 WHERE 子句过滤出每个用户的第一条记录,并计算总登录用户数、留存用户数和留存率。其中,COUNT(DISTINCT t1.user_id) 表示总登录用户数,COUNT(DISTINCT t2.user_id) 表示留存用户数,COUNT(DISTINCT t2.user_id) / COUNT(DISTINCT t1.user_id) 表示留存率。 注意,这里使用了子查询来找到每个用户的第一条记录,具体做法是在 WHERE 子句中使用了一个标量子查询,该子查询返回每个用户的最早登录日期。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值