1.变量

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

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

可以试验下:

  SELECT @hello

会有如下类似错误信息:

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

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

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

2.数据类型

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

我们的格式是:

  DECLARE 变量名 类型

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

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

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

  DECLARE @hello VARCHAR(30)

俺可以一次声明多个呢,

  DECLARE @i INT,

@j INT

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

SELECT @i 您看看吧

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

3.赋值

  1. SET @i=123

这次看看吧SELECT @i

当然SET也可以用SELECT代替。

稍微来点复杂的:

--=====================

--计算面积@area=@m*@n

--=====================

DECLARE @m INT, 

        @n INT, 

        @area INT 

SET @m=12 

SET @n=5 

SET @area=@m*@n 

SELECT @area 

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

USE pubs 

GO 

DECLARE @count INT
SET @count=(SELECT COUNT(*) FROM authors) SELECT @count GO

  

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

USE pubs 

GO 

DECLARE @city CHAR(20)
SET @city='Oakland' SELECT RTRIM(au_fname) + ' ' + RTRIM(au_lname) AS Name FROM authors WHERE city = @city GO

4.流程控制

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

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

如下:

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

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

DECLARE @i INT
SET @i=123 IF @i>0 BEGIN SELECT 'positive' SELECT 'not negative' END ELSE SELECT 'OMG'

没错ELSE也支持的。

也可以嵌套。

循环LOOP

使用关键字WHILE

DECLARE @i INT 

SET @i=0 

WHILE @i<10 

    BEGIN 

        SET @i=@i+1 

        PRINT '@i='+CAST(@i AS CHAR) 

    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)。

转载自:http://xcf007.blog.51cto.com/471707/833008

最新文章

  1. Bool 类型变量的使用
  2. 【译】Activitys, Threads和 内存泄露
  3. Sql动态添加字段的正确姿势
  4. 【剑指offer】题目36 数组中的逆序对
  5. 在MyEclipse中搭建Spring MVC开发环境
  6. UVa (二分) 11627 Slalom
  7. 阿里云OSS存储开发(一)
  8. JavaScript实现复制功能
  9. SQL表连接
  10. 第六十八节,htnl全局属性和其他属性
  11. Java 资源本地化与国际化
  12. 初探OpenCL之Mac OS上的hello world示例
  13. 微信小程序开发学习记录
  14. Android测试技能树
  15. 10.110.20.16上的MQTT server
  16. iOS架构设计系列之解耦的尝试之变异的MVVM
  17. Forward团队-爬虫豆瓣top250项目-团队编程项目开发环境搭建过程
  18. 20155326 第十周课下作业-IPC
  19. Android的layout_weight和weightSum
  20. PHP操作Redis常用

热门文章

  1. Eyeshot Ultimate 学习笔记(2)
  2. 《工作型PPT设计之道》培训心得
  3. 【 java版坦克大战--事件处理】 让坦克动起来--事件处理的准备
  4. jinja2 宏的简单使用总结(macro)
  5. 在windows下的mysql使用
  6. 005 Python的数值类型
  7. C#中获得汉字的首拼音(加强版)
  8. STM32库函数开发使用总结
  9. Mvc 分页栏扩展方法
  10. 避免eclipse下启动run就进入debug模式