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

相关推荐
Flynt4 小时前
Room 3.0 包名重构 + KMP 迁移:我把项目升级踩了个遍
android·数据库·kotlin
这个DBA有点耶20 小时前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
这个DBA有点耶1 天前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技1 天前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend1 天前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence1 天前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
你好潘先生1 天前
别再记命令了,用 yeero do 说句人话就能跑脚本,而且不烧 token
服务器·python·命令行
先吃饱再说2 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils2 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend2 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent