0

0

SQL Server数据库操作

php中文网

php中文网

发布时间:2016-06-07 14:49:50

|

1736人浏览过

|

来源于php中文网

原创

通过SQL Server建库语句等,采用纯代码方式创建数据库,创建数据表,以及进行相应数据库操作,包括检索,插入,删除,修改。 以下通过一个例题说明数据库操作。 某仓储超市采用POS(PointofSale)收银机负责前台的销售收款,为及时掌握销售信息,并依此指导

 通过sql server建库语句等,采用纯代码方式创建数据库,创建数据表,以及进行相应数据库操作,包括检索,插入,删除,修改。


以下通过一个例题说明数据库操作。

某仓储超市采用POS(Point of Sale)收银机负责前台的销售收款,为及时掌握销售信息,并依此指导进货,拟建立商品进、销、存数据库信息管理系统。经过系统需求分析、概念结构设计和逻辑结构设计,可以简化得到如下一组关系模式(其中     表示主键,    表示外键):

积分卡(用户编号,用户名,累积消费金额,积分点)

销售详单(销售流水号,商品编码,数量,金额,用户编号,收银员,时间)

销售日汇总(日期,商品编码,数量)

存货表(商品编码,数量)

进货表(送货号码,商品编码,数量,日期)

商品(商品编码,商品名称,单价)

请在SQL Server的查询分析器中按要求完成如下各题:

1、 创建名为Supermarket的数据库,数据文件名取为:Supermarket_data.mdf,日志文件名取为:Supermarket_log.ldf。

 

2、 按表1-6要求创建6张数据表,并为每张表设置主键码和外键码(若有的话)。

表1 Integralcard积分卡信息表

列名

数据类型

可否为空

说明

User_id

char(10)

Not null

用户编号

User_name

varchar(20)

Not null

用户名

Cumulative_consumption

numeric(8,2)

Not null

累计消费金额

Integral_point

numeric(5,0)

Not null

积分点

表2 Salesdetails 销售详单信息表

列名

数据类型

可否为空

说明

sales_id

char(10)

Not null

销售流水号

commodity_code

char(10)

Not null

商品编码

number

Notion AI
Notion AI

Notion是一款集成了笔记、知识库、数据表格、看板、日历等多种能力于一体的应用程序,它既可供个人使用,也可以与他人进行跨平台协作。

下载

numeric(4,0)

null

数量

amount

numeric(9,2)

null

金额

User_id

char(10)

Not null

用户编号

cashier

varchar(20)

null

收银员

sd_time

datetime

null

时间

表3 Salesdatesummary 销售日汇总信息表

列名

数据类型

可否为空

说明

sds_date

datetime

Not null

日期

commodity_code

char(10)

Not null

商品编码

number

numeric(4,0)

null

数量

表4 Inventorylist存货信息表

列名

数据类型

可否为空

说明

commodity_code

char(10)

Not null

商品编码

number

numeric(4,0)

null

数量

表5 Purchasetable进货信息表

列名

数据类型

可否为空

说明

delivery_number

char(10)

Not null

送货号码

commodity_code

char(10)

Not null

商品编码

number

numeric(4,0)

null

数量

pt_date

datetime

Not null

日期

表6 Commodity商品信息表

列名

数据类型

可否为空

说明

commodity_code

char(10)

Not null

商品编码

commodity_name

varchar(10)

Not null

商品名称

commodity_price

numeric(7,2)

Not null

商品单价

 

3、在建好的6张表中,利用对象资源管理器分别输入和更新若干条记录,要求主键码不能为空和重复,外键码只能取另一张表的主键码之一。

 

4、针对该数据库的6张表,完成如下10个查询请求:

1)查询用户编号为’yh23001011’的用户的用户名、累积消费金额和积分点;

 

2)查询’张三’用户所购的全部商品的商品编码、商品名称、单价、数量和金额;

 

(3)查询2016年4月各类商品销售数量的排行榜,要求显示商品编号、商品名称和数量(按降序排列);

 

(4)根据销售详单中的销售流水号’xs80020001’和商品编码’sp03004561’,对存货表中的数量进行更新;

 

5根据进货表中的送货号码’sh00012288’和商品编码’sp03006677’, 对存货表中的数量进行更新;

 

(6)统计2016年4月中每一天的销售金额,要求显示日期、销售金额(按降序排列)。

 

5、针对该数据库的6张表,定义如下2个视图:

(1)定义一个商品存货的视图Commodity_Inventorylist,属性包括商品编码、商品名称、单价和数量;

 

(2)定义一个用户购买商品的详细清单User_Purchase_Details, 属性包括用户编号、用户名、商品编码、商品名称、单价和数量。


SQL Server 2008 R2上实现过程如下:


--创建数据库
--创建名为Supermarket的数据库,数据文件名取为:Supermarket_data.mdf,日志文件名取为:Supermarket_log.ldf。
USE master--使用系统
GO
CREATE DATABASE Supermarket --创建数据库

ON PRIMARY	--主文件
(
	NAME='Supermarket_data', --文件名
	FILENAME='D:\SQLProject\Supermarket_data.mdf',--路径
	SIZE=5MB,--初始大小
	MAXSIZE=100MB,--最大容量
	FILEGROWTH=10%--增长速度
)

LOG ON--日志文件
(
	NAME='Supermarket_log',
	FILENAME='D:\SQLProject\Supermarket_log.ldf',
	SIZE=5MB,
	FILEGROWTH=0
)
GO

--创建你数据库表
--模式(其中     表示主键,    表示外键):
--积分卡(用户编号,用户名,累积消费金额,积分点)
--销售详单(销售流水号,商品编码,数量,金额,用户编号,收银员,时间)
--销售日汇总(日期,商品编码,数量)
--存货表(商品编码,数量)
--进货表(送货号码,商品编码,数量,日期)
--商品(商品编码,商品名称,单价)
use Supermarket
go

--积分卡(用户编号,用户名,累积消费金额,积分点)
create table Integralcard
(
	User_id char(10) primary key not null,
	User_name varchar(20) not null,
	Cumulative_consumption numeric(8,2) not null,
	Integral_point numeric(5,0) not null
)
go

--销售详单(销售流水号,商品编码,数量,金额,用户编号,收银员,时间)
use Supermarket
go

create table Salesdetails
(
	sales_id char(10) not null,
	commodity_code char(10) not null foreign key(commodity_code) references Commodity(commodity_code)
	on delete cascade,
	number numeric(4,0) null,
	amount numeric(9,2) null,
	User_id char(10) not null foreign key(User_id) references Integralcard(User_id)
	on delete cascade,
	cashier varchar(20) null,
	sd_time datetime null
)
go
--外键
ALTER TABLE Salesdetails
ADD CONSTRAINT Salesdetails_KEY PRIMARY KEY(sales_id,commodity_code,User_id)
Go
--销售日汇总(日期,商品编码,数量)
use Supermarket
go

create table Salesdatesummary
(
	sds_date datetime not null,
	commodity_code char(10) not null  foreign key(commodity_code) references Commodity(commodity_code)
	on delete cascade,
	number numeric(4,0) null
)
go

ALTER TABLE Salesdatesummary
ADD CONSTRAINT Salesdatesummary_KEY PRIMARY KEY(commodity_code)
Go
--存货表(商品编码,数量)
use Supermarket
go

create table Inventorylist
(
	commodity_code char(10) not null foreign key(commodity_code) references Commodity(commodity_code)
	on delete cascade,
	number numeric(4,0) null
)
go
ALTER TABLE Inventorylist
ADD CONSTRAINT Inventorylist_KEY PRIMARY KEY(commodity_code)
Go

--进货表(送货号码,商品编码,数量,日期)
use Supermarket
go

create table Purchasetable
(
	delivery_number char(10) not null,
	commodity_code char(10) not null foreign key(commodity_code) references Commodity(commodity_code)
	on delete cascade,
	number numeric(4,0) null,
	pt_date datetime not null
)
go
--外键
ALTER TABLE Purchasetable
ADD CONSTRAINT Purchasetable_KEY PRIMARY KEY(delivery_number,commodity_code)
Go


--商品(商品编码,商品名称,单价)
use Supermarket
go

create table Commodity
(
	commodity_code char(10) primary key not null,
	commodity_name varchar(10) not null,
	commodity_price numeric(7,2) not null
)
go

-----------------------------------------------
--查询用户编号为’yh23001011’的用户的用户名、累积消费金额和积分点
use Supermarket
select User_name as 姓名,Cumulative_consumption as 累计消费金额,Integral_point as 积分点 from Integralcard
where User_id='yh23001011'
go


--查询’张三’用户所购的全部商品的商品编码、商品名称、单价、数量和金额;
use Supermarket
select com.commodity_code,com.commodity_name,com.commodity_price,sal.number,sal.amount
 from Commodity com,Salesdetails sal,Integralcard ca
where com.commodity_code=sal.commodity_code and sal.User_id=ca.User_id and ca.User_name='张三'
go

--查询2016年4月各类商品销售数量的排行榜,要求显示商品编号、商品名称和数量(按降序排列)
use Supermarket
select com.commodity_code,com.commodity_name,sal.number,sal.sd_time
from Commodity com,Salesdetails sal
where com.commodity_code=sal.commodity_code and sal.sd_time between '2016-04-01' and '2016-04-30' 
order by sal.number desc
go


--查看结果
use Supermarket
select number from Inventorylist
where Inventorylist.commodity_code='sp03004561'
go
--根据销售详单中的销售流水号’xs80020001’和商品编码’sp03004561’,对存货表中的数量进行更新
use Supermarket
update Inventorylist
set number= number - (select sal.number from Salesdetails sal
where sal.sales_id='xs80020001' and sal.commodity_code='sp03004561')
go
--查看更新结果
use Supermarket
select number from Inventorylist
where Inventorylist.commodity_code='sp03004561'
go


--查看结果
use Supermarket
select number from Inventorylist
where Inventorylist.commodity_code='sp03006677'
go
--根据进货表中的送货号码’sh00012288’和商品编码’sp03006677’, 对存货表中的数量进行更新
use Supermarket
update Inventorylist
set Inventorylist.number=Inventorylist.number +(select pur.number from Purchasetable pur
where pur.delivery_number='sh00012288' and pur.commodity_code='sp03006677')
go
--查看更新结果
use Supermarket
select number from Inventorylist
where commodity_code='sp03006677'
go

--统计2016年4月中每一天的销售金额,要求显示日期、销售金额(按降序排列)
use Supermarket
select sal.sds_date,salemoney=com.commodity_price*sal.number
from Commodity com,Salesdatesummary sal
where com.commodity_code=sal.commodity_code and sal.sds_date>='2016-04-01' and sal.sds_date<='2016-04-30'
go

--5
--定义一个商品存货的视图Commodity_Inventorylist,属性包括商品编码、商品名称、单价和数量
use Supermarket
go

create view Commodity_Inventorylist(commodity_code,commodity_name,commodity_price,number)
as select com.commodity_code,com.commodity_name,com.commodity_price,inve.number
 from Commodity com,Inventorylist inve
where com.commodity_code=inve.commodity_code
go

--定义一个用户购买商品的详细清单User_Purchase_Details, 属性包括用户编号、用户名、商品编码、商品名称、单价和数量
use Supermarket
go

create view User_Purchase_Details(User_id,User_name,commodity_code,commodity_name,commodity_price,number)
as select inte.User_id,inte.User_name,com.commodity_code,com.commodity_name,com.commodity_price,sal.number
from Integralcard inte,Salesdetails sal,Commodity com
where inte.User_id=sal.User_id and sal.commodity_code=com.commodity_code
go


数据库实现截图:




相关专题

更多
Word 字间距调整方法汇总
Word 字间距调整方法汇总

本专题整合了Word字间距调整方法,阅读下面的文章了解更详细操作。

2

2025.12.24

任务管理器教程
任务管理器教程

本专题整合了任务管理器相关教程,阅读下面的文章了解更多详细操作。

2

2025.12.24

AppleID格式
AppleID格式

本专题整合了AppleID相关内容,阅读专题下面的文章了解更多详细教程。

0

2025.12.24

csgo视频观看入口合集
csgo视频观看入口合集

本专题整合了csgo观看入口合集,阅读下面的文章了知道更多入口地址。

29

2025.12.24

yandex外贸入口合集
yandex外贸入口合集

本专题汇总了yandex外贸入口地址,阅读下面的文章了解更多内容。

58

2025.12.24

添加脚注通用方法
添加脚注通用方法

本专题整合了添加脚注方法合集,阅读专题下面的文章了解更多内容。

1

2025.12.24

重启电脑教程汇总
重启电脑教程汇总

本专题整合了重启电脑操作教程,阅读下面的文章了解更多详细教程。

3

2025.12.24

纸张尺寸汇总
纸张尺寸汇总

本专题整合了纸张尺寸相关内容,阅读专题下面的文章了解更多内容。

5

2025.12.24

Java Spring Boot 微服务实战
Java Spring Boot 微服务实战

本专题深入讲解 Java Spring Boot 在微服务架构中的应用,内容涵盖服务注册与发现、REST API开发、配置中心、负载均衡、熔断与限流、日志与监控。通过实际项目案例(如电商订单系统),帮助开发者掌握 从单体应用迁移到高可用微服务系统的完整流程与实战能力。

1

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3万人学习

SQL优化与排查(MySQL版)
SQL优化与排查(MySQL版)

共26课时 | 2.2万人学习

MySQL索引优化解决方案
MySQL索引优化解决方案

共23课时 | 2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号