[T-SQL]从变量与数据类型说起

简介:

 1.变量

学习计算机语言,难免不碰到这个名词,不过咱这里说的是MSSQL(微软SQL Server产品)里的数据库语言实现。

稍微对程序比较严谨的语言都要求使用之前都要声明变量先,比如c.c++,java,c#之类,T-SQL也没有例外。

可以试验下:

 

 
  1. SELECT @hello 

会有如下类似错误信息:

 

 
  1. [Err] 42000 - [SQL Server]必须声明标量变量 "@hello"。 

声明变量使用如下关键字:DECLARE(不区分大小写的)

声明变量需要使用类型,因为“我”要知道你这玩意到底是整数还是日期还是字符串,我该给你分配多少字节空间啊。

2.数据类型

数据类型就是之前提到的整型,字符之类的类别。

我们的格式是:

 

 
  1. DECLARE 变量名 类型 

我这里约定下,关键字和类型等用大写,变量名小写,你可以不这样子,但希望你遵守“我们学堂”的规范,呵呵。

先说下,TSQL这孩子变量分好多哇,跟其他语言差不多(其他语言有,局部变量,全局变量之类的,俺可没搞什么大的特殊)

这里先用局部变量(Local Variant),T-SQL局部变量是@后接变量名字,

 

 
  1. DECLARE @hello VARCHAR(30) 

俺可以一次声明多个呢,

 
  1. DECLARE @i INT, 
  2.         @j INT 

当然了声明后,俺们的值是个NULL(注意不是'NULL'字符串哦)

SELECT @i 您看看吧

你坑我啊,光个NULL怎么用,别急,我们看看怎么给他们赋值,不会和其他语言一样直接用赋值运算符=吧,对头不过语法稍微区别下

3.赋值

 

 
  1. SET @i=123 

这次看看吧SELECT @i

当然SET也可以用SELECT代替。

稍微来点复杂的:

 
  1. --===================== 
  2. --计算面积@area=@m*@n 
  3. --===================== 
  4. DECLARE @m INT, 
  5.         @n INT, 
  6.         @area INT 
  7. SET @m=12 
  8. SET @n=5 
  9. SET @area=@m*@n 
  10. SELECT @area 

赋值也可以是sql执行的结果:

 
  1. USE pubs 
  2. GO 
  3.  
  4. DECLARE @count INT 
  5.  
  6. SET @count=(SELECT COUNT(*) FROM authors) 
  7.  
  8. SELECT @count 
  9. GO 

 变量也可以用在sql里,比如下面:

 

 
  1. USE pubs 
  2. GO 
  3.  
  4. DECLARE @city CHAR(20) 
  5. SET @city='Oakland' 
  6.  
  7. SELECT RTRIM(au_fname) + ' ' + RTRIM(au_lname) AS Name 
  8. FROM authors 
  9. WHERE city = @city 
  10.  
  11. GO 

4.流程控制

分支条件语句这个太常见了,顺序、分支和重复(循环)是结构化程序设计的3个流程,不得不说。

我们看看T-SQL里的条件语句怎么写,关键字IF不多说了。

如下:

 

 
  1. DECLARE @i INT 
  2. SET @i=123 
  3. IF @i>0 (SELECT 'positive') 

一条语句可以这么干,多条语句块怎么整呢,别着急,BEGIN...END啊,(如果没在一些语言里见过,c类似的里面的{}总该行了吧)

 

 
  1. DECLARE @i INT 
  2. SET @i=123 
  3. IF @i>0  
  4.     BEGIN 
  5.         SELECT 'positive' 
  6.         SELECT 'not negative' 
  7.     END 
  8. ELSE 
  9.     SELECT 'OMG' 

没错ELSE也支持的。

也可以嵌套。

循环LOOP

使用关键字WHILE

 
  1. DECLARE @i INT 
  2. SET @i=0 
  3.  
  4. WHILE @i<10 
  5.     BEGIN 
  6.         SET @i=@i+1 
  7.         PRINT '@i='+CAST(@i AS CHAR) 
  8.     END 

while也可以嵌套。

5.附录:数据类型总结

比特bit:取值0,1和NULL

整型:

tinyint:取值0-255,存储大小1个字节

smallint:2个字节,-32768~+32767

int:4个字节

bigint:8个字节

 

以下来自文档:

decimal 和 numeric 

decimal

从 -10^38 +1 到 10^38 –1 的固定精度和小数位的数字数据。

numeric

功能上等同于 decimal

money 和 smallmoney

money

货币数据值介于 -2^63 (-922,337,203,685,477.5808) 与 2^63 - 1 (+922,337,203,685,477.5807) 之间,精确到货币单位的千分之十。

smallmoney

货币数据值介于 -214,748.3648 与 +214,748.3647 之间,精确到货币单位的千分之十。

近似数字

float

从 -1.79E + 308 到 1.79E + 308 的浮点精度数字。

real

从 -3.40E + 38 到 3.40E + 38 的浮点精度数字。

datetime 和 smalldatetime

datetime

从 1753 年 1 月 1 日到 9999 年 12 月 31 日的日期和时间数据,精确到百分之三秒(或 3.33 毫秒)。

smalldatetime

从 1900 年 1 月 1 日到 2079 年 6 月 6 日的日期和时间数据,精确到分钟。

字符串

char

固定长度的非 Unicode 字符数据,最大长度为 8,000 个字符。

varchar

可变长度的非 Unicode 数据,最长为 8,000 个字符。

text

可变长度的非 Unicode 数据,最大长度为 2^31 - 1 (2,147,483,647) 个字符。

Unicode 字符串

nchar

固定长度的 Unicode 数据,最大长度为 4,000 个字符。

nvarchar

可变长度 Unicode 数据,其最大长度为 4,000 字符。sysname 是系统提供用户定义的数据类型,在功能上等同于 nvarchar(128),用于引用数据库对象名。

ntext

可变长度 Unicode 数据,其最大长度为 2^30 - 1 (1,073,741,823) 个字符。

二进制字符串

binary

固定长度的二进制数据,其最大长度为 8,000 个字节。

varbinary

可变长度的二进制数据,其最大长度为 8,000 个字节。

image

可变长度的二进制数据,其最大长度为 2^31 - 1 (2,147,483,647) 个字节。

其它数据类型

cursor

游标的引用。

sql_variant

一种存储 SQL Server 支持的各种数据类型(textntexttimestamp 和 sql_variant 除外)值的数据类型。

table

一种特殊的数据类型,存储供以后处理的结果集。

timestamp

数据库范围的唯一数字,每次更新行时也进行更新。

uniqueidentifier

全局唯一标识符 (GUID)。

 

 

 本文转自 xcf007 51CTO博客,原文链接:http://blog.51cto.com/xcf007/833008,如需转载请自行联系原作者


目录
打赏
0
0
0
0
348
分享
相关文章
Oracle的PL/SQL定义变量和常量:数据的稳定与灵动
【4月更文挑战第19天】在Oracle PL/SQL中,变量和常量扮演着数据存储的关键角色。变量是可变的“魔术盒”,用于存储程序运行时的动态数据,通过`DECLARE`定义,可在循环和条件判断中体现其灵活性。常量则是不可变的“固定牌”,一旦设定值便保持不变,用`CONSTANT`声明,提供程序稳定性和易维护性。通过 `%TYPE`、`NOT NULL`等特性,可以更高效地管理和控制变量与常量,提升代码质量。善用两者,能优化PL/SQL程序的结构和性能。
【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性
【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性
|
1月前
|
SQL
【YashanDB知识库】like 变量的SQL语句应用程序执行效率低与yasql执行效率高
【YashanDB知识库】like 变量的SQL语句应用程序执行效率低与yasql执行效率高
RDS for MySQL的SQL分类与数据类型
小明需在MySQL中管理商品信息,使用SQL完成业务操作。SQL分为DQL(查询)、DML(增删改)、DDL(定义)、DCL(权限控制)和TCL(事务)五大类。DDL用于创建、修改和删除数据库结构,DML处理数据,DCL控制权限,TCL管理事务,DQL则用于查询数据。MySQL有多种数据类型,如数值型(整数、小数)、日期型和字符串型等,选择合适的数据类型是高效开发的关键。
124 0
SQL Server、MySQL、PostgreSQL:主流数据库SQL语法异同比较——深入探讨数据类型、分页查询、表创建与数据插入、函数和索引等关键语法差异,为跨数据库开发提供实用指导
【8月更文挑战第31天】SQL Server、MySQL和PostgreSQL是当今最流行的关系型数据库管理系统,均使用SQL作为查询语言,但在语法和功能实现上存在差异。本文将比较它们在数据类型、分页查询、创建和插入数据以及函数和索引等方面的异同,帮助开发者更好地理解和使用这些数据库。尽管它们共用SQL语言,但每个系统都有独特的语法规则,了解这些差异有助于提升开发效率和项目成功率。
873 0
DataWorks产品使用合集之ODPPS中如何使用SQL查询从表中获取值并将其赋值给临时变量以供后续使用
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
SQL分类与数据类型
【7月更文挑战第12天】Mysql SQL语句分类与数据类型 介绍
|
10月前
|
SQL 通用数据类型
SQL 通用数据类型
54 1

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等