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

相关推荐
小乌龟不会飞17 分钟前
Ubuntu 安装 etcd 与 etcd-cpp-apiv3
数据库·etcd
南瓜胖胖24 分钟前
【seismic unix相速度分析-频散曲线】
服务器·unix
热爱生活的猴子3 小时前
阿里云服务器正确配置 Docker 国内镜像的方法
服务器·阿里云·docker
计算机毕设定制辅导-无忧学长8 小时前
西门子 PLC 与 Modbus 集成:S7-1500 RTU/TCP 配置指南(一)
服务器·数据库·tcp/ip
程序员柳8 小时前
基于微信小程序的校园二手交易平台、微信小程序校园二手商城源代码+数据库+使用说明,layui+微信小程序+Spring Boot
数据库·微信小程序·layui
梦在深巷、9 小时前
MySQL/MariaDB数据库主从复制之基于二进制日志的方式
linux·数据库·mysql·mariadb
IT乌鸦坐飞机9 小时前
ansible部署数据库服务随机启动并创建用户和设置用户有完全权限
数据库·ansible·centos7
IT_10249 小时前
Spring Boot项目开发实战销售管理系统——数据库设计!
java·开发语言·数据库·spring boot·后端·oracle
祁思妙想10 小时前
八股学习(三)---MySQL
数据库·学习·mysql
惊骇世俗王某人10 小时前
1.MySQL之如何定位慢查询
数据库·mysql