数据库SQL查询相关练习

这篇具有很好参考价值的文章主要介绍了数据库SQL查询相关练习。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

第一题:表名:worker-- 表中字段均为中文,比如 部门号 工资 职工号 参加工作 等

CREATE TABLE worker (
	部门号 int(11) NOT NULL,
	职工号 int(11) NOT NULL,
	工作时间 date NOT NULL,
	工资 float(8,2) NOT NULL,
	政治面貌 varchar(10) NOT NULL DEFAULT '群众',
	姓名 varchar(20) NOT NULL,
	出生日期 date NOT NULL,
	PRIMARY KEY (职工号)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;
INSERT INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌,姓名, 出生日期) VALUES (101, 1001, '2015-5-4', 3500.00, '群众', '张三', '1990-7-1');
INSERT INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌,姓名, 出生日期) VALUES (101, 1002, '2017-2-6', 3200.00, '团员', '李四', '1997-2-8');
INSERT INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌,姓名, 出生日期) VALUES (102, 1003, '2011-1-4', 8500.00, '党员', '王亮', '1983-6-8');
INSERT INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌,姓名, 出生日期) VALUES (102, 1004, '2016-10-10', 5500.00, '群众', '赵六', '1994-9-5');
INSERT INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌,姓名, 出生日期) VALUES (102, 1005, '2014-4-1', 4800.00, '党员', '钱七', '1992-12-30');
INSERT INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌,姓名, 出生日期) VALUES (102, 1006, '2017-5-5', 4500.00, '党员', '孙八', '1996-9-2');

1、显示所有职工的基本信息。

SELECT * FROM worker;

2、查询所有职工所属部门的部门号,不显示重复的部门号。

SELECT DISTINCT 部门号 FROM worker;

3、求出所有职工的人数。

SELECT COUNT(职工号) '人数' FROM worker;

4、列出最高工和最低工资。

SELECT MAX(工资) '最高工资',MIN(工资) '最低工资' FROM worker;

5、列出职工的平均工资和总工资。

SELECT AVG(工资) '平均工资',SUM(工资) '总工资' FROM worker;

6、创建一个只有职工号、姓名和参加工作的新表,名为工作日期表。

CREATE TABLE WorkDate(职工号 INT(11) NOT NULL,姓名 VARCHAR(20) NOT NULL,work VARCHAR(20) NOT NULL);

8、列出所有姓刘的职工的职工号、姓名和出生日期。

SELECT 职工号,姓名,出生日期 FROM worker WHERE 姓名 LIKE '刘%';

9、列出1960年以前出生的职工的姓名、参加工作日期。

SELECT 姓名,工作时间 FROM worker WHERE 出生日期 < 1960;

10、列出工资在1000-2000之间的所有职工姓名。

SELECT 姓名 FROM worker WHERE 工资 BETWEEN 1000 AND 2000;

11、列出所有陈姓和李姓的职工姓名。

SELECT 姓名 FROM worker WHERE 姓名 LIKE '刘%' OR 姓名 LIKE '李%';

12、列出所有部门号为2和3的职工号、姓名、党员否。

SELECT 职工号,姓名,政治面貌 FROM worker WHERE 部门号='102' OR 部门号='103';

13、将职工表worker中的职工按出生的先后顺序排序。

SELECT 姓名 FROM worker ORDER BY 出生日期 asc;

14、显示工资最高的前3名职工的职工号和姓名。

SELECT 职工号,姓名 FROM worker ORDER BY 工资 desc limit 3;

15、求出各部门党员的人数。

SELECT COUNT(*) '党员人数' FROM worker WHERE 政治面貌='党员' ORDER BY 部门号;

16、统计各部门的工资和平均工资

SELECT AVG(工资) '平均工资',SUM(工资) '总工资' FROM worker ORDER BY 部门号;

17、列出总人数大于4的部门号和总人数。

SELECT 部门号,COUNT(*) '总人数' FROM worker GROUP BY 部门号 HAVING COUNT(*)>=4;

第二题:多表查询

1.创建student和score表
CREATE  TABLE student (
	id  INT(10)  NOT NULL  UNIQUE  PRIMARY KEY ,
	name  VARCHAR(20)  NOT NULL ,
	sex  VARCHAR(4) ,
	birth  YEAR,
	department  VARCHAR(20) ,
	address  VARCHAR(50)
);
创建score表。SQL代码如下:
CREATE  TABLE score (
	id  INT(10)  NOT NULL  UNIQUE  PRIMARY KEY  AUTO_INCREMENT ,
	stu_id  INT(10)  NOT NULL ,
	c_name  VARCHAR(20) ,
	grade  INT(10)
);
2.为student表和score表增加记录
向student表插入记录的INSERT语句如下:
INSERT INTO student VALUES( 901,'张老大', '男',1985,'计算机系', '北京市海淀区');
INSERT INTO student VALUES( 902,'张老二', '男',1986,'中文系', '北京市昌平区');
INSERT INTO student VALUES( 903,'张三', '女',1990,'中文系', '湖南省永州市');
INSERT INTO student VALUES( 904,'李四', '男',1990,'英语系', '辽宁省阜新市');
INSERT INTO student VALUES( 905,'王五', '女',1991,'英语系', '福建省厦门市');
INSERT INTO student VALUES( 906,'王六', '男',1988,'计算机系', '湖南省衡阳市');
向score表插入记录的INSERT语句如下:
INSERT INTO score VALUES(NULL,901, '计算机',98);
INSERT INTO score VALUES(NULL,901, '英语', 80);
INSERT INTO score VALUES(NULL,902, '计算机',65);
INSERT INTO score VALUES(NULL,902, '中文',88);
INSERT INTO score VALUES(NULL,903, '中文',95);
INSERT INTO score VALUES(NULL,904, '计算机',70);
INSERT INTO score VALUES(NULL,904, '英语',92);
INSERT INTO score VALUES(NULL,905, '英语',94);
INSERT INTO score VALUES(NULL,906, '计算机',90);
INSERT INTO score VALUES(NULL,906, '英语',85);

3.查询student表的所有记录

SELECT * FROM student;

4.查询student表的第2条到4条记录

SELECT * FROM student LIMIT 2,4;

5.从student表查询所有学生的学号(id)、姓名(name)和院系(department)的信息

SELECT id,name,department FROM student;

6.从student表中查询计算机系和英语系的学生的信息

SELECT * FROM student WHERE department='计算机系' OR department='英语系';

7.从student表中查询年龄18~22岁的学生信息

SELECT * FROM student WHERE 18 <= 2024-birth <= 22;

8.从student表中查询每个院系有多少人

SELECT department,COUNT(*) '院校人数' FROM student GROUP BY department;

9.从score表中查询每个科目的最高分

SELECT c_name,MAX(grade) FROM score GROUP BY c_name;

10.查询李四的考试科目(c_name)和考试成绩(grade)

SELECT c_name,grade FROM score WHERE stu_id = (SELECT id FROM student WHERE name='李四');

11.用连接的方式查询所有学生的信息和考试信息

SELECT * FROM student s LEFT JOIN score sc ON s.id = sc.stu_id;

12.计算每个学生的总成绩

SELECT name,SUM(grade) FROM student s LEFT OUTER JOIN score sc ON s.id = sc.stu_id GROUP BY name;

13.计算每个考试科目的平均成绩

SELECT c_name,AVG(grade) FROM score GROUP BY c_name;

14.查询计算机成绩低于95的学生信息

SELECT * FROM student s LEFT OUTER JOIN score sc ON s.id = sc.stu_id WHERE grade < 95;

15.查询同时参加计算机和英语考试的学生的信息

SELECT * FROM student s LEFT OUTER JOIN score sc ON s.id = sc.stu_id WHERE c_name='计算机系' AND c_name='英语系';

16.将计算机考试成绩按从高到低进行排序

SELECT c_name,grade FROM score ORDER BY grade desc;

17.从student表和score表中查询出学生的学号,然后合并查询结果

SELECT s.id '学号'  FROM student s INNER JOIN score sc ON s.id = sc.stu_id;

18.查询姓张或者姓王的同学的姓名、院系和考试科目及成绩

SELECT name '姓名',department '院系',c_name '考试科目',grade '成绩' FROM student s INNER JOIN score sc ON s.id = sc.stu_id WHERE name LIKE '张%' OR name LIKE '王%';

19.查询都是湖南的学生的姓名、年龄、院系和考试科目及成绩文章来源地址https://www.toymoban.com/news/detail-822766.html

SELECT name '姓名',birth '年龄',department '院系',c_name '考试科目',grade '成绩' FROM student s INNER JOIN score sc ON s.id = sc.stu_id WHERE address LIKE '湖南%';

到了这里,关于数据库SQL查询相关练习的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据库 SQL高级查询语句:聚合查询,多表查询,连接查询

    创建Students和Courses表 直接查询 设置别名查询 设置条件查询 使用COUNT(*) 和 COUNT(StudentID)是一样的效果,因为StudentID是主键,每行记录的主键都不同。另外我们在聚合查询中还是能使用WHERE子句的,比如我们要 查找年龄大于20岁的学生数量 ,可使用以下SQL语句: 函数 说明 SUM

    2024年02月09日
    浏览(93)
  • 《数据库原理》实验六 SQL数据查询实验

    本系列传送门: 实验二 SQL Server SSMS工具创建和管理数据库及数据表 实验三 SQL Server SSMS工具添加数据 实验四 SQL的数据定义语句 实验五 数据库完整性约束的实现与验证 实验六 SQL数据查询实验 实验六(2) SQL数据查询—连接查询 实验七 SQL的数据更新和视图 实验八 T_SQL编程

    2024年02月03日
    浏览(82)
  • 用MariaDB创建数据库,SQL练习,MarialDB安装和使用

    前言:MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。在存储引擎方面,使用XtraDB来代替MySQL的InnoDB。  Download MariaDB Server - MariaDB.org 注意:安装路径别选C盘 期间

    2024年02月13日
    浏览(27)
  • 【数据库】日常使用PL/SQL 登录ORACLE 数据库查询数据

    一、PL/SQL 登录方式 username: ##访问数据库的账号 password: ##访问数据库的密码 Databse: ##数据库IP地址/实例名 数据库集群心跳地址/实例名 Connect as : ##Normal,如果使用sysdba账户登录选择SYSDBA 二、PL/SQL使用SQL语句查询 点击上方导航栏,New,选择SQL Window,即可再次输入要查询的

    2024年02月19日
    浏览(51)
  • WordPress必备数据库SQL查询语句整理

    最近明月给博客和主站都部署了SSL证书,彻彻底底的加入了HTTPS站点行列。这个期间也用到了SQL查询语句来批量的对内链的HTTP前缀做替换,就感觉掌握一些SQL方面的语句还是非常有必要的,这不在【俄语译客】博客上就发现了几条比较实用的,适合 WordPress 实用的SQL语句。于

    2024年02月01日
    浏览(84)
  • SQL Server数据库 -- 表的高级查询

      一、子查询 嵌套子查询 相关子查询 二、查询运算 并运算union 交运算intersect 差运算except 三、函数的使用 if语句 while语句 case语句 四、总结 高级子查询是对查询更灵活的运用,学会了高级查询将对数据库使用有很大的帮助。       在SQL语言中,一个select-from-where语句称为一

    2024年02月13日
    浏览(33)
  • SQL Server数据库 -- 表的基础查询

    一、单表查询基本结构 二、单表查询结构语法 select 聚合函数 where 模糊查询 order by group by having 三、多表查询基本结构 四、多表查询结构语法 内连接 自连接 外连接 五、总结         学习了数据库,在以后公司等地方,你可能不会用到创建数据库或者表格,但是你一定会使

    2024年02月11日
    浏览(74)
  • SQL数据库的查询操作大全(select)

    1、数据库的连接、创建 2、对字段的操作:(alter table) 3、对数据的操作(插入、修改、删除) 4、数据查询(select) 5、多表查询(join on) 6、约束操作 四、数据库查询大全(select) 1、select 字段名 from 表; 2、In查询:用于 过滤 你所需要查询的内容                

    2023年04月08日
    浏览(60)
  • 数据库系统概述——第三章 关系数据库标准语言SQL(知识点复习+练习题)

    🌟 博主: 命运之光 🦄 专栏: 离散数学考前复习(知识点+题) 🍓 专栏: 概率论期末速成(一套卷) 🐳 专栏: 数字电路考前复习 🦚 专栏: 数据库系统概述 ☀️ 博主的其他文章: 点击进入博主的主页​​​​​ 前言: 身为大学生考前复习一定十分痛苦,你有没有过

    2024年02月10日
    浏览(50)
  • 数据库SQL Server实验报告 之 SQL语言进行简单查询(3/8)

    实验名称          SQL语言进行简单查询 注意:原版word在下载资源里面(免费下载) 实验目的及要求: 掌握各种查询的SQL脚本写法,包括SELECT、FROM、WHERE、GROUP BY、HAVING子句的用法,特别要求比较内连接、外连接的结果 在XSGL数据库中,使用各种查询条件完成指定的查询

    2024年02月02日
    浏览(31)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包