数据库原理与应用(SQL Server)笔记 第八章 用户自定义数据类型与变量

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: 数据库原理与应用(SQL Server)笔记 第八章 用户自定义数据类型与变量

前言


以下皆使用T-SQL语句的方式来执行语句,使用图形界面方式不再累赘。


一、用户定义数据类型


(一) CREATE TYPE 语句


1、CREATE TYPE语句

下面介绍使用T-SQL语句,创建用户自定义数据类型,即使用CREATE TYPE 语句:

CREATE TYPE <自定义数据类型名称>

FROM <所依据的系统数据类型> NULL/NOT NULL


2、DROP TYPE 语句

删除用户自定义数据类型,使用DROP TYPE 语句删除:

DROP TYPE <自定义数据类型名称>


例:在数据库YGGZ中,使用CREATE TYPE 命令创建用户自定义数据类型School_classNO,定义为char类型,且不能为空。


语句如下:

CREATE TYPE School_classNO
FROM char(6) NOT NULL

运行如下:

1666890808210.jpg

3、自定义数据类型定义列


若要自定义数据类型定义列时,可以定义一列,即在定义侯跟多个要定义的自定义数据类型,例使用用户自定义数据类型class_classID定义class表的classID列。这里创建class表与之前不同的是,在定义classID列时应用了用户自定义数据类型class_classID。

USE YGGZ
CREATE TABLE class
    calssID  class_classID NULL PRIMARY KEY,
    Classname char(6) NOT NULL,
    Sex char(2) NOT NULL
GO

(二)用户自定义表数据类型


用户自定义表数据类型,可以作为参数提供给语句、函数、存储过程。


CREATE TYPE <自定义表数据类型名称>
    AS TABLE <列的描述> (表的约束)


二、变量


变量分为全局变量和局部变量。


(一)全局变量


全局变量是由系统定义,,而不是用户定义的,在其名称前面加“@@”,用于提供当前的系统信息。


其可以作为函数引用,SELECT @@+语句,即可调用,例SELECT @@ERROR即表示最后执行的sql语句的错误代码(0表示没错误)。

1666890850567.jpg

(二)局部变量


局部变量是由用户自己定义和使用的,在其局部变量前面加有“@”,要注意局部变量只是在声明它的批处理里或者过程中才有效,当执行结束后,即无效。


1、DECLARE语句

使用DECLARE语句定义局部变量,所有的局部变量声明后均初始化为NULL,格式如下:

DECLARE @局部变量名称 <局部变量的数据类型>(=value)            /*value为变量赋值*/

2、SET语句和SELECT语句

我们可以使用SET语句或者SELECT语句对定义的局部变量赋值,


(1)SET语句

DECLARE @<局部变量名称>

SET @<局部变量名称> = <表达式>

在为局部变量赋值前,局部变量必须要首先已DECLARE 语句定义过。


例1:创建两个个局部变量,前两个变量赋值后,并输出变量值(student_NO、student_Name)。


语句如下:

DECLARE @student_NO char(6),@student_Name char(6)
SET @student_NO='001'
SET @student_Name='曾成'
SELECT @student_NO+@student_Name


运行如下:

1666890903972.jpg

例2:使用一个局部变量(class_number)来查找该学校School数据库classes表中班级编号为A103的班级的班主任和人数信息。

USE School
DECLARE @class_number char(5)
SET @class_number='A103'
    SELECT teacher_headteacher,number_class
    FROM classes
    WHERE class_number=@class_number

(2)SELECT语句

SELECT <@数据类型名称=表达式>

例:在数据量School中classes表使用SELECT语句将姓名为“成小”的学生输出。

USE School
DECLARE @name char(3)
SELECT @name=classes_name
FROM classes
WHERE classes_name='成小'
PRINT @name


结语


以上就是本次数据库原理与应用(SQL Server)笔记用户自定义数据类型与变量的全部内容,感谢您的阅读和支持,篇幅较长,若有表述以及代码中的不当之处,望指出!您的指出和建议能给作者带来很大的动力!!!


相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
4天前
|
SQL 存储 关系型数据库
数据库SQL入门指南
数据库SQL入门指南
|
1天前
|
SQL 关系型数据库 MySQL
解决:Mybatis-plus向数据库插入数据的时候 报You have an error in your SQL syntax
该博客文章讨论了在使用Mybatis-Plus向数据库插入数据时遇到的一个常见问题:SQL语法错误。作者发现错误是由于数据库字段中使用了MySQL的关键字,导致SQL语句执行失败。解决方法是将这些关键字替换为其他字段名称,以避免语法错误。文章通过截图展示了具体的操作步骤。
|
1天前
|
SQL 关系型数据库 MySQL
SQL数据库和 SQLserver数据库
【8月更文挑战第19天】SQL数据库和 SQLserver数据库
7 2
|
1天前
|
SQL 存储 安全
SQL Server数据库创建
【8月更文挑战第19天】SQL Server数据库创建
4 1
|
4天前
|
SQL 关系型数据库 数据库
数据库空间之谜:彻底解决RDS for SQL Server的空间难题
【8月更文挑战第16天】在管理阿里云RDS for SQL Server时,合理排查与解决空间问题是确保数据库性能稳定的关键。常见问题包括数据文件增长、日志文件膨胀及索引碎片累积。利用SQL Server的动态管理视图(DMV)可有效监测文件使用情况、日志空间及索引碎片化程度。例如,使用`sp_spaceused`检查文件使用量,`sys.dm_db_log_space_usage`监控日志空间,`sys.dm_db_index_physical_stats`识别索引碎片。同时,合理的备份策略和文件组设置也有助于优化空间使用,确保数据库高效运行。
11 2
|
6天前
|
存储 关系型数据库 MySQL
MySQL——数据库备份上传到阿里云OSS存储
MySQL——数据库备份上传到阿里云OSS存储
23 0
|
1天前
|
SQL 存储 关系型数据库
数据库-MySQL-01(一)
数据库-MySQL-01(一)
13 4
|
6天前
|
缓存 NoSQL Redis
一天五道Java面试题----第九天(简述MySQL中索引类型对数据库的性能的影响--------->缓存雪崩、缓存穿透、缓存击穿)
这篇文章是关于Java面试中可能会遇到的五个问题,包括MySQL索引类型及其对数据库性能的影响、Redis的RDB和AOF持久化机制、Redis的过期键删除策略、Redis的单线程模型为何高效,以及缓存雪崩、缓存穿透和缓存击穿的概念及其解决方案。
|
1天前
|
SQL 存储 关系型数据库
数据库-MySQL-03
数据库-MySQL-03
7 0
|
1天前
|
SQL 数据库
数据库-MySQL-02(二)
数据库-MySQL-02(二)
4 0