牛客网-SQL专项练习2
①从学生信息表(student)中提取姓名(name)列值为NULL的记录,SQL语句为:
解析:注意不是只查name值,而是查name值为空的所有信息
SQL语句为:
SELECT * FROM student WHERE name is NULL;
知识点:判断是否为空值用 IS NULL 和 IS NOT NULL。
②需查看stu表中索引的索引信息时,应使用的存储过程是()
A.sp_helpindex B.sp_help
C.sp_helpdb D.sp_helptext
解析:查看索引信息时,应使用的存储过程是sp-helpindex。sp_help:报告有关数据库对象的信息。sp_helpdb:返回指定数据库或者全部数据库的信息。sp_helptext:显示规则、默认、存储过程、触发器、视图等对象的未加密的文本定义信息。
③SQL中,对于数据定义语言DDL描述是:定义数据库的结构。
SQL主要分成四部分:
(2)数据操纵语言。(SQL DML)数据操纵分成数据查询和数据更新两类。数据更新又分成插入、删除、和修改三种操作。
(3)数据库控制语言,授权,角色控制等。(DCL)包括对基本表和视图的授权,完整性规则的描述,事务控制等内容。
现要找出,除开在职员工(指to_date = '9999-01-01')的最大、最小工资(可能存在并列最大或最小)后,其他员工的平均工资avg_salary,示例数据查询后输出:

MySQL查询语句为:

我的理解:我觉得这个题目有点让人误解,我以为是除开在职员工工资的最大值和最小值,算剩下员工工资的平均值。当我看了他的结果,一计算发现73292是除了在职员工的最大值和最小值后,算在职员工的平均薪资。而且还说了可能有并列的最大值和最小值,如果按照D选项算出最大值和最小值后,又用了NOT IN 就会排除所以的最大值和最小值。感觉C选项是对的。但是官方答案是D。
⑤Mysql中表student_table(id,name,birth,sex),插入如下记录:
('1009' , '李四', '2000-01-01', '男');
('1010' , '李四', '2001-01-01', '男');
('1006' , '王五', '2000-08-06' , '女');
('1008' , '张三', '2002-12-01', '女');
('1012' , '张三', '2001-12-01', '女');
('1011' , '李四', '2002-08-06' , '女');
执行
from (
select * from student_table where sex = '男' ) t1
right join
(select * from student_table where sex = '女')t2
on t1.name = t2.name ;
的结果行数是:5
NULL NULL NULL NULL 1006 王五 2000-08-06 女
1004 张三 2000-08-06 男 1008 张三 2002-12-01 女
1004 张三 2000-08-06 男 1012 张三 2001-12-01 女
1009 李四 2000-01-01 男 1011 李四 2002-08-06 女
1010 李四 2001-01-01 男 1011 李四 2002-08-06 女
id name birth sex id name birth sex
1004 张三 2000-08-06 男 1008 张三 2002-12-01 女
1004 张三 2000-08-06 男 1012 张三 2001-12-01 女
1009 李四 2000-01-01 男 1011 李四 2002-08-06 女
1010 李四 2001-01-01 男 1011 李四 2002-08-06 女
如果为左连接left join,t1为主表,t2为从表,从表有两个张三满足条件,于是主表再重复一遍张三,则查得结果为:
1004 张三 2000-08-06 男 1008 张三 2002-12-01 女
1004 张三 2000-08-06 男 1012 张三 2001-12-01 女
1009 李四 2000-01-01 男 1011 李四 2002-08-06 女
1010 李四 2001-01-01 男 1011 李四 2002-08-06 女
总结:
1)不论左右连接,两表排序都是先写的放在左边,后写的放在右边;
2)左右连接中,以谁为主表,则其信息全部保存。从表中有多于一项符合条件的,则额外重复一次主表从而列出全部从表情况。
牛客网-SQL专项练习2的更多相关文章
- MySql面试题、知识汇总、牛客网SQL专题练习
点击名字直接跳转到链接: Linux运维必会的100道MySql面试题之(一) Linux运维必会的100道MySql面试题之(二) Linux运维必会的100道MySql面试题之(三) Linux运 ...
- 牛客网Sql
牛客网Sql: 1.查询最晚入职的员工信息 select * from employees where hire_date =(select max(hire_date) from employee ...
- 牛客网sql刷题解析-完结
查找最晚入职员工的所有信息 解题步骤: 题目:查询最晚入职员工的所有信息 目标:查询员工的所有信息 筛选条件:最晚入职 答案: SELECT *--查询所有信息就用* ...
- Java基础之引用(String,char[],Integer)总结于牛客网的专项练习题
1.String的引用: 下列代码执行后的结果为: public class Test { public static void main(String[] args) { StringBuffer ...
- 牛客网sql练习
一建表语句 /* Navicat MySQL Data Transfer Source Server : test Source Server Version : 50717 Source Host ...
- 牛客网sql实战参考答案(mysql版):16-21
16.统计出当前(titles.to_date='9999-01-01')各个title类型对应的员工当前(salaries.to_date='9999-01-01')薪水对应的平均工资.结果给出ti ...
- 牛客网sql实战参考答案(mysql版):1-15
1.查找最晚入职员工的所有信息,为了减轻入门难度,目前所有的数据里员工入职的日期都不是同一天(sqlite里面的注释为--,mysql为comment) CREATE TABLE `employees ...
- 牛客网数据库SQL实战解析(51-61题)
牛客网SQL刷题地址: https://www.nowcoder.com/ta/sql?page=0 牛客网数据库SQL实战解析(01-10题): https://blog.csdn.net/u010 ...
- 牛客网数据库SQL实战解析(41-50题)
牛客网SQL刷题地址: https://www.nowcoder.com/ta/sql?page=0 牛客网数据库SQL实战解析(01-10题): https://blog.csdn.net/u010 ...
- 牛客网数据库SQL实战解析(31-40题)
牛客网SQL刷题地址: https://www.nowcoder.com/ta/sql?page=0 牛客网数据库SQL实战解析(01-10题): https://blog.csdn.net/u010 ...
随机推荐
- 数组动态表单验证,添加数组,逆序添加,表单验证会错位,发现是key的默认index问题,还有验证trigger问题,添加数据会爆红
数组动态表单验证,添加数组,逆序添加,表单验证会错位,发现是key的默认index问题,还有验证trigger问题,添加数据会爆红 解决方案: trigger: 'blur,change' 换 tri ...
- C++保证线程安全的方式
1.互斥量 可以确保同一时间只有一个线程访问临界区,防止出现竞态条件. 2.原子操作 std::atomic<int> mutex(1); 对原子变量的操作是线程安全的. 3.读写锁 st ...
- linux使用hostapd+dnsmasq管理多张网卡,搭建dns服务器,并发射wifi热点(支持360wifi等等)
PS:要转载请注明出处,本人版权所有. PS: 这个只是基于<我自己>的理解, 如果和你的原则及想法相冲突,请谅解,勿喷. 前置说明 本文发布于 2015-03-03 18:37:39 ...
- 广西首次!3DCAT实时云渲染助力南宁数字气象科普馆上线
11月17日,南宁市气象局举行数字气象科普馆上线发布仪式.目前,以气象为主题的三维虚拟数字气象科普馆在广西尚属首创.17日起,在微信搜索小程序南宁气象科普馆&就能在3DCAT实时云渲染技术助力 ...
- drf(序列化器)
一 序列化器组件介绍(Serializer) 1 序列化器组件介绍 序列化组件,又称序列化器,是处理对象和字典的数据格式转换,json的序列化和反序列化,在Request和Response处理了. ' ...
- 安装npm install报错npm ERR! code ETIMEDOUT npm ERR! errno ETIMEDOUT npm ERR! network request to https://registry.npmjs.org/webpack-subresource-integrity failed, reason
执行命令:npm run dev 启动前端项目报如下错误,vue-cli-service是Vue一个启动的插件,需要安装 D:\nodejs\npm.cmd run dev > yuntan1h ...
- java 发送 http 请求练习两年半(HttpURLConnection)
1.起一个 springboot 程序做 http 测试: @GetMapping("/http/get") public ResponseEntity<String> ...
- 关于SQL Server数据库中的用户权限和角色管理
简介 在SQL Server数据库系统中,管理用户权限和角色对于确保数据安全.完整性和可访问性至关重要.在本文中,我们将探讨在SQL Server数据库中创建用户.分配权限和管理角色的过程.我们将涵盖 ...
- C# URL参数编码
string s = "lw123abc测试信息!@#¥%--&*()--+"; Console.WriteLine("原数据:\t\t" + s); ...
- MongoDB java.lang.ClassCastException: java.lang.Double cannot be cast to java.lang.Integer
详细报错如下: java.lang.ClassCastException: java.lang.Double cannot be cast to java.lang.Integer at or ...