sql server T-SQL 基础
SQL语言按照用途可以分为如下3类:
定义修改和删除数据库、表、索引和视图等
对数据进行查询(SELECT)、插入(INSERT)、删除(DELETE)、更新(UPDATE)等
对数据库对象的权限管理和事务管理
一、T-SQL语法基础
1.标识符
Select * from book where bname=“C程序”
中的book和bname。
例如: SELECT * FROM " My Table "
例如: SELECT * FROM [My Table]
2.常量
常量是指在程序运行过程中值始终不变的值。
3.变量
在SQL Server中,变量分为局部变量和全局变量
前面有一个@字符,由用户定义和使用。
名称前面有两个@字符,由系统定义和维护。
DECLARE { @local_variable data_type }[,...n]
例如:
DECLARE @grade int,@sex char(2)
set @grade=60
select @sex='女‘
select @grade, @sex
4.运算符
运算符是一种符号,用来指定要在一个或多个表达式中执行的操作。
运算符优先级:
+(正)、-(负)、~(按位NOT)
*、/、%
+(加)、+(连接)、-(减)
=、>、<、>=、<=、<>、!=、!>、!<
^(按位异或)、&(按位与)、|(按位或)
NOT
AND
ALL、ANY、BETWEEN、IN、LIKE、OR、
=(赋值)
5.流程控制语句
控制流语句是用来控制程序执行流程的语句,使用控制流语句可以在程序中组织语句的执行流程,提高编程语言的处理能力。
T-SQL提供控制流关键字,用于控制语句、语句块和存储过程的执行流。
控制流语句 |
说明 |
BEGIN…END |
定义语句块 |
IF…ELSE |
条件处理语句,如果条件成立,执行IF语句; 否则执行ELSE语句 |
CASE |
分支语句 |
WHILE |
循环语句 |
GOTO |
无条件跳转语句 |
RETURN |
无条件退出语句 |
WAITFOR |
延迟语句 |
BREAK |
跳出循环语句 |
CONTINUE |
重新开始循环语句 |
① BEGIN…END语句
BEGIN…END语句用于将多个Transact-SQL语句组合为一个逻辑块。
语法格式为:
BEGIN
{
sql语句|语句块
}
END
IF或ELSE子句需要包含语句块。
② IF…ELSE语句
使用IF…ELSE语句,可以有条件地执行语句。其语法格式如下:
IF Boolean_expression
{sql语句|语句块}
[ELSE
{sql语句|语句块}]
1)简单CASE格式
其语法格式如下:
CASE input_expression
WHEN when_expression THEN result_expression
[…n]
[ELSE else_result_expression]
END
注: input_expression和每个when_expression的数据类型必须相同或隐形转换。
如果未找到匹配值,也没有else子句,则返回null。
2)搜索CASE格式
其语法格式如下:
CASE
WHEN Boolean_expression THEN result_expression
[…n]
[ELSE else_result_expression]
END
注:如果Boolean_expression表达式的值为true,则返回then后的表达式,然后跳出case语句。
④ WHILE语句
WHILE语句可以重复执行若干SQL语句。
其语法格式如下:
WHILE Boolean_expression
{sql语句|语句块}
[BREAK]
{sql语句|语句块}
[CONTINUE]
⑤GOTO语句
GOTO语句可以实现无条件的跳转。其语法格式为:
GOTO lable
⑥ RETURN语句
RETURN [integer_expression]
其中:integer_expression为一个整数值,是return语句要返回的值。
⑦ WAITFOR语句
WAITFOR {DELAY 'time' | TIME 'time'}
⑧try…catch语句
Begin try
{sql_statement|sql_block}
End try
Begin catch
{sql_statement|sql_block}
End catch
6.注释
这些注释字符可与要执行的代码处在同一行,也可另起一行。从双连字符开始到行尾均为注释。
从开始注释对(/*)到结束注释对(*/)之间的全部内容均视为注释部分。可对多行注释。
7.游标的使用
定义该游标的SELECT语句返回的行的集合。
指向这个集合中某一行的指针。
游标的典型使用过程 :
声明游标使用DECLARE CURSOR语句,格式如下:
DECLARE cursor_name [ SCROLL ] CURSOR
FOR select_statement
[ FOR { READ ONLY | UPDATE [ OF column_name [ , …n ] ] } ]
打开游标使用OPEN语句,其语法格式如下:
OPEN { { [ GLOBAL ] cursor_name } | cursor_variable_name }
其中:
FETCH [ [ NEXT | PRIOR | FIRST | LAST
| ABSOLUTE { n | @nvar }
| RELATIVE { n | @nvar }
]
FROM
]
{ { [ GLOBAL ] cursor_name } | @cursor_variable_name }
[ INTO @variable_name [ , …n ] ]
@@FETCH_STATUS()函数
该函数报告上一个FETCH语句的状态,其取值和含义如表所示。
取值 |
含义 |
0 |
FETCH语句成功 |
-1 |
FETCH语句失败或此行不在结果集中 |
-2 |
被提取的行不存在 |
@@ROWCOUNT 全局变量
用来提供游标活动信息,它返回受上一语句影响的行数。
关闭游标使用CLOSE语句,其语法格式如下:
CLOSE { { [ GLOBAL ] cursor_name } | cursor_variable_name }
DEALLOCATE { { [ GLOBAL ] cursor_name } | @cursor_variable_name }
sql server T-SQL 基础的更多相关文章
- .NET/ASP.NET/C#/WCF/SQL Server/My SQL/Java/JSP/JDBC/Spring/Spring MVC/PHP/Python/Ruby/Shell/Agile/CSS/HTML/HTTP/Unix/Linux大量PDF书籍/电子书籍下载, Effective Java 下载
223本电子书籍,囊括了.NET/ASP.NET/C#/WCF/SQL Server/My SQL/Java/JSP/JDBC/Spring/Spring MVC/PHP/Python/Shell/A ...
- 【SQL Server】SQL触发器经验详解
[SQL Server]SQL触发器经验详解 | 浏览: 4314 | 更新: 2013-01-07 15:33 25 11 全文阅读分步阅读 加入杂志 步骤 1 2 3 4 5 6 7 8 ...
- SQL Server经典sql语句大全(转)
一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数 ...
- PowerDesigner反向数据库时遇到[Microsoft][ODBC SQL Server Driver][SQL Server]无法预定义语句。SQLSTATE = 37错误解决方法
逆向工程中,有时会出现如下错误 ... [Microsoft][ODBC SQL Server Driver][SQL Server]无法预定义语句 SQLSTATE = 37000 解决方案: 1. ...
- [Oracle][ODBC SQL Server Driver][SQL Server]对象名 'RECOVER.HS_TRANSACTION_LOG' 无效(转)
原帖由 qingyun 于 2010-6-21 15:44 发表 在写pl/sql的时候,有个很重要的注意点:比如:begin update 某个sqlserver的表@dblink名字 .... ...
- (转)[SQL Server] 动态sql给变量赋值(或返回值给变量)
本文转载自:http://blog.csdn.net/xiaoxu0123/article/details/5684680 [SQL Server] 动态sql给变量赋值(或返回值给变量) decla ...
- SQL Server 2008 /SQL Server 2008 R2 配置数据库邮件
原文:SQL Server 2008 /SQL Server 2008 R2 配置数据库邮件 从2005开始,就引入了"数据库邮件"功能.并且取代SQLMail.原有SQLMail ...
- SQL Server审计功能入门:SQL Server审核 (SQL Server Audit)
原文:SQL Server审计功能入门:SQL Server审核 (SQL Server Audit) 介绍 Audit是SQL Server 2008之后才有的功能,它能告诉你"谁什么时候 ...
- sql server 与 sql server compact 互相数据导入
从SQL Server 导出数据到 Sql Compact 使用 Sql Server Compact Tool box 从SQL Server Comapct 导出数据到 Sql Server 使 ...
- SQLSERVER 免费对比数据库结构和数据的工具支持:SQL Server 2012, SQL Server 2008 and SQL Server 2005
New xSQL Schema Compare - version 5 Compare the schemas of two SQL Server databases, review differen ...
随机推荐
- 一次由于字符集问题引发的MySQL主从同步不一致问题追查
近期业务准备上线一个新功能,灌入数据之后突然发现主从同步停止,报错如下: Error 'Duplicate entry '66310984-2014-04-18 00:00:00--122815.sh ...
- Myeclipse6.0 在线安装svn插件
一.官网地址 1.SVN 官方网站:http://subversion.apache.org/ 二.安装步骤 1. 打开Myeclipse,在菜单栏中选择Help→Software Updates→F ...
- iOS -数据库网络之xml解析
XML文件有2种解析方式 1.基于文档(document) 2.基于事件(sax) 1.IOS中XML文件获取 首先要将XML导入工程中 在ViewController的按钮事件中,代码如下: ...
- folly
一.简介 Folly是,Facebook于2012年6月初开源的一个基于C++11的C++组件库,提供了类似Boost库和std库的功能,包括散列.字符串.向量.内存分配.位处理等,以满足大规模高性能 ...
- openfire+asmack搭建的安卓即时通讯(六) 15.4.16
啊啊啊啊啊啊啊啊,这东西越做越觉得是个深坑啊! 1.SharedPreferences.Editor的密码保存和自动登录: 首先还是从主界面开始,因为要提升一下用户体验自然要加入保存密码和自动登录的功 ...
- 孙鑫视频学习:对第10章设置线宽时为什么不调用UpDateData(TRUE)的理解
在第10章10.2.1小节中,首先分别对视图类和对话框类添加了一个名为m_nLineWidth的int型变量,再将用户在CSetting dlg对话框的edit控件中输入的线宽值记录在dlg.m_nL ...
- java11-4 字符串的遍历以及字符串中各类字符的统计
1.需求:获取字符串中的每一个字符 分析: A:如何能够拿到每一个字符呢? char charAt(int index) B:我怎么知道字符到底有多少个呢? int length() publi ...
- 通过imeMode禁用键盘只能输入数字
var obj = document.getElementById('y'); var arr = [48,49,50,51,52,53,54,55,56,57];//数字对应的键码 obj.onke ...
- html中的src与href的区别
写代码的时候就经常把这两个属性弄混淆,到底是href还是src,href标识超文本引用,用在link和a等元素上,href是引用和页面关联,是在当前元素和引用资源之间建立联系,src表示引用资源,表示 ...
- javascript中的迭代器
1.forEach迭代器 forEach方法接收一个函数作为参数,对数组中每个元素使用这个函数,只调用这个函数,数组本身没有任何变化 //forEach迭代器 function square(num) ...