首页 > 试题广场 >

查找employees表emp_no与last_name的员

[编程题]查找employees表emp_no与last_name的员
  • 热度指数:317754 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32M,其他语言64M
  • 算法知识视频讲解
有一个员工表employees简况如下:
emp_no
birth_date
first_name
last_name
gender hire_date
10001
1953-09-02
Georgi
Facello
M 1986-06-26
10002
1964-06-02
Bezalel
Simmel
F 1985-11-21
10003
1959-12-03
Bezalel
Mary M 1986-08-28
10004
1954-05-01
Christian
Koblick
M 1986-12-01
10005 1953-11-07 Mary Sluis F 1990-01-22

请你查找employees表所有emp_no为奇数,且last_name不为Mary的员工信息,并按照hire_date逆序排列,以上例子查询结果如下:
emp_no birth_date first_name last_name gender hire_date
10005
1953-11-07 Mary
Sluis   F
1990-01-22
10001 1953-09-02 Georgi Facello   M 1986-06-26
示例1

输入

drop table if exists  `employees` ; 
CREATE TABLE `employees` (
`emp_no` int(11) NOT NULL,
`birth_date` date NOT NULL,
`first_name` varchar(14) NOT NULL,
`last_name` varchar(16) NOT NULL,
`gender` char(1) NOT NULL,
`hire_date` date NOT NULL,
PRIMARY KEY (`emp_no`));
INSERT INTO employees VALUES(10001,'1953-09-02','Georgi','Facello','M','1986-06-26');
INSERT INTO employees VALUES(10002,'1964-06-02','Bezalel','Simmel','F','1985-11-21');
INSERT INTO employees VALUES(10003,'1959-12-03','Bezalel','Mary','M','1986-08-28');
INSERT INTO employees VALUES(10004,'1954-05-01','Chirstian','Koblick','M','1986-12-01');
INSERT INTO employees VALUES(10005,'1953-11-07','Mary','Sluis','F','1990-01-22');

输出

10005|1953-11-07|Mary|Sluis|F|1990-01-22
10001|1953-09-02|Georgi|Facello|M|1986-06-26
头像 牛客题解官
发表于 2025-03-17 10:18:20
精华题解 这道题目要求我们从员工表中查找出员工编号为奇数且姓氏不为“Mary”的员工信息,我们要做的事情如下: 1. 确定总体问题 我们需要从员工表中提取数据,应用条件过滤和排序,并按入职日期降序排列。 2. 分析关键问题 筛选奇数编号的员工:使用条件过滤筛选出员工编号为奇数的员工。 排除姓氏为“Mary” 展开全文
头像 N刻后告诉你
发表于 2020-05-19 20:32:32
题目:查找employees表所有emp_no为奇数,且last_name不为Mary的员工信息,并按照hire_date逆序排列题意:每个title下,emp_no重复的员工忽略不计 方法1:使用%SELECT *FROM employeesWHERE emp_no % 2 = 1 AND 展开全文
头像 不是江小白
发表于 2020-10-23 13:26:05
此题跟leetcode的一道题几乎一样,除了字段名不同,解法相同。之前小白特地去查了一下相关的知识总结了一篇博客,希望对大家有帮助。博文指路👉:https://blog.csdn.net/weixin_41013322/article/details/106146793
头像 数据分析阿宇君
发表于 2020-08-21 15:05:34
法一:使用% select * from employees where emp_no%2 =1 and last_name!='Mary' order by hire_date desc 补充:不相等有三种表示方式:<>、!=、IS NOT 法二:使用& SELECT * F 展开全文
头像 F_anta
发表于 2021-07-22 16:42:25
课程难度是简单的,奇偶判断下意识会用mod()函数,%2的想法,但是看到讨论中一位兄弟的结果,是始料未及的。【通过二进制方式,&字符判断奇偶】select *from employeeswhere emp_no&1 =1 and last_name <>'Mary'ord 展开全文
头像 高质量搬砖人
发表于 2021-01-29 15:21:59
方法)NOT LIKE  last_name不为Mary 按照hire_date逆序排列 emp_no为奇数 奇数 -- [expression]%2 = 1 偶数 -- [expression]%2 = 0 展开全文
头像 Master_zx
发表于 2021-11-19 14:15:42
select * from employees where SUBSTRING(emp_no,5,1) in ('1','3','5','7','9') and last_name != 'Mary' order by hire_date DESC SUBSTRING 解题思路: 1.本题需要获取e 展开全文
头像 小佛系
发表于 2021-07-06 11:31:19
select * from employees where emp_no mod 2 <> 0 and last_name <> 'Mary' order by hire_date desc其实这题的唯一难点就是员工号是奇数怎么判断。奇数是不能整除2的,那么奇数除以2就 展开全文
头像 jiang_dr
发表于 2021-10-09 09:16:00
位运算 select * from employees where emp_no & 1 = 1 and last_name != 'Mary' order by hire_date desc 思路:按照给定要求作答即可 其中,使用位运算是效率最高的,当然也可以使用取模 在这补充一下位运 展开全文
头像 数据流动DataFlow
发表于 2023-03-12 23:34:08
方法一:思路:员工号为奇数,则 emp_no 取余应为 1,last_name 不为 Mary,用‘!=’表示,另外注意字符串要用单引号括起来,逆序用 desc。代码: select * from employees where emp_no % 2 = 1 and last_name != 'Ma 展开全文
头像 牛客225632273号
发表于 2022-01-12 11:02:20
本题中值得积累的知识点:1、判断奇数的方法 n%2=1;判断偶数的方法 n%2=0;2、匹配字段是否相同的方法 使用不等于符号 != 或 <>; 解题代码: select * from employees as e where e.emp_no %2=1 and e.last_ 展开全文