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

简介: 数据库原理与应用(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)笔记用户自定义数据类型与变量的全部内容,感谢您的阅读和支持,篇幅较长,若有表述以及代码中的不当之处,望指出!您的指出和建议能给作者带来很大的动力!!!


相关文章
【YashanDB知识库】like 变量的SQL语句应用程序执行效率低与yasql执行效率高
【YashanDB知识库】like 变量的SQL语句应用程序执行效率低与yasql执行效率高
|
缓存 NoSQL Redis
Redis原理—2.单机数据库的实现
本文概述了Redis数据库的核心结构和操作机制。
Redis原理—2.单机数据库的实现
|
缓存 算法 关系型数据库
Mysql(3)—数据库相关概念及工作原理
数据库是一个以某种有组织的方式存储的数据集合。它通常包括一个或多个不同的主题领域或用途的数据表。
1180 5
Mysql(3)—数据库相关概念及工作原理
|
存储 缓存 网络安全
南大通用GBase 8s 数据库 RHAC集群基本原理和搭建步骤
南大通用GBase 8s 数据库 RHAC集群基本原理和搭建步骤
|
存储 Java 关系型数据库
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践,包括连接创建、分配、复用和释放等操作,并通过电商应用实例展示了如何选择合适的连接池库(如HikariCP)和配置参数,实现高效、稳定的数据库连接管理。
358 2
|
SQL 关系型数据库 数据库
SQL数据库:核心原理与应用实践
随着信息技术的飞速发展,数据库管理系统已成为各类组织和企业中不可或缺的核心组件。在众多数据库管理系统中,SQL(结构化查询语言)数据库以其强大的数据管理能力和灵活性,广泛应用于各类业务场景。本文将深入探讨SQL数据库的基本原理、核心特性以及实际应用。一、SQL数据库概述SQL数据库是一种关系型数据库
577 6
|
关系型数据库 MySQL 数据库
MySQL数据库基础(数据库操作,常用数据类型,表的操作)
MySQL数据库基础(数据库操作,常用数据类型,表的操作)
265 5
|
SQL 数据处理 数据库
SQL Server 数据类型转换详解
SQL Server 数据类型转换详解
1343 2
|
SQL 关系型数据库 MySQL
sql注入原理与实战(三)数据库操作
sql注入原理与实战(三)数据库操作
sql注入原理与实战(三)数据库操作
|
SQL 存储 Java
sql注入原理与实战(二)数据库原理
sql注入原理与实战(二)数据库原理