当前位置: 首页 > news >正文

数据库复习笔记

写在最前,

写文章的初衷只是为了复习与记录自己的成长,笔者目前水平还有待提高,文章中难免会出现许多问题与错误,文章内容仅供参考,有不足的地方还请大家多多包涵并指正,谢谢~

第八章 T-SQL程序结构 

8.1  注释和变量

8.1.1  T-SQL程序的基本结构 

1.批

批是一组SQL语句的集合,一个批以结束符GO而终结。批中的所有语句被一次提交给SQL Server,SQL Server将这些语句编译为一个执行单元在执行时全部执行。
注意:在执行批时:
(1)只要有其中任一个SQL语句存在语法错误,SQL Server将取消整个批内所有语句执行。
(2)如果没有语法问题可以运行,但发生逻辑错误(如算术溢出),则可能导致停止批中当前语句及后面语句执行,或仅停止当前语句执行,后面继续。这样可能发生严重错误,所以批应位于一个事务之内。

使用批的基本规则

(1)所有CREATE语句应单独构成一个批,不能在批中和其它SQL语句组合使用。
(2)使用ALTER TABLE语句修改表结构后,不能在同一个批中使用新定义的列
(3)EXCUTE语句为批中第一个语句时,可以省略EXCUTE关键字,否则,必须使用EXCUTE关键字。
(4)批命令GO和SQL语句不能在同一行上。但在GO命令中可以包含注释。
批命令GO并不是SQL的语句组成部分它仅是作为批结束的标志。当编译器读到GO时,会把它前面的所有语句打成一个数据包一起发给服务器。 

--正确批处理的例子:
USE  教学管理
GO
CREATE  VIEW  sub_学生表 
AS SELECT  学号,姓名FROM  学生表
GO
SELECT  *  FROM  sub_学生表
GO
--不正确批处理的例子1:
USE  教学管理
CREATE  VIEW  sub_学生表 
AS SELECT  学号,姓名FROM  学生表
GO
SELECT  *  FROM  sub_学生表
GO
错误的原因在于将选择数据库与创建视图放在了同一个批中,前面说过CREATE必须单独在一个批中。  
--不正确批处理的例子2:
USE  教学管理
GO
CREATE  TABLE mytab (name  nvarchar(20),pric  tinyint)
GO  
INSERT  INTO  mytab (name,pric) VALUES (‘Binete’, 3)
INSERT  INTO  mytab (name,pric) VALUES (‘Binete’, 3000)   --3000超过tinyint类型
GO--第2个插入语句插入时出错,只产生部分数据(容易成为垃圾数据)。为了避免这种情况发生需要用事务保证批中的命令要么全做,要么全不做。 

2.程序结构  
一个T-SQL程序包含若干个以BEGIN TRANSACTION开始、以COMMIT(提交)或ROLLBACK(回滚)结束的事务,一个事务又包含若干个以GO结束的批处理,一个批处理包含若干条T-SQL语句。因此T-SQL程序的基本结构为:

{             
     BEGIN TRANSACTION
           {  T-SQL语句[ …n]
     GO
            }[ …n]
     { COMMIT | ROLLBACK }
}[ …n]

--例:下列T-SQL程序含两个事务,每个事务又含两个批处理。
USE  教学管理
GO
BEGIN TRANSACTIONDELETE FROM 选课表 WHERE 学号=’S060101’DELETE FROM 学生表 WHERE 学号=’S060101’GOSELECT * FROM 选课表 WHERE 学号=’S060101’SELECT * FROM 学生表 WHERE 学号=’S060101’GO
ROLLBACK
BEGIN TRANSACTIONINSERT INTO 学生表(学号,身份证号,姓名,专业,所在院系) VALUES
('S060199','****19880115***','张三','计算机','信息学院')INSERT INTO 选课表(学号,课程号) VALUES(’S060199’, ’010101’)GOSELECT * FROM 选课表 WHERE 学号=’S060199’SELECT * FROM 学生表 WHERE 学号=’S060199’GO
COMMIT

8.1.2  注释 

注释是程序代码中不执行的文本,用于对代码进行说明暂时禁用正在进行调试的部分T-SQL 语句和批处理。
SQL Server支持两种类型的注释: 

1.双减号(--)
从双减号(--)开始到行尾均为注释,是单行注释
2.斜杠-星号对(/*…*/)
从“/*”开始到“*/”结束的内容均视为注释,常用来给出多行注释

注意: 斜杠-星号对注释不能跨越批。例如,以下程序是错误的。

USE  教学管理
GO
SELECT * FROM 课程表
/* The
GO in this comment causes it to be broken in half */
SELECT * FROM products
GO
--下面是一个有效注释的例子。
USE  教学管理
GO
-- First line of a multiple-line comment.
-- Second line of a multiple-line comment.
SELECT * FROM  课程表
GO
/* First line of a multiple-line comment.Second line of a multipl-line comment. */
SELECT * FROM  教师表
GO
SELECT  学号, /* 身份证号, */ 姓名
FROM  学生表
GO

8.1.3  变量

 T-SQL使用两种变量,即全局变量局部变量
全局变量是SQL Server 系统内部使用的变量,其作用范围并不局限于某一程序,而是任何程序均可随时调用
局部变量用户自定义的变量,它仅在定义它的批处理内有效,常用来暂存从表中查询到的数据,或作为流程控制变量。SQL Server规定,局部变量必须以@开头,而且必须先用DECLARE命令定义后才可使用。

DECLARE命令的格式:

DECLARE  {@变量名 变量类型}[, …n]

其中变量类型可以是SQL Server支持的所有数据类型,也可以是用户自定义的数据类型。

--以下例子定义了两个局部变量。  
DECLARE  @V1 INT,  @V2 CHAR(100)

8.1.4 变量赋值 

T-SQL使用SELECTSET命令为变量赋值,其语法如下:

SELECT {@变量名=<表达式>}[, …n]
SET @变量名=<表达式>

注意:一条SET语句只能为一个变量赋值,而一条SELECT可以为多个变量赋值。 

--例:用SET和SELECT语句为变量赋值。 
DECLARE @V1 INT, @V2 CHAR(100), @V3 INT, @V4 CHAR(100)
SET @V1=100*100 
SET @V2='ABC'+'DEF'
SELECT @V3=2*@V1, @V4=@V2+'HIJ'
PRINT @V1+@V3
PRINT @V2+@V4
GO

8.2  运算符和表达式

运算符是一种符号,用来指定要在一个或多个表达式中执行的操作。
T-SQL的运算符包括:

1)算术运算符;2)位运算符;3)连接运算符;4)比较运算符;5)逻辑运算符。

表达式是用运算符括号将多个常量、局部变量、列、函数连接起来而得的符合T-SQL语法规则的式子。

T-SQL的表达式有:

1)数值型表达式;

2)字符串表达式;

3)条件表达式;

8.2.1  算术运算符

算术运算符用来对一个或两个数值型数据实施操作,进行其间的算术运算并返回数值型运算结果。

算术运算符包括:

+ (加)        -(减、求负数)    * (乘)       /(除)       %(求余)

8.2.2  位运算符

位运算符用来对一个或两个整型数据实施操作,进行其间的按位运算并返回整型运算结果。

位运算符包括:

&(按位与)        |(按位或)       ~(按位取反)      ^(按位异或)

8.2.3  连接运算符

连接运算符用来将两个字符串操作数进行首尾相接,形成一个更长的字符串作为运算结果返回。

T-SQL的连接运算符是“+

8.2.4  比较运算符

比较运算符用来对一个、两个或3个(同类)数据实施操作,进行其间的比较运算并返回逻辑值“真”或“假”。分为普通的和特殊的两类。 
普通比较运算符用来对两个同类数据实施比较,包括:

>(大于)         <(小于)        =(等于)        >=(大于等于)        <=(小于等于)        <>(不等于)        !=(不等于)        !>(不大于)        !<(不小于)

特殊比较运算符实际上是普通比较运算符的推广或缩写形式,包括:

[NOT] BETWEEN AND                              (确定范围,三元运算)

[NOT] IN                                                     (确定集合,二元运算)

[NOT] LIKE                                                 (字符串匹配,二元运算)

IS [NOT] NULL                                            (空值判断,一元运算)

<普通比较运算符>+{ALL|ANY}                   (二元运算)

EXISTS                                                        (一元运算)

特殊比较运算符的用法请参阅第5章的文章内容 

8.2.5 逻辑运算符

逻辑运算符用来对一个或两个逻辑型数据实施操作,进行其间的逻辑运算并返回逻辑值“真”或“假”。

逻辑运算符包括:

AND(与)        OR(或)        NOT(非)

8.2.6  表达式

T-SQL的表达式可分为数值型表达式字符串表达式条件表达式
数值型表达式是用算术运算符位运算符括号将多个数值型常量数值型局部变量数值型列数值型函数连接起来而得的符合T-SQL语法规则的式子。数值型表达式的返回值是数值型数据。
字符串表达式是用连接运算符括号将多个字符型常量字符型局部变量字符型列字符型函数连接起来而得的符合T-SQL语法规则的式子。字符串表达式的返回值是字符串。
条件表达式是用比较运算符逻辑运算符括号将多个数值型表达式字符串表达式连接起来而得的符合T-SQL语法规则的式子。条件表达式的返回值是逻辑值“真”或“假”。  

函数、流程控制、程序应用实例分析三部分的内容后续会在本篇文章中更新添加

相关文章:

数据库复习笔记

写在最前&#xff0c; 写文章的初衷只是为了复习与记录自己的成长&#xff0c;笔者目前水平还有待提高&#xff0c;文章中难免会出现许多问题与错误&#xff0c;文章内容仅供参考&#xff0c;有不足的地方还请大家多多包涵并指正&#xff0c;谢谢~ 第八章 T-SQL程序结构 8.…...

学习STM32(6)-- STM32单片机ADCDAC的应用

1 引 言 深入了解并掌握STM32F103单片机在模拟数字转换&#xff08;ADC&#xff09;和数字模拟转换&#xff08;DAC&#xff09;应用方面的功能和操作。学习如何配置STM32F103的ADC模块&#xff0c;实现模拟信号到数字信号的精确转换&#xff1b;同时&#xff0c;探索DAC模块…...

学习记录第二十五天

wait函数 wait函数是一个系统调用&#xff0c;用于等待一个子进程结束并回收其资源。当父进程调用wait函数时&#xff0c;它会暂停执行&#xff0c;直到至少有一个子进程结束。wait函数的原型如下&#xff1a; #include <sys/types.h> #include <sys/wait.h>pid_…...

C语言:字符串函数strcmp

该函数用于比较两个字符串是否一样。 使用方法如下&#xff1a; #include<stdio.h> #include<string.h>int main() {//strcmp函数返回值有三种情况&#xff0c;小于零时返回-1&#xff0c;等于零&#xff0c;大于零时返回1printf("%d\n", strcmp("…...

【数据分析---偏企业】 Excel操作

各位大佬好 &#xff0c;这里是阿川的博客&#xff0c;祝您变得更强 个人主页&#xff1a;在线OJ的阿川 大佬的支持和鼓励&#xff0c;将是我成长路上最大的动力 阿川水平有限&#xff0c;如有错误&#xff0c;欢迎大佬指正 Excel操作前 必看 Python 初阶 Python—语言基础与…...

Ajax-01.原生方式

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Ajax-原生方式</title> </head> <!-…...

OpenAI GPT-2 model use with TensorFlow JS

题意&#xff1a;使用 TensorFlow JS 应用 OpenAI GPT-2 模型 问题背景&#xff1a; Is that possible to generate texts from OpenAI GPT-2 using TensorFlowJS? 是否可以使用 TensorFlowJS 生成 OpenAI GPT-2 的文本&#xff1f; If not what is the limitation, like mo…...

JVM-运行数据区(堆、栈、元空间)

文章声明&#xff1a;文章图片均来自互联网&#xff0c;因为本人画的图不够生动。 运行数据区是JVM最重要的一个区域。 运行数据区由栈、堆、元空间构成。 栈&#xff1a;程序计数器、JVM虚拟机栈&#xff0c;本地方法栈 本地方法栈&#xff1a;加载native修饰的方法&#…...

超详细!!! LVS(Linux virual server)负载均衡知识及其NAT模式、DR模式、火墙标记实验

目录 前言系统性能扩展方式集群Cluster分布式集群与分布式 四层转发与七层转发的区别 LVS&#xff08;Linux virual server&#xff09;一、LVS介绍LVS相关概念 二、LVS集群结构体系1. 负载均衡层&#xff08;Load Balancer&#xff09;2. 服务器群组层&#xff08;Server Pool…...

信息学奥赛一本通1259:【例9.3】求最长不下降序列

题目&#xff1a; 1259&#xff1a;【例9.3】求最长不下降序列 时间限制: 1000 ms 内存限制: 65536 KB 提交数:51218 通过数: 20928 Special Judge 【题目描述】 设有由n(1≤n≤200)n(1≤n≤200)个不相同的整数组成的数列&#xff0c;记为:b(1)、b(2)、……、…...

星露谷模组开发教程#3 事件

首发于Enaium的个人博客 SMAPI提供了一些事件&#xff0c;比如游戏的内容、显示、输入等事件。这些事件可以让我们在游戏中添加自己的逻辑。这一节我们就来看看如何使用这些事件。 注册一个事件 在SMAPI中&#xff0c;我们可以通过IModHelper的Events属性来注册事件。比如我们…...

C语言程序设计(初识C语言后部分)

愿天下无Bug&#xff0c;秀发常驻。 3&#xff09;函数的参数 1.实际参数&#xff08;实参&#xff09;&#xff1a; 真实传给函数的参数&#xff0c;叫实参。 实参可以是&#xff1a;常量、变量、表达式、函数等。 无论实参是何类型的量&#xff0c;在进行函数调用时&#…...

驱动基础开发

1、字符设备传统开发模板 字符设备驱动框架&#xff0c;首先我们需要去用module_init这个宏去修饰整个驱动的入口函数&#xff0c;用module_exit去修饰整个驱动的出口函数&#xff0c;然后还需要用MODULE_LICENSE用于声明模块的许可证类型。 在入口函数里面我们需要注册字符设…...

从苹果AppStore看AI开发者生态

从苹果 App Store 看 AI 开发者生态 在人工智能迅速发展的今天&#xff0c;我们不禁要问&#xff1a;未来的 AI 开发者生态将会是什么样子&#xff1f;为了回答这个问题&#xff0c;我们不妨回顾一下移动互联网时代最成功的开发者生态之一——苹果的 App Store。 通过分析 App …...

【Python学习-UI界面】PyQt5 小部件1-Label

QLabel 对象可用作显示不可编辑的文本、图像或动态GIF影片的占位符。 它还可以用作其他小部件的助记键。 标签可以显示普通文本、超链接或富文本。 1、普通文本 直接双击输入即可 2、添加超链接 选中对应Label&#xff0c;右键选择多信息文本&#xff0c;添加链接&#xff0c…...

【Linux详解】进度条实现 Linux下git 的远程上传

&#x1f4c3;个人主页&#xff1a;island1314 &#x1f525;个人专栏&#xff1a;Linux—登神长阶 ⛺️ 欢迎关注&#xff1a;&#x1f44d;点赞 &#x1f442;&#x1f3fd;留言 &#x1f60d;收藏 &#x1f49e; &#x1f49e; &#x1f49e; &#x1f680;前言 &#x…...

Android进阶之路 - res、raw、assets 资源解析、区别对比

那天遇到一个资源目录层级的问题&#xff0c;索性重新整理记录一下&#xff0c;希望能帮到如吾往昔之少年的你们&#xff0c;哈哈哈哈哈哈… 一脸茫然&#xff0c;越写越多&#xff0c;时间成本属实有点大&#xff0c;就当一起来基础扫盲吧 resdrawablemipmapvaluescolor asset…...

从数字化到数智化:消费零售企业如何实现门店数智化管理?

随着信息技术的飞速发展&#xff0c;数字化已成为企业转型的必经之路。然而&#xff0c;数字化本身并不是目的&#xff0c;而是通往数智化的桥梁。数智化&#xff0c;即数据智能化&#xff0c;是指企业通过数字化手段收集和分析数据&#xff0c;进而利用这些数据驱动决策和创新…...

Linux中ES的安装

文章目录 一、ES是什么1.1、ES概念介绍1.2、技术架构1.2.1、Lucene介绍 1.3、ES的工作原理1.4、ES的适用场景 二、安装前的配置2.1、创建普通用户2.2、调整文件描述符数量和虚拟内存2.3、设置shell会话的资源限制&#xff08;软限制和硬限制&#xff09;2.4、增加虚拟内存的设置…...

Redis远程字典服务器(5) —— hash类型详解

目录 一&#xff0c;hash基本情况 二&#xff0c;hash常用命令详解 2.1 hset&#xff0c;hget&#xff0c;hexists&#xff0c;hdel 2.2 hexists&#xff0c;hdel 2.3 hkeys&#xff0c;hvals 2.4 hgetall&#xff0c;hmget 2.5 hlen&#xff0c;hsetnx 2.6 hincrby&am…...

多云管理“拦路虎”:深入解析网络互联、身份同步与成本可视化的技术复杂度​

一、引言&#xff1a;多云环境的技术复杂性本质​​ 企业采用多云策略已从技术选型升维至生存刚需。当业务系统分散部署在多个云平台时&#xff0c;​​基础设施的技术债呈现指数级积累​​。网络连接、身份认证、成本管理这三大核心挑战相互嵌套&#xff1a;跨云网络构建数据…...

基于距离变化能量开销动态调整的WSN低功耗拓扑控制开销算法matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.算法仿真参数 5.算法理论概述 6.参考文献 7.完整程序 1.程序功能描述 通过动态调整节点通信的能量开销&#xff0c;平衡网络负载&#xff0c;延长WSN生命周期。具体通过建立基于距离的能量消耗模型&am…...

线程与协程

1. 线程与协程 1.1. “函数调用级别”的切换、上下文切换 1. 函数调用级别的切换 “函数调用级别的切换”是指&#xff1a;像函数调用/返回一样轻量地完成任务切换。 举例说明&#xff1a; 当你在程序中写一个函数调用&#xff1a; funcA() 然后 funcA 执行完后返回&…...

FastAPI 教程:从入门到实践

FastAPI 是一个现代、快速&#xff08;高性能&#xff09;的 Web 框架&#xff0c;用于构建 API&#xff0c;支持 Python 3.6。它基于标准 Python 类型提示&#xff0c;易于学习且功能强大。以下是一个完整的 FastAPI 入门教程&#xff0c;涵盖从环境搭建到创建并运行一个简单的…...

转转集团旗下首家二手多品类循环仓店“超级转转”开业

6月9日&#xff0c;国内领先的循环经济企业转转集团旗下首家二手多品类循环仓店“超级转转”正式开业。 转转集团创始人兼CEO黄炜、转转循环时尚发起人朱珠、转转集团COO兼红布林CEO胡伟琨、王府井集团副总裁祝捷等出席了开业剪彩仪式。 据「TMT星球」了解&#xff0c;“超级…...

unix/linux,sudo,其发展历程详细时间线、由来、历史背景

sudo 的诞生和演化,本身就是一部 Unix/Linux 系统管理哲学变迁的微缩史。来,让我们拨开时间的迷雾,一同探寻 sudo 那波澜壮阔(也颇为实用主义)的发展历程。 历史背景:su的时代与困境 ( 20 世纪 70 年代 - 80 年代初) 在 sudo 出现之前,Unix 系统管理员和需要特权操作的…...

Unit 1 深度强化学习简介

Deep RL Course ——Unit 1 Introduction 从理论和实践层面深入学习深度强化学习。学会使用知名的深度强化学习库&#xff0c;例如 Stable Baselines3、RL Baselines3 Zoo、Sample Factory 和 CleanRL。在独特的环境中训练智能体&#xff0c;比如 SnowballFight、Huggy the Do…...

【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具

第2章 虚拟机性能监控&#xff0c;故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令&#xff1a;jps [options] [hostid] 功能&#xff1a;本地虚拟机进程显示进程ID&#xff08;与ps相同&#xff09;&#xff0c;可同时显示主类&#x…...

招商蛇口 | 执笔CID,启幕低密生活新境

作为中国城市生长的力量&#xff0c;招商蛇口以“美好生活承载者”为使命&#xff0c;深耕全球111座城市&#xff0c;以央企担当匠造时代理想人居。从深圳湾的开拓基因到西安高新CID的战略落子&#xff0c;招商蛇口始终与城市发展同频共振&#xff0c;以建筑诠释对土地与生活的…...

vulnyx Blogger writeup

信息收集 arp-scan nmap 获取userFlag 上web看看 一个默认的页面&#xff0c;gobuster扫一下目录 可以看到扫出的目录中得到了一个有价值的目录/wordpress&#xff0c;说明目标所使用的cms是wordpress&#xff0c;访问http://192.168.43.213/wordpress/然后查看源码能看到 这…...