首页 数据库 mysql教程 SQL Server数据库操作

SQL Server数据库操作

Jun 07, 2016 pm 02:49 PM
server sql 操作 数据库 通过

通过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

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
<p><span style="font-size:18px"><br>
</span></p>
<p><span style="font-size:18px"><span style="color:#ff6600">数据库实现截图:</span></span></p>
<br>
<img src="/static/imghw/default1.png" data-src="http://img.blog.csdn.net/20160519185100347?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" class="lazy" alt=""><br>
<p><span style="font-size:18px"><br>
</span></p>
   








登录后复制
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 Jul 18, 2024 am 05:48 AM

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

在PHP中使用MySQLi建立数据库连接的详尽教程 在PHP中使用MySQLi建立数据库连接的详尽教程 Jun 04, 2024 pm 01:42 PM

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

如何在PHP中处理数据库连接错误 如何在PHP中处理数据库连接错误 Jun 05, 2024 pm 02:16 PM

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

Astar质押原理、收益拆解、空投项目及策略 & 操作保姆级攻略 Astar质押原理、收益拆解、空投项目及策略 & 操作保姆级攻略 Jun 25, 2024 pm 07:09 PM

目录Astar Dapp 质押原理质押收益 拆解潜在空投项目:AlgemNeurolancheHealthreeAstar Degens DAOVeryLongSwap 质押策略 & 操作“AstarDapp质押”今年初已升级至V3版本,对质押收益规则做了不少调整。目前首个质押周期已结束,第二质押周期的“投票”子周期刚开始。要获取“额外奖励”收益,需把握此关键阶段(预计持续至6月26日,现余不到5天)。我将细致拆解Astar质押收益,

如何在 Golang 中使用数据库回调函数? 如何在 Golang 中使用数据库回调函数? Jun 03, 2024 pm 02:20 PM

在Golang中使用数据库回调函数可以实现:在指定数据库操作完成后执行自定义代码。通过单独的函数添加自定义行为,无需编写额外代码。回调函数可用于插入、更新、删除和查询操作。必须使用sql.Exec、sql.QueryRow或sql.Query函数才能使用回调函数。

如何用 Golang 连接远程数据库? 如何用 Golang 连接远程数据库? Jun 01, 2024 pm 08:31 PM

通过Go标准库database/sql包,可以连接到MySQL、PostgreSQL或SQLite等远程数据库:创建包含数据库连接信息的连接字符串。使用sql.Open()函数打开数据库连接。执行SQL查询和插入操作等数据库操作。使用defer关闭数据库连接以释放资源。

如何使用C++处理数据库连接和操作? 如何使用C++处理数据库连接和操作? Jun 01, 2024 pm 07:24 PM

在C++中使用DataAccessObjects(DAO)库连接和操作数据库,包括建立数据库连接、执行SQL查询、插入新记录和更新现有记录。具体步骤为:1.包含必要的库语句;2.打开数据库文件;3.创建Recordset对象执行SQL查询或操作数据;4.遍历结果或按照具体需求更新记录。

如何在 Golang 中将 JSON 数据保存到数据库中? 如何在 Golang 中将 JSON 数据保存到数据库中? Jun 06, 2024 am 11:24 AM

可以通过使用gjson库或json.Unmarshal函数将JSON数据保存到MySQL数据库中。gjson库提供了方便的方法来解析JSON字段,而json.Unmarshal函数需要一个目标类型指针来解组JSON数据。这两种方法都需要准备SQL语句和执行插入操作来将数据持久化到数据库中。

See all articles