T-SQL语法大全
T-SQL简介及基本语法
T-SQL简介及基本语法⼀、T-SQL概述SQL Server⽤于操作数据库的编程语⾔为Transaction-SQL,简称T-SQL。
T-SQL与PL/SQL不同,并没有固定的程序结构。
T-SQL包括以下4个部分:DDL:定义和管理数据库及其对象,例如create、alter和drop等。
DML:实现对数据库表各对象的操作,例如insert、update等。
DCL:数据控制语⾔,实现对数据库进⾏安全管理和权限管理等控制,例如grant、revoke、deny等。
附加的语⾔元素。
T-SQL的附加语⾔元素,包括变量、运算符、函数、注释和流程控制语句等。
在T-SQL中,命令和语句的书写是不区分⼤⼩写的。
⼆、T-SQL编程基础1、标识符①T-SQL规则标识符由字母、数字、下划线、@、#、$符号组成,其中字母可以是a-z或A-Z,也可以是来⾃其他语⾔的字母字符。
⾸字符不能为数字和$。
标识符不允许是T-SQL保留字。
标识符内不允许有空格和特殊字符长度⼩于128②界定标识符 对于不符合标识符规则的标识符,则要使⽤界定符⽅括号([])或双引号(“”)将标识符括起来。
如标识符[My Table]、“select”内分别使⽤了空格和保留字select。
2、数据类型在SQL Server中提供了多种系统数据类型。
除了系统数据类型外,还可以⾃定义数据类型。
①系统数据类型(1)精确数字数据类型int 存储整型数值,存储数值范围为-231~231-1。
bigint bigint⽐int能存储更⼤的数值,存储数值范围为-263~263-1。
smallint 数据类型的范围数值⽐int更⼩,在-215~215-1之间。
定义这种数据类型的时候⼀定要⼩⼼,要确定存储的数据不会超过smallint所能存储的数值范围。
tinyint 数据类型的范围数值⽐smallint更⼩,存储从 0 到 255 的整型数据。
decimal/numeric decimal[(p,s)]和numeric[(p,s)]这两种数据类型⽤于存储相同精度和范围的数据(⼩数点的左、右两边存储的数值位数相同),所能存储的数值范围为-1038+1~1038-1。
数据库T-SQL语言操作(T-SQL语句、数据库、表、视图、索引)
数据库T-SQL语⾔操作(T-SQL语句、数据库、表、视图、索引)T-SQL语⾔按⽤途分四部分1. 数据定义语⾔(CREATE,DROP,ALTER)2. 数据操作语⾔(INSERT,DELETE,UPDATE)3. 数据查询语⾔(SELECT)4. 数据控制语⾔(GRANT,REVOKE,DENY)数据类型1. 系统数据类型2. ⽤户⾃定义数据类型(建⽴⽅式:a.图形化⽅式 b.命令⽅式)1use TEST2EXEC sp_addtype sno,'varchar(10)','nonull'3EXEC sp_droptype sno变量命名规则:字母、下划线、@或#开头,但不能全为下划线、@或#不能为“关键字”,不能嵌⼊空格及其他特殊字符,如需使⽤则需要双引号或⽅括号括起1.局部变量:由⽤户声明,必须以@开头,只在定义该变量的过程中有效,局部变量必须先声明后使⽤注意:第⼀次声明变量时,其值设置为NULL。
局部变量不能使⽤“变量=变量值”的格式进⾏初始化,必须使⽤SELECT或SET语句来设置其初始值。
如果声明字符型的局部变量,⼀定要在变量类型中指明其最⼤长度,否则系统默认其长度为1。
若要声明多个局部变量,请在定义的第⼀个局部变量后使⽤⼀个逗号,然后指定下⼀个局部变量名称和数据类型。
1USE student2DECLARE@var1char(10),@var2int3SET@var1='number'4select@var2=cgrade5from sc6where sno='201810010'78print@var1+"s"2.全局变量:由系统定义,供SQL server系统内部使⽤的变量,任何程序任何时间都可以调⽤。
通常以“@@”开头。
T-SQL语句1.注释语句(1) --(2) /*……*/2.批处理--GO3.控制流程语句(1) begin...end语句(相当于C语⾔中的{} )(2) if...else语句(可嵌套)(3)case语句(多条件选择语句)(4)print语句(屏幕输出语句)(5)while语句(有条件的循环语句)(6)goto语句(⽆条件跳转语句)(7)break语句(8)continue语句4.常⽤函数(系统函数、⽤户⾃定义函数)⼀些系统函数:(1)字符串函数(2)数学函数(3)⽇期和时间函数(4)聚合函数注意:⽤户⾃定义函数:1.分类:标量值函数:返回单个值内联表值函数:返回可更新的表多语句表值函数:返回不可更新的表2.标量值函数命令⽅式创建1CREATE FUNCTION f2(@a real,@b real) 2RETURNS real3AS4BEGIN5IF@a>=@b6RETURN@a7RETURN@b8END910PRINT'最⼤值为'11PRINT dbo.f2(77,56)1CREATE FUNCTION f3(@n real)2RETURNS real3AS4BEGIN5DECLARE@i real,@sum real6SET@i=07SET@sum=08WHILE@i<@n9BEGIN10SET@i=@i+111SET@sum=@sum+@i12END13RETURN@sum14END1516PRINT dbo.f3(10)3.⾃定义函数的调⽤(1)标量值函数可以使⽤select、print、exec调⽤(2)表值函数只能⽤select调⽤4.删除⽅式drop function 函数名数据库数据库概述1.数据库常⽤对象:表、数据类型、视图、索引、存储过程、触发器系统数据库:master、model、tempdb、msdb2.数据库存储结构(数据库⽂件、数据库⽂件组):数据库⽂件:存放数据库数据和数据库对象的⽂件。
常用T-SQL数据库函数
常用T-SQL数据库函数1. 聚合函数(1) A VG函数功能返回组中值的平均值。
空值将被忽略语法A VG ( [ ALL | DISTINCT ] expression )(2) MAX函数功能返回表达式的最大值语法MAX ( [ ALL | DISTINCT ] expression )(3) MIN函数功能返回表达式的最小值语法MIN ( [ ALL | DISTINCT ] expression )(4) SUM函数功能返回表达式中所有值的和,或只返回DISTINCT 值。
SUM 只能用于数字列。
空值将被忽略语法SUM ( [ ALL | DISTINCT ] expression )(5) COUNT函数功能返回组中项目的数量语法COUNT ( { [ ALL | DISTINCT ] expression ] | * } )2. 时间和日期函数(1) DATEADD函数功能在向指定日期加上一段时间的基础上,返回新的datetime值语法DATEADD ( datepart , number, date )样例SELECT DATEADD(day, 21, pubdate) AS timeframe FROM titles(2) DATEPART函数功能返回代表指定日期的指定日期部分的整数语法DATEPART ( datepart , date )样例SELECT DATEPART(month, GETDATE()) AS …Month Number‟(3) DAY函数功能返回代表指定日期的天的日期部分的整数语法DAY ( date )(4) GETDATE函数功能按datetime 值的Microso ft® SQL Server™ 标准内部格式返回当前系统日期和时间语法GETDATE ( )(5) GETUTCDATE函数功能返回表示当前UTC 时间(世界时间坐标或格林尼治标准时间)的datetime 值。
T-SQL 程序循环结构
T-SQL 程序循环结构WHILE1.特点:WHILE循环语句可以根据某些条件重复执行一条T—SQL语句或一个语句块。
WHILE(条件)BEGIN语句或语句块END3。
调试程序:ALT+F5 启动调试,启动后F9切换断点,F10逐过程,F11逐语句4.例题:使用循环求1—10之间的累加和DECLARE@sum int,@i intSET@sum=0SET@i=1——使用循环结构累加求和WHILE(@i<=10)BEGINSET@sum=@i+@sumSET@i=@i+1ENDPRINT'1—10之间的累加和为:’+CAST(@sum AS varchar(4))GO三、CONTINUE、BREAK、RETURN关键字1。
特点:1)CONTINUE:可以让程序跳过CONTINUE关键字后的语句,回到WHILE循环的第一行命令。
2)BREAK:让程序完全跳出循环,结束WHILE循环的执行3)RETURN:从查询或过程中无条件退出,RETURN语句可在任何时候,用于从过程、批处理或语句块中退出。
位于RETURN之后的语句不会被执行。
2。
例题【1】在循环中使用CONTINUE,遇到CONTINUE回到WHILE的条件判断处求1-10之间的偶数和DECLARE@sum int,@i intSET@i=1WHILE(@i<=10)BEGINIF(@i%2=1)BEGINSET@i=@i+1CONTINUEENDELSEBEGINSET@sum=@sum+@iSET@i=@i+1ENDEND--WHILE的结束PRINT'1—10之间的偶数和为:’+CONVERT(varchar(2),@sum) GO【2】在循环中使用BREAK遇到数字5退出程序。
DECLARE@i intSET@i=1WHILE(@i〈=10)BEGINIF(@i=5)BEGINBREAK--退出循环结构,即使条件成立也不去判断了ENDELSESET@i=@i+1ENDPRINT’@i的值为:@x=’+CAST(@i AS varchar(2))GO【3】RETURN实现退出功能DECLARE@i intSET@i=1WHILE(@i<=10)BEGINIF(@i=5)BEGINRETURN—-退出功能可以执行批处理后的代码ENDELSESET@i=@i+1ENDPRINT’@i的值为:@x='+CAST(@i AS varchar(2))GO-—执行该语句,发现没有输出,因为程序遇到RETURN后,整个批处理后面的内容不被执行,但是可以执行批处理后的代码PRINT'我是批处理后的代码'。
第6章 使用T-SQL语言
6.1 变量
6.2 批处理 6.3 流程控制
6.4 事务
6.1 变量
2类: 局部:@ 全局: @@
一、局部变量
用户可自定义的变量
局部变量作用范围:
只能在定义它的语句、批处理或过程中使用
用 DECLARE 声明局部变量
declare @变量名 数据类型 [, @变量名 数据类型…]
二、全局变量
由 SQL Server 提供,用来记录SQL Server的配置
设定值和效能统计数据,可随时调用。
用户不能创建全局变量和赋值,只能读取。
常用的全局变量
@@connections: 自SQL Server最后一次启动以来,连接或试
图连接到SQL Server的连接数目
@@rowcount: 上一条T-SQL语句影响到的数据行数
Select:可用于给变量赋值
Select @local_variable=expression[,„n]
说明:当expression为列名时,select可利用查询功
能将查询结果赋给变量,如果有多个查询结果,则为 查询的最后一个值。
Declare @max int,@min int If (Select avg(score) from score where courseid=‘00100001’)>=60 Begin Print ‘课程代号为00100001的平均分及格’ Select @max=max(score),@min=min(score) from score Where course_id=‘00100001’ Print ‘最高分:’+Convert(char(3),@max) Print ‘最低分:’+convert(char(3),@min) End Else Print ‘我们还需加倍努力!’
T-SQL语句
表级完整性约束条件 Nhomakorabea
Primary key:由多列组成的复合主键,语法格 式: Constraint 约束名 Primary key(字段列表) Foreign key:由多列组成的复合外键,语法格 式: Constraint 约束名 Foreign key(外键) references 被参照表(被参照表的主键) Check(条件表达式) :由多列组成的表达式, 语法格式: Constraint 约束名 Check(条件表达式)
使用T-SQL语句创建表
创建系部信息表如下: create table DeptInfo ( Dept_ID int identity(1,1) primary key, Dept_Code varchar(16) not null unique, --系 部代码,指定唯一性约束 Dept_Name varchar(50) not null, --系部名称 Dept_Desc varchar(200) --系部描述 )
使用T-SQL语句创建数据库
例:创建一个名为STUDENT的数据库,要求数据库存放在 ‘D:\database‘目录下 CREATE DATABASE STUDENT ON ( NAME= STUDENT, FILENAME =‘D:\database\STUDENT.mdf‘, SIZE=10, MAXSIZE=100 ) 注意:1.选项之间必须以半角逗号分隔 2.如果将数据库文件保存在文件夹中,必须确保文件夹存在
Primary key:主键约束,一个表只能有一个主键,所以 在创建表单时只能出现一次 Foreign key:外键约束,一个表可以定义多个外键约束, 但列级完整性约束控制外键列只能为单一列 Null或Not null:指定表中的属性列是否为空,控制用户 必须输入的列,默认值为Null Unique:唯一性约束,指定表中列保持唯一值即不能 重复 Defalut:默认值 Check(条件表达式):用于校验用户的输入值,拒绝 不满足条件的数据 例:Check(Student_Sex=‘1’ Or Student_Sex=‘0’)
数据库教学资料第6章t-sql语言基础PPT课件
T-SQL是结构化查询语言(SQL)的一个扩展,专门针对Microsoft SQL Server数据库系统。它提供了许多额外 的功能和命令,使得对数据库的操作更加高效和强大。T-SQL具有丰富的语言特性,包括条件语句、循环语句、 存储过程、触发器等,可以用来执行复杂的查询、数据处理和数据库管理任务。
T-SQL语言还支持存储过程、触发 器、视图等高级功能,可以大大简 化复杂的业务逻辑和数据处理流程, 降低系统开发和维护成本。
T-SQL的未来发展前景
1
随着云计算、大数据等技术的快速发展,T-SQL 语言将继续发挥重要作用,支持更多的数据处理 场景和应用领域。
2
未来,T-SQL语言将不断演进和完善,支持更多 的数据类型、函数和操作符,提高数据处理效率 和安全性。
3
变量和常量的声明与赋值
使用DECLARE语句声明变量,使用SET或 SELECT语句为变量赋值。
流程控制语句
IF语句
用于根据条件执行不同的代码块。
WHILE语句
用于重复执行一段代码直到满足特定条件。
CASE语句
用于根据条件执行不同的代码块,类似于IF-ELSE结构。
GOTO语句
用于将程序控制转移到指定的标签位置。
使用存储过程和触发器
存储过程
使用CREATE PROCEDURE语句创建一个 存储过程,该过程可以包含一系列的TSQL语句,用于执行特定的数据库操作。
VS
触发器
使用CREATE TRIGGER语句创建一个触 发器,该触发器将在指定的事件(如 INSERT、UPDATE或DELETE操作)发生 时自动执行相应的操作。
同时,T-SQL语言将与新兴技术如人工智能、机 器学习等相结合,拓展其在数据分析、预测和智 能决策等领域的应用价值。
T-SQL日期函数
T-SQL⽇期函数GETDATE()它将返回当前⽇期和时间。
# 语法上述函数的语法:GETDATE()# 例以下查询将返回当前⽇期以及MS SQL Server中的时间。
Select getdate() as currentdatetimeDATEPART()它将返回⽇期或时间的⼀部分。
# 语法上述函数的语法:DATEPART(datepart, datecolumnname)# 例⽰例1 -以下查询将返回MS SQL Server中当前⽇期的⼀部分。
Select datepart(day, getdate()) as currentdate⽰例2 -以下查询将返回当前⽉份在MS SQL Server中的部分。
Select datepart(month, getdate()) as currentmonthDATEADD()它将通过加或减⽇期和时间间隔显⽰⽇期和时间。
# 语法上述函数的语法:DATEADD(datepart, number, datecolumnname)# 例以下查询将返回MS SQL Server中当前⽇期和时间之后10天的⽇期和时间。
Select dateadd(day, 10, getdate()) as after10daysdatetimefromcurrentdatetimeDATEDIFF()它将显⽰两个⽇期之间的⽇期和时间。
# 语法上述函数的语法:DATEDIFF(datepart, startdate, enddate)# 例以下查询将返回MS SQL Server中2015-11-16和2015-11-11之间的时间差异。
Select datediff(hour, 2015-11-16, 2015-11-11) asdifferencehoursbetween20151116and20151111CONVERT()它将以不同的格式显⽰⽇期和时间。
# 语法上述函数的语法:CONVERT(datatype, expression, style)# 例以下查询将以不同格式在MS SQL Server中返回⽇期和时间。
SQL语句多张表UPDATE语法
SQL语句多张表UPDATE语法多张表UPDATE⽤法sql 语句多张表UPDATE⽤法⼀、当⽤⼀个表中的数据来更新另⼀个表中的数据,T-SQL提供多种写法(下⾯列出了⼆种),但建议⽤第⼀种写法,虽然传统,但结构清晰。
并且要注意,当⽤⼀个表中的数据来更新另⼀个表中的数据时,⼆个表⼀定要有关联!1.update t1 set t1.c2 = t2.c2from t2where t1.c1 = t2.c12.Update t1 set t1.c2 = t2.c2from t1 inner join t2 on t1.c1 = t2.c1⼆、FROM ⼦句中指定的表的别名不能作为 SET column_name ⼦句中被修改字段的限定符使⽤。
UPDATE titlesSET t.ytd_sales = t.ytd_sales + s.qtyFROM titles t, sales sWHERE t.title_id = s.title_idAND s.ord_date = (SELECT MAX(sales.ord_date) FROM sales)若要使上例合法,请从列名中删除别名 t 或使⽤本⾝的表名。
1.UPDATE titlesSET ytd_sales = t.ytd_sales + s.qtyFROM titles t, sales sWHERE t.title_id = s.title_idAND s.ord_date = (SELECT MAX(sales.ord_date) FROM sales)2.UPDATE titlesSET titles.ytd_sales = t.ytd_sales + s.qtyFROM titles t, sales sWHERE t.title_id = s.title_idAND s.ord_date = (SELECT MAX(sales.ord_date) FROM sales)EXAMPLEupdate item_master i set i.contral_ma= ( select max(b.control_ma) from base_complex b where b.code=i.hs_code );更新⼀列:update mytab a set name=(select from goal b where b.id=a.id)where exists (select 1 from goal b where b.id=a.id);更新多列:update mytab aset (name,address)=(select ,b.addressfrom goal bwhere b.id=a.id)where exists (select 1from goal bwhere b.id=a.id )特别是要注意exists后⾯的语句:)这会让⽬标⾏不⾄于为NULL更新update多个关联表的SQL写法:update customers aset city_name=(select b.city_name from tmp_cust_city b where b.customer_id=a.customer_id)where exists (select 1from tmp_cust_city bwhere b.customer_id=a.customer_id)update 超过2个值update customers aset (city_name,customer_type)=(select b.city_name,b.customer_typefrom tmp_cust_city bwhere b.customer_id=a.customer_id)where exists (select 1from tmp_cust_city bwhere b.customer_id=a.customer_id )。
T-sql语句
Transact-SQL语言简介
使用DELETE语句语法格式为: DELETE FROM table_or_view [WHERE <search_condition>] 其中:table_or_view是指要删除数据的表或视图; WHERE子句指定待删除的记录应当满足的条件, WHERE子句省略时,则删除表中的所有记录。 事务管理语言(TML)语言,包括 BEGIN TRANSACTION、 COMMIT TRANSACTION 和 ROLLBACK TRANSACTION 。
Transact-SQL语言简介
举例:首先在pubs数据库的S表中给 public 角色 授予 SELECT 权限,然后,拒绝用户 Mary,John 和 Tom 的特定操作权限。 程序清单如下: USE pubs GO GRANT SELECT ON s TO public GO DENY SELECT, INSERT, UPDATE, DELETE ON s TO Mary,John,Tom
TO <用户名>|<角色>|PUBLIC[,<用户名>|<角色>]… [WITH ADMIN OPTION]
其语义为:将指定的语句权限(对象权限)授予指 定的用户或角色。其中:
(1)PULBIC代表数据库中的全部用户;
(2)WITH ADMIN OPTION为可选项,指定后则允许被授权的用户 将指定的系统特权或角色再授予其他用户或角色。
数据类型限制了在数据库中存储的数值类型。 数据类型就是属性,它指定了一个列、参数或变量 中能够存储什么类型的信息。 SQL Server 提供了供系统使用的基本数据类型
UPDATE table_or_view SET <column>=<expression>[,<column>=<expression>>]…
第4章 T-SQL语言
Select select select select
cast('2008-05-08 12:35:29.1234567' as time(7)) cast('2008-05-08 12:35:29.1234567' as date) cast('2008-05-08 12:35:29.123' as smalldatetime) cast('2008-05-08 12:35:29.123' as datetime)
4.1 T-SQL特点
一体化 两种使用方式,交互和嵌入 非过程化语言 简洁
4.2 T-SQL数据类型
分为系统数据类型和用户自定义数据类型 系统数据类型
数字型:整数,小数,负数、分数等
整数int,bigint,smallint,tinyint 非整型decimal(p,s),float
货币:money,smallmoney 日期:datetime,datetime2,date,time, datetimeoffset,smalldatetime
4.2 T-SQL数据类型--例子
Select cast('2007-05-03 12:35:29' as smalldatetime), cast('2007-05-08 12:35:30' as smalldatetime), cast('2007-05-08 12:59:59.998' as smalldatetime)
应用程序----作为一个批处理; 存储过程或触发器-----作为一个批处理; 由EXECUTE命令语句执行的字符串构成一个批处理
Select * from 客户表 Select * from 工作人员表 go
快速理解T-SQL中的创建数据库Create database语法
快速理解T-SQL中的创建数据库Create database语法联机帮助的语法完整如下,看了就晕:CREATE DATABASE database_name[ ON[ < filespec > [ ,...n ] ][ , < filegroup > [ ,...n ] ]][ LOG ON { < filespec > [ ,...n ] } ][ COLLATE collation_name ][ FOR LOAD | FOR ATTACH ]< filespec > ::=[ PRIMARY ]( [ NAME = logical_file_name , ]FILENAME ='os_file_name'[ , SIZE = size ][ , MAXSIZE = { max_size | UNLIMITED } ][ , FILEGROWTH = growth_increment ] ) [ ,...n ]< filegroup > ::=FILEGROUP filegroup_name < filespec > [ ,...n ]其实,绿色部分才是建库的语法,下面< filespec > ::=和< filegroup > ::=只是替代语法中的部分。
还原以后就是:CREATE DATABASE database_name[ ON[ PRIMARY ]( [ NAME = logical_file_name , ]FILENAME ='os_file_name'[ , SIZE = size ][ , MAXSIZE = { max_size | UNLIMITED } ][ , FILEGROWTH = growth_increment ] )[ ,...n ] --注意,多个此文件组间有逗号分隔,但和下面的LOG ON没有逗号[ , < filegroup > [ ,...n ] ] --替代方法也是一样。
T-SQL语法格式
● 方括号“[]”:它所列出的项为可选项,用户可根 据需要选择使用。
● 竖线“︱”:表示参数之间是“或”关系, 可以从中任意选择使用一个。
● 省略号“…”:表示重复前面的语法单元。
● 注释:为T_SQL脚本代码中的说明信息, SQL Server不解释这部分内容。SQL Server支持 以下两种注释格式。
● 单行注释:使用两个连字符“——”作为注 释的开始标志,从“——”到本行行尾的所有内 容均为注释信息,例如:
—— Choose the pubs database.
Use pubs
SELECT * FROM table
——the result
ห้องสมุดไป่ตู้
● 块注释:块注释的格式为“/*注释内容*/”, 其间的所有内容均为注释信息。块注释与单行注 释不同的是它可以跨越多行,并且可以插入在程 序代码中的任何地方。
需要注意的是,SQL Server中对于标识符的命名 规定如下:标识符的首字符必须是字母、下划线、 @字符或#字符。当一个标识符以@开头时,表 示它是一个局部变量。当一个标识符以#字符开 头时,表示它是一个局部临时表或是存储过程。 标识符中的其他字符可以是字母、数字、下划线、 @字符、#字符或$字符。最大长度一般不超过 128个字符。 返回
网络数据库技术与应用
T-SQL语法格式
完整的SQL语句中包括关键字、用户自定义参数以及各 种表达式。T-SQL 采用不同的书写格式来区分这些内 容,这些语法格式的约定如下:
● 关键字是SQL语言中的固定部分,并有固定的含义, 书写时常用大写字母表示。
T-SQL控制流程语句
T-SQL语言基础
4.While
While语句通过逻辑表达式来设置一个条件,当条件成立时,重复执行一个语句或语句块 (重复执行的部分称为循环体),条件不成立时退出循环,继续执行后面的语句,其语 法格式如下:While <逻辑表达式> Begin <命令行或程序块> [Continue] <命令行或程序块>
Begin <命令行或程序块> End
T-SQL语言基础
【例6-10】 下面的SQL语句是一个Begin…End的例子。 Begin Declare @myvar float Set @myvar =456.256
Begin Print '变量@myvar的值为:' Print @myvar
End End 运行结果如图6-8所示。
数据库基础
T-SQL语言基础
图6-8 T-SQL中的Begin…End语句
T-SQL语言基础
3.Case
Case表达式用来简化SQL表达式,它可以用在任何允许使用表达式的地方 ,并根据条件的不同返回不同的值。Case表达式不同于一个T-SQL语句, 它不能够单独执行,而只能作为一个可以单独执行的语句的一部分来使用 。
数据库基础
T-SQL语言基础
T-SQL 语言使用的流程控制命令与常见的程序设计语言类似,主要有以下几种。 1.If…Else 其语法如下: If <条件表达式> <命令行或程序块> [Else [条件表达式] <命令行或程序块>]
数据库系统技术 项目五 使用T-SQL命令定义数据库和表
T-SQL语言即事务SQL(Transact-SQL),简称为T-SQL。TSQL在SQL语言的基础上增加了变量、流程控制、功能函数、 系统存储过程等功能,提供了丰富的编程结构。 T-SQL是对SQL语言扩充的基础上发展起来的,因此它的核心 内容还是SQL语言中的四类语句。
T-SQL语言的开发环境
根据功能来划分SQL语言分为四类
SQL功能名称 数据查询 数据操纵
SQL功能英文简称和全称
DQL(Data Query Language) DML(Data Manipulation Language)
SQL语句
SELECT INSERT UPDATE DELETE
数据定义
DQL(Data Definition Language)
省略号“…”:表示重复前面的语法项目。
项目五 使用T-SQL命令定义数据库和表
1 2
了解T-SQL语言 T-SQL语言基础 使用T-SQL命令定义数据库 使用T-SQL命令定义表
3 4
T-SQL语言基础
T-SQL中的常量和变量
T-SQL中的运算符 T-SQL中的函数 T-SQL中的批处理 T-SQL中的流程控制语句 T-SQL中的功能性语句
创建数据库命令createdatabase创建数据库命令createdatabase最简单的createdatabase命令格式createdatabasedatabasenamecreatedatabasedatabasename指定数据库文件名称和位置的createdatabase命令格式createdatabasedatabasenameprimary这里的关键字primary可省略用于主文件的定义namelogicalfilename设置主数据文件的逻辑名称filenameosfilename设置主数据文件的操作系统名称logon用于日志文件的定义namelogicalfilename设置日志文件的逻辑名称filenameosfilename设置日志文件的操作系统名称createdatabasedatabasenameprimary这里的关键字primary可省略用于主文件的定义namelogicalfilename设置主数据文件的逻辑名称filenameosfilename设置主数据文件的操作系统名称logon用于日志文件的定义namelogicalfilename设置日志文件的逻辑名称filenameosfilename设置日志文件的操作系统名称创建数据库命令createdatabase创建数据库命令createdatabase演示教材中例514至例516创建数据库命令之完整格式创建数据库命令之完整格式createdatabase数据库名collatecollationnameon
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
T-SQL语法大全SELECT --从数据库表中检索数据行和列INSERT --向数据库表添加新数据行DELETE --从数据库表中删除数据行UPDATE --更新数据库表中的数据--数据定义CREATE TABLE --创建一个数据库表DROP TABLE --从数据库中删除表ALTER TABLE --修改数据库表结构CREATE VIEW --创建一个视图DROP VIEW --从数据库中删除视图CREATE INDEX --为数据库表创建一个索引DROP INDEX --从数据库中删除索引CREATE PROCEDURE --创建一个存储过程DROP PROCEDURE --从数据库中删除存储过程CREATE TRIGGER --创建一个触发器DROP TRIGGER --从数据库中删除触发器CREATE SCHEMA --向数据库添加一个新模式DROP SCHEMA --从数据库中删除一个模式CREATE DOMAIN --创建一个数据值域ALTER DOMAIN --改变域定义DROP DOMAIN --从数据库中删除一个域-- 数据控制GRANT --授予用户访问权限DENY --拒绝用户访问REVOKE --解除用户访问权限--事务控制COMMIT --结束当前事务ROLLBACK --中止当前事务SET TRANSACTION --定义当前事务数据访问特征--程序化SQLDECLARE --为查询设定游标EXPLAN --为查询描述数据访问计划OPEN --检索查询结果打开一个游标FETCH --检索一行查询结果CLOSE --关闭游标PREPARE --为动态执行准备SQL 语句EXECUTE --动态地执行SQL 语句DESCRIBE --描述准备好的查询---局部变量declare @id char(10)--set @id = '10010001'select @id = '10010001'---全局变量---必须以@@开头--IF ELSEdeclare @x int @y int @z intselect @x = 1 @y = 2 @z=3if @x > @yprint 'x > y' --打印字符串'x > y'else if @y > @zprint 'y > z'else print 'z > y'--CASEuse panguupdate employeeset e_wage =casewhen job_level = ’1’ then e_wage*1.08w hen job_level = ’2’ then e_wage*1.07 when job_level = ’3’ then e_wage*1.06 else e_wage*1.05end--WHILE CONTINUE BREAKdeclare @x int @y int @c intselect @x = 1 @y=1while @x < 3beginprint @x --打印变量x 的值while @y < 3beginselect @c = 100*@x + @yprint @c --打印变量c 的值select @y = @y + 1endselect @x = @x + 1select @y = 1end--WAITFOR--例等待1 小时2 分零3 秒后才执行SELECT 语句waitfor delay ’01:02:03’select * from employee--例等到晚上11 点零8 分后才执行SELECT 语句waitfor time ’23:08:00’select * from employee***SELECT***select *(列名) from table_name(表名) where column_name operator valueex:(宿主)select * from stock_information where stockid = str(nid)stockname = 'str_name'stockname like '% find this %'stockname like '[a-zA-Z]%' --------- ([]指定值的范围)stockname like '[^F-M]%' --------- (^排除指定范围)--------- 只能在使用like关键字的where子句中使用通配符)or stockpath = 'stock_path'or stocknumber < 1000and stockindex = 24not stocksex = 'man'stocknumber between 20 and 100stocknumber in(10,20,30)order by stockid desc(asc) --------- 排序,desc-降序,asc-升序order by 1,2 --------- by列号stockname = (select stockname from stock_information where stockid = 4)--------- 子查询--------- 除非能确保内层select只返回一个行的值,--------- 否则应在外层where子句中用一个in限定符select distinct column_name form table_name --------- distinct指定检索独有的列值,不重复select stocknumber ,"stocknumber + 10" = stocknumber + 10 from table_name select stockname , "stocknumber" = count(*) from table_name group by stockname--------- group by 将表按行分组,指定列中有相同的值having count(*) = 2 --------- having选定指定的组select *from table1, table2where table1.id *= table2.id -------- 左外部连接,table1中有的而table2中没有得以null表示table1.id =* table2.id -------- 右外部连接select stockname from table1union [all] ----- union合并查询结果集,all-保留重复行select stockname from table2***insert***insert into table_name (Stock_name,Stock_number) value ("xxx","xxxx")value (select Stockname , Stocknumber from Stock_table2)---value为select语句***update***update table_name set Stockname = "xxx" [where Stockid = 3]Stockname = defaultStockname = nullStocknumber = Stockname + 4***delete***delete from table_name where Stockid = 3truncate table_name ----------- 删除表中所有行,仍保持表的完整性drop table table_name --------------- 完全删除表***alter table*** --- 修改数据库表结构alter table database.owner.table_name add column_name char(2) null .....sp_help table_name ---- 显示表已有特征create table table_name (name char(20), age smallint, lname varchar(30))insert into table_name select ......... ----- 实现删除列的方法(创建新表)alter table table_name drop constraint Stockname_default ---- 删除Stockname的defaul t约束***function(/*常用函数*/)***----统计函数----AVG --求平均值COUNT --统计数目MAX --求最大值MIN --求最小值SUM --求和--AVGuse panguselect avg(e_wage) as dept_avgWagefrom employeegroup by dept_id--MAX-- 求工资最高的员工姓名use panguselect e_namefrom employeewhere e_wage =(select max(e_wage)from employee)--STDEV()--STDEV() 函数返回表达式中所有数据的标准差--STDEVP()--STDEVP()函数返回总体标准差--VAR()--VAR() 函数返回表达式中所有值的统计变异数--VARP()--VARP()函数返回总体变异数----算术函数----/***三角函数***/SIN(float_expression) --返回以弧度表示的角的正弦COS(float_expression) --返回以弧度表示的角的余弦TAN(float_expression) --返回以弧度表示的角的正切COT(float_expression) --返回以弧度表示的角的余切/***反三角函数***/ASIN(float_expression) --返回正弦是FLOAT 值的以弧度表示的角ACOS(float_expression) --返回余弦是FLOAT 值的以弧度表示的角ATAN(float_expression) --返回正切是FLOAT 值的以弧度表示的角ATAN2(float_expression1,float_expression2)--返回正切是float_expression1 /float_expres-sion2的以弧度表示的角DEGREES(numeric_expression)--把弧度转换为角度返回与表达式相同的数据类型可为--INTEGER/MONEY/REAL/FLOAT 类型RADIANS(numeric_expression) --把角度转换为弧度返回与表达式相同的数据类型可为--INTEGER/MONEY/REAL/FLOAT 类型EXP(float_expression) --返回表达式的指数值LOG(float_expression) --返回表达式的自然对数值LOG10(float_expression)-- 返回表达式的以10 为底的对数值SQRT(float_expression) --返回表达式的平方根/***取近似值函数***/CEILING(numeric_expression) --返回>=表达式的最小整数返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT 类型FLOOR(numeric_expression) --返回<=表达式的最小整数返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT 类型ROUND(numeric_expression) --返回以integer_expression 为精度的四舍五入值返回的数据--类型与表达式相同可为INTEGER/MONEY/REAL/FLOAT 类型ABS(numeric_expression) --返回表达式的绝对值返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT 类型SIGN(numeric_expression) --测试参数的正负号返回0 零值1 正数或-1 负数返回的数据类型--与表达式相同可为INTEGER/MONEY/REAL/FLOAT 类型PI() --返回值为π 即3.1415926535897936RAND([integer_expression]) --用任选的[integer_expression]做种子值得出0-1 间的随机浮点数----字符串函数----ASCII() --函数返回字符表达式最左端字符的ASCII 码值CHAR() --函数用于将ASCII 码转换为字符--如果没有输入0 ~ 255 之间的ASCII 码值CHAR 函数会返回一个NULL 值LOWER() --函数把字符串全部转换为小写UPPER() --函数把字符串全部转换为大写STR() --函数把数值型数据转换为字符型数据LTRIM() --函数把字符串头部的空格去掉RTRIM() --函数把字符串尾部的空格去掉LEFT(),RIGHT(),SUBSTRING() --函数返回部分字符串CHARINDEX(),PATINDEX() --函数返回字符串中某个指定的子串出现的开始位置SOUNDEX() --函数返回一个四位字符码--SOUNDEX函数可用来查找声音相似的字符串但SOUNDEX函数对数字和汉字均只返回0 值DIFFERENCE() --函数返回由SOUNDEX 函数返回的两个字符表达式的值的差异--0 两个SOUNDEX 函数返回值的第一个字符不同--1 两个SOUNDEX 函数返回值的第一个字符相同--2 两个SOUNDEX 函数返回值的第一二个字符相同--3 两个SOUNDEX 函数返回值的第一二三个字符相同--4 两个SOUNDEX 函数返回值完全相同QUOTENAME() --函数返回被特定字符括起来的字符串/*select quotename('abc', '{') quotename('abc')运行结果如下----------------------------------{{abc} [abc]*/REPLICATE() --函数返回一个重复character_expression 指定次数的字符串/*select replicate('abc', 3) replicate( 'abc', -2)运行结果如下----------- -----------abcabcabc NULL*/REVERSE() --函数将指定的字符串的字符排列顺序颠倒REPLACE() --函数返回被替换了指定子串的字符串/*select replace('abc123g', '123', 'def')运行结果如下----------- -----------abcdefg*/SPACE() --函数返回一个有指定长度的空白字符串STUFF() --函数用另一子串替换字符串指定位置长度的子串----数据类型转换函数----CAST() 函数语法如下CAST() (<expression> AS <data_ type>[ length ])CONVERT() 函数语法如下CONVERT() (<data_ type>[ length ], <expression> [, style])select cast(100+99 as char) convert(varchar(12), getdate())运行结果如下------------------------------ ------------199 Jan 15 2000----日期函数----DAY() --函数返回date_expression 中的日期值MONTH() --函数返回date_expression 中的月份值YEAR() --函数返回date_expression 中的年份值DATEADD(<datepart> ,<number> ,<date>)--函数返回指定日期date 加上指定的额外日期间隔number 产生的新日期DATEDIFF(<datepart> ,<number> ,<date>)--函数返回两个指定日期在datepart 方面的不同之处DATENAME(<datepart> , <date>) --函数以字符串的形式返回日期的指定部分DATEPART(<datepart> , <date>) --函数以整数值的形式返回日期的指定部分GETDATE() --函数以DATETIME 的缺省格式返回系统当前的日期和时间----系统函数----APP_NAME() --函数返回当前执行的应用程序的名称COALESCE() --函数返回众多表达式中第一个非NULL 表达式的值COL_LENGTH(<'table_name'>, <'column_name'>) --函数返回表中指定字段的长度值COL_NAME(<table_id>, <column_id>) --函数返回表中指定字段的名称即列名DATALENGTH() --函数返回数据表达式的数据的实际长度DB_ID(['database_name']) --函数返回数据库的编号DB_NAME(database_id) --函数返回数据库的名称HOST_ID() --函数返回服务器端计算机的名称HOST_NAME() --函数返回服务器端计算机的名称IDENTITY(<data_type>[, seed increment]) [AS column_name])--IDENTITY() 函数只在SELECT INTO 语句中使用用于插入一个identity column列到新表中/*select identity(int, 1, 1) as column_nameinto newtablefrom oldtable*/ISDATE() --函数判断所给定的表达式是否为合理日期ISNULL(<check_expression>, <replacement_value>) --函数将表达式中的NULL 值用指定值替换ISNUMERIC() --函数判断所给定的表达式是否为合理的数值NEWID() --函数返回一个UNIQUEIDENTIFIER 类型的数值NULLIF(<expression1>, <expression2>)--NULLIF 函数在expression1 与expression2 相等时返回NULL 值若不相等时则返回expression 1 的值====精妙SQL语句====说明:复制表(只复制结构,源表名:a 新表名:b)SQL: select * into b from a where 1<>1说明:拷贝表(拷贝数据,源表名:a 目标表名:b)SQL: insert into b(a, b, c) select d,e,f from b;说明:显示文章、提交人和最后回复时间SQL: select a.title,ername,b.adddatefrom table a,(select max(adddate) adddate from table where table.title=a.title) b说明:外连接查询(表名1:a 表名2:b)SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c说明:日程安排提前五分钟提醒SQL: select * from 日程安排where datediff('minute',f开始时间,getdate())>5说明:两张关联表,删除主表中已经在副表中没有的信息SQL:delete from info where not exists ( select * from infobz where info.infid=infobz.infid )---------数学函数1.绝对值S:select abs(-1) valueO:select abs(-1) value from dual2.取整(大)S:select ceiling(-1.001) valueO:select ceil(-1.001) value from dual3.取整(小)S:select floor(-1.001) valueO:select floor(-1.001) value from dual4.取整(截取)S:select cast(-1.002 as int) valueO:select trunc(-1.002) value from dual5.四舍五入S:select round(1.23456,4) value 1.23460O:select round(1.23456,4) value from dual 1.23466.e为底的幂S:select Exp(1) value 2.7182818284590451O:select Exp(1) value from dual 2.718281827.取e为底的对数S:select log(2.7182818284590451) value 1O:select ln(2.7182818284590451) value from dual; 18.取10为底对数S:select log10(10) value 1O:select log(10,10) value from dual; 19.取平方S:select SQUARE(4) value 16O:select power(4,2) value from dual 1610.取平方根S:select SQRT(4) value 2O:select SQRT(4) value from dual 211.求任意数为底的幂S:select power(3,4) value 81O:select power(3,4) value from dual 81S:select rand() valueO:select sys.dbms_random.value(0,1) value from dual;13.取符号S:select sign(-8) value -1O:select sign(-8) value from dual -1----------数学函数14.圆周率S:SELECT PI() value 3.1415926535897931O:不知道15.sin,cos,tan 参数都以弧度为单位例如:select sin(PI()/2) value 得到1(SQLServer)16.Asin,Acos,Atan,Atan2 返回弧度17.弧度角度互换(SQLServer,Oracle不知道) DEGREES:弧度-〉角度RADIANS:角度-〉弧度---------数值间比较18. 求集合最大值S:select max(value) value from(select 1 valueunionselect -2 valueunionselect 4 valueunionselect 3 value)aO:select greatest(1,-2,4,3) value from dual19. 求集合最小值S:select min(value) value from(select 1 valueunionselect -2 valueunionselect 4 valueunionselect 3 value)aO:select least(1,-2,4,3) value from dual20.如何处理null值(F2中的null以10代替)S:select F1,IsNull(F2,10) value from TblO:select F1,nvl(F2,10) value from Tbl--------数值间比较S:select ascii('a') valueO:select ascii('a') value from dual22.从序号求字符S:select char(97) valueO:select chr(97) value from dual23.连接S:select '11'+'22'+'33' valueO:select CONCAT('11','22')||33 value from dual23.子串位置--返回3S:select CHARINDEX('s','sdsq',2) valueO:select INSTR('sdsq','s',2) value from dual23.模糊子串的位置--返回2,参数去掉中间%则返回7S:select patindex('%d%q%','sdsfasdqe') valueO:oracle 没发现,但是instr可以通过第四霾问 刂瞥鱿执问?BR> select INSTR('sdsfasdqe','sd', 1,2) value from dual 返回624.求子串S:select substring('abcd',2,2) valueO:select substr('abcd',2,2) value from dual25.子串代替返回aijklmnefS:SELECT STUFF('abcdef', 2, 3, 'ijklmn') valueO:SELECT Replace('abcdef', 'bcd', 'ijklmn') value from dual26.子串全部替换S: 没发现O:select Translate('fasdbfasegas','fa','我' ) value from dual27.长度S:len,datalengthO:length28.大小写转换lower,upper29.单词首字母大写S: 没发现O:select INITCAP('abcd dsaf df') value from dual30.左补空格(LPAD的第一个参数为空格则同space函数)S:select space(10)+'abcd' valueO:select LPAD('abcd',14) value from dual31.右补空格(RPAD的第一个参数为空格则同space函数)S:select 'abcd'+space(10) valueO:select RPAD('abcd',14) value from dual32.删除空格S:ltrim,rtrimO:ltrim,rtrim,trim33. 重复字符串S:select REPLICATE('abcd',2) valueO:没发现34.发音相似性比较(这两个单词返回值一样,发音相同)S:SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe')O:SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe') from dualSQLServer中用SELECT DIFFERENCE('Smithers', 'Smythers') 比较soundex的差返回0-4,4为同音,1最高-------------- 日期函数35.系统时间S:select getdate() valueO:select sysdate value from dual36.前后几日直接与整数相加减37.求日期S:select convert(char(10),getdate(),20) valueO:select trunc(sysdate) value from dualselect to_char(sysdate,'yyyy-mm-dd') value from dual38.求时间S:select convert(char(8),getdate(),108) valueO:select to_char(sysdate,'hh24:mm:ss') value from dual39.取日期时间的其他部分S:DATEPART 和DATENAME 函数(第一个参数决定)O:to_char 函数第二个参数决定参数---------------------------------下表需要补充year yy, yyyyquarter qq, q (季度)month mm, m (m O无效)dayofyear dy, y (O表星期)day dd, d (d O无效)week wk, ww (wk O无效)weekday dw (O不清楚)Hour hh,hh12,hh24 (hh12,hh24 S无效)minute mi, n (n O无效)second ss, s (s O无效)millisecond ms (O无效)----------------------------------------------40.当月最后一天S:不知道O:select LAST_DAY(sysdate) value from dual41.本星期的某一天(比如星期日)S:不知道O:SELECT Next_day(sysdate,7) vaule FROM DUAL;42.字符串转时间S:可以直接转或者select cast('2004-09-08'as datetime) valueO:SELECT To_date('2004-01-05 22:09:38','yyyy-mm-dd hh24-mi-ss') vaule FROM DUA L;43.求两日期某一部分的差(比如秒)S:select datediff(ss,getdate(),getdate()+12.3) valueO:直接用两个日期相减(比如d1-d2=12.3)SELECT (d1-d2)*24*60*60 vaule FROM DUAL;44.根据差值求新的日期(比如分钟)S:select dateadd(mi,8,getdate()) valueO:SELECT sysdate+8/60/24 vaule FROM DUAL;45.求不同时区时间S: 不知道O:SELECT New_time(sysdate,'ydt','gmt' ) vaule FROM DUAL;-----时区参数,北京在东8区应该是Ydt-------AST ADT 大西洋标准时间BST BDT 白令海标准时间CST CDT 中部标准时间EST EDT 东部标准时间GMT 格林尼治标准时间HST HDT 阿拉斯加—夏威夷标准时间MST MDT 山区标准时间NST 纽芬兰标准时间PST PDT 太平洋标准时间YST YDT YUKON标准时间sql中的保留字action add aggregate allalter after and asasc avg avg_row_length auto_incrementbetween bigint bit binaryblob bool both bycascade case char characterchange check checksum columncolumns comment constraint createcross current_date current_time current_timestampdata database databases datedatetime day day_hour day_minuteday_second dayofmonth dayofweek dayofyeardec decimal default delayeddelay_key_write delete desc describedistinct distinctrow double dropend else escape escapedenclosed enum explain existsfields file first floatfloat4 float8 flush foreignfrom for full functionglobal grant grants grouphaving heap high_priority hourhour_minute hour_second hosts identifiedignore in index infileinner insert insert_id intinteger interval int1 int2int3 int4 int8 intoif is isam joinkey keys kill last_insert_idleading left length likelines limit load locallock logs long longbloblongtext low_priority max max_rowsmatch mediumblob mediumtext mediumintmiddleint min_rows minute minute_secondmodify month monthname myisamnatural numeric no notnull on optimize optionoptionally or order outeroutfile pack_keys partial passwordprecision primary procedure processprocesslist privileges read realreferences reload regexp renamereplace restrict returns revokerlike row rows secondselect set show shutdownsmallint soname sql_big_tables sql_big_selectssql_low_priority_updates sql_log_off sql_log_updatesql_select_limitsql_small_result sql_big_result sql_warnings straight_join starting status string tabletables temporary terminated textthen time timestamp tinyblobtinytext tinyint trailing totype use using uniqueunlock unsigned update usagevalues varchar variables varying varbinary with write when where year year_month zerofill。