【SQL Server】实验二 基本查询

1 实验目的

(1) 掌握SQL的DDL使用方法。

(2) 掌握SQL的基本查询语句使用方法。

2 实验内容

2.1 掌握SQL的DDL使用方法

(1) 创建名为TPCH的数据库。

(2) 在TPCH数据库中创建表。

2.2 掌握SQL的基本查询语句使用方法

(1) 单表查询

(2) 单表单条件查询

(3) 单表多条件查询

(4) 两表连接查询

(5) 单表自身连接查询

(6) 三表连接查询

(7) 四表连接查询

(8) 五表连接查询

(9) 六表连接查询

(10) 七表连接查询

3 实验要求

(1) 深入复习教材第三章SQL有关数据库定义和基本查询SQL语句,理解关系代数表达式如何使用基本的SQL查询语句实现。

(2) 通过企业管理器添加数据,或者通过其他的数据自动产生工具自动添加数据,以便进行查询。如果是手动添加数据,请以你班同学当做顾客,国家和地区表的数据参照附件3表中的数据录入(全部或部分数据即可),请从网上搜集尽量真实的零件和供应商信息添加到相应的表中,最后根据购物常识添加订单及其明细信息。

(3) 针对TPCH数据库模式设计各种基本查询语句,每种类型的基本查询至少要设计一个查询,描述清楚查询要求,运行你所设计的查询语句,并截图相应的实验结果,每幅截图并要有较为详细的描述。也可以按照附2所列示例查询做实验。

(4) 实验步骤和实验总结中要详细描述实验过程中出现的问题、原因和解决方法。

4 实验步骤

4.1 掌握SQL的DDL使用方法

(1) 创建名为TPCH的数据库。

(2) 在TPCH数据库中创建表。

4.2 掌握SQL的基本查询语句使用方法

(1) 单表查询(实现投影操作)(如下图)

(2) 单表单条件查询(实现选择操作)(如下图)

(3) 单表多条件查询

(4) 两表连接查询(实现笛卡尔积操作)(如下图)

(5) 两表连接查询(实现普通连接操作,任意两个列做大于、小于等连接操作)(如下图)

(6) 两表连接查询(实现等值连接操作)

(7) 两表连接查询(实现自然连接操作)

(8) 单表自身连接查询

(9) 三表连接查询

(10)四表连接查询

查询顾客"苏举库"订购的订单编号、总价及其订购的零件供应价格、数量和实际价格。

(11)五表连接查询

查询顾客"苏举库"订购的订单编号、总价及其订购的零件名称、数量和实际价格。

(12)六表连接查询

查询顾客"苏举库"订购的订单编号、总价及其订购零件的供应商名称、零件名称、数量、实际价格。

(13)七表连接查询

查询中国顾客订购的订单编号、总价及其订购零件的供应商名称、零件名称、数量、实际价格。

(14)八表查询

查询亚洲顾客订购的订单编号、总价及其订购零件的供应商名称、零件名称、数量、实际价格。

5 总结与体会

5.1 实验中出现的问题及其解决方案

1.在连接表时,忘记了在where语句后面添加主码与外码相等的条件,在老师的提醒下成功改正。

5.2 总结

  1. 在书写语句时,要考虑全面,考虑到各种条件,否则容易出错或落下某一条件。

  2. 要熟知各种语句,方便编写

附1:TPC-H数据库模式SQL语句

CREATE TABLE supplier (

suppkey INTEGER,

name CHAR(25),

address VARCHAR(40),

nationkey INTEGERR,

phone CHAR(15),

acctbal REAL,

comment VARCHAR(101)) ;

CREATE TABLE part (

partkey INTEGER,

name VARCHAR(55),

mfgr CHAR(25),

brand CHARE(10),

type VARCHAR(25),

size INTEGER,

container CHAR(10),

retailprice REAL,

comment VARCHAR(23));

CREATE TABLE partsupp (

partkey INTEGER,

suppkey INTEGER,

availqty INTEGER,

supplycost REALe,

comment VARCHAR(199));

CREATE TABLE customer (

custkey INTEGER,

name VARCHAR(25),

address VARCHAR(40),

nationkey INTEGER,

phone CHAR(15),

acctbal REAL,

mktsegment CHAR(10),

comment VARCHAR(117));

CREATE TABLE orders (

orderkey INTEGER,

custkey INTEGER,

orderstatus CHAR(1),

totalprice REAL,

orderDATE DATE,

orderpriority CHAR(15),

clerk CHAR(15),

shippriority INTEGER,

comment VARCHAR(79));

CREATE TABLE lineitem (

orderkey INTEGER,

partkey INTEGER,

suppkey INTEGER,

linenumber INTEGER,

quantity REAL,

extendedprice REAL,

discount REAL,

tax REAL,

returnflag CHAR(1),

linestatus CHAR(1),

shipDATE DATE,

commitDATE DATE,

receiptDATE DATE,

shipinstruct CHAR(25),

shipmode CHAR(10),

comment VARCHAR(44));

CREATE TABLE nation (

nationkey INTEGER,

name CHAR(25),

regionkey INTEGER,

comment VARCHAR(152));

CREATE TABLE region (

regionkey INTEGER,

name CHAR(25),

comment VARCHAR(152));

相关推荐
vvw&2 分钟前
如何在 Ubuntu 22.04 上安装 Graylog 开源日志管理平台
linux·运维·服务器·ubuntu·开源·github·graylog
大哥_ZH6 分钟前
Linux umami在国产麒麟系统安装网站统计工具(只能上国内网站的系统)
linux·服务器
做梦敲代码33 分钟前
达梦数据库-读写分离集群部署
数据库·达梦数据库
不爱学英文的码字机器1 小时前
[Linux] Shell 命令及运行原理
linux·运维·服务器
cdut_suye1 小时前
Linux工具使用指南:从apt管理、gcc编译到makefile构建与gdb调试
java·linux·运维·服务器·c++·人工智能·python
qq_433618441 小时前
shell 编程(三)
linux·运维·服务器
小蜗牛慢慢爬行1 小时前
如何在 Spring Boot 微服务中设置和管理多个数据库
java·数据库·spring boot·后端·微服务·架构·hibernate
hanbarger1 小时前
nosql,Redis,minio,elasticsearch
数据库·redis·nosql
丘狸尾2 小时前
[cisco 模拟器] ftp服务器配置
android·运维·服务器