SQL Server笔记 -- 第78章:MS SQL Server 基本 DDL 操作

节78.1:入门

本节介绍一些基本的 DDL(数据定义语言)命令,用于创建数据库、数据库内的表、视图以及存储过程。

创建数据库

以下 SQL 命令在当前服务器上新建名为 Northwind 的数据库,路径为 C:\Program Files\Microsoft SQL Server\...

sql 复制代码
USE [master]
GO
CREATE DATABASE [Northwind]
CONTAINMENT = NONE
ON PRIMARY
(
    NAME = N'Northwind',
    FILENAME = N'C:\Program Files\Microsoft SQL Server\MSSQL11.INSTSQL2012\MSSQL\DATA\Northwind.mdf',
    SIZE = 5120KB,
    MAXSIZE = UNLIMITED,
    FILEGROWTH = 1024KB
)
LOG ON
(
    NAME = N'Northwind_log',
    FILENAME = N'C:\Program Files\Microsoft SQL Server\MSSQL11.INSTSQL2012\MSSQL\DATA\Northwind_log.ldf',
    SIZE = 1536KB,
    MAXSIZE = 2048GB,
    FILEGROWTH = 10%
)
GO
ALTER DATABASE [Northwind] SET COMPATIBILITY_LEVEL = 110
GO

注意:T-SQL 数据库由两个文件组成,数据库文件 *.mdf 及其事务日志 *.ldf。新建数据库时必须同时指定两者。

创建表

以下 SQL 命令在当前数据库中新建名为 Categories 的表,使用架构 dbo(可用 USE <DatabaseName> 切换数据库上下文):

sql 复制代码
CREATE TABLE dbo.Categories(
    CategoryID int IDENTITY NOT NULL,
    CategoryName nvarchar(15) NOT NULL,
    Description ntext NULL,
    Picture image NULL,
    CONSTRAINT PK_Categories PRIMARY KEY CLUSTERED (
        CategoryID ASC
    )
    WITH (
        PAD_INDEX = OFF,
        STATISTICS_NORECOMPUTE = OFF,
        IGNORE_DUP_KEY = OFF,
        ALLOW_ROW_LOCKS = ON,
        ALLOW_PAGE_LOCKS = ON
    ) ON PRIMARY
) ON PRIMARY TEXTIMAGE_ON PRIMARY

创建视图

以下 SQL 命令在当前数据库中新建名为 Summary_of_Sales_by_Year 的视图,使用架构 dbo

sql 复制代码
CREATE VIEW dbo.Summary_of_Sales_by_Year AS
SELECT 
    ord.ShippedDate,
    ord.OrderID,
    ordSub.Subtotal
FROM Orders ord
INNER JOIN [Order Subtotals] ordSub
    ON ord.OrderID = ordSub.OrderID

该视图将 Orders 表与 [Order Subtotals] 表联接,展示 ShippedDate、OrderID 和 Subtotal 三列。由于 Northwind 数据库中表名 [Order Subtotals] 包含空格,需用方括号括起。

创建存储过程

以下 SQL 命令在当前数据库中新建名为 MyCustOrdersDetail 的存储过程,使用架构 dbo

sql 复制代码
CREATE PROCEDURE dbo.MyCustOrdersDetail
    @OrderID int,
    @MinQuantity int = 0
AS
BEGIN
    SELECT 
        ProductName,
        UnitPrice = ROUND(Od.UnitPrice, 2),
        Quantity,
        Discount = CONVERT(int, Discount * 100),
        ExtendedPrice = ROUND(
            CONVERT(money, Quantity * (1 - Discount) * Od.UnitPrice),
            2
        )
    FROM Products P, [Order Details] Od
    WHERE 
        Od.ProductID = P.ProductID
        AND Od.OrderID = @OrderID
        AND Od.Quantity >= @MinQuantity
END

创建完成后,可如下调用该存储过程:

sql 复制代码
EXEC dbo.MyCustOrdersDetail 10248

上述语句返回所有 OrderID = 10248 且数量大于等于 0(默认)的订单明细。也可指定可选参数:

sql 复制代码
EXEC dbo.MyCustOrdersDetail 10248, 10

此时仅返回数量至少为 10 的订单行。

相关推荐
Albert Edison7 小时前
【Python】学生管理系统
开发语言·数据库·python
AomanHao8 小时前
【阅读笔记】沙尘图像线性颜色校正A fusion-based enhancing approach for single sandstorm image
图像处理·笔记·isp·图像增强·沙尘图像·色偏·颜色校正
产品经理邹继强10 小时前
需求优先级之争可以休矣
microsoft·产品经理
枷锁—sha11 小时前
【pwn系列】Pwndbg 汇编调试实操教程
网络·汇编·笔记·安全·网络安全
heimeiyingwang11 小时前
企业供应链 AI 优化:需求预测与智能调度
大数据·数据库·人工智能·机器学习
山岚的运维笔记12 小时前
SQL Server笔记 -- 第73章:排序/对行进行排序
数据库·笔记·后端·sql·microsoft·sqlserver
XLYcmy12 小时前
智能体大赛 目录
数据库·ai·llm·prompt·agent·检索·万方
盟接之桥12 小时前
盟接之桥EDI软件:API数据采集模块深度解析,打造企业数据协同新引擎
java·运维·服务器·网络·数据库·人工智能·制造
QQ243919713 小时前
语言在线考试与学习交流网页平台信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·spring boot·sql·学习·java-ee