【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));

相关推荐
李元豪39 分钟前
grpo nl2sql qwen3 模型强化学习训练有效果的成立条件有哪些
数据库·oracle
Hello.Reader4 小时前
RedisJSON 路径语法深度解析与实战
数据库·redis·缓存
TDengine (老段)4 小时前
TDengine 使用最佳实践(2)
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
Two_brushes.5 小时前
【Linux】线程机制深度实践:创建、等待、互斥与同步
linux·运维·服务器·多线程
设计师小聂!7 小时前
Linux系统中部署Redis详解
linux·运维·数据库·redis
kfepiza7 小时前
Debian-10编译安装Mysql-5.7.44 笔记250706
linux·数据库·笔记·mysql·debian·bash
Touper.7 小时前
Redis 基础详细介绍(Redis简单介绍,命令行客户端,Redis 命令,Java客户端)
java·数据库·redis
不剪发的Tony老师7 小时前
phpMyAdmin:一款经典的MySQL在线管理工具又回来了
数据库·mysql·phpmyadmin
极限实验室7 小时前
TDBC 2025 可信数据库发展大会,极限科技邀您来赴约!
数据库
lixia0417mul29 小时前
使用Starrocks替换Clickhouse的理由
数据库