什么是T-SQL?-mysql教程-学派吧

Transact-SQL通常缩写为T-SQL,或者TSQL,是Microsoft和Sybase对SQL的专有扩展。Transact-SQL对SQL标准进行扩展,以包含SQL标准中不包含的额外特性。

什么是T-SQL?-mysql教程-学派吧

下面是一个简单的T-SQL语句的例子:

CREATE DATABASE Movies;

这是一个简单的T-SQL示例。这将创建一个名为Movies的新数据库。

但是,T-SQL提供了在此语句中包含的其他选项,例如数据库文件应该位于何处、这些文件的大小、它们的最大大小应该是多少,等等。

T-SQL的一些特性包括:

1、程序编程

2、局部变量

3、支持字符串处理、数据处理、数学等多种功能

4、对DELETE和UPDATE语句的更改。特别是,它们允许添加FROM子句,这允许包含连接。

5、T-SQL有一个BULK INSERT批量插入语句,允许你以用户指定的格式将数据文件导入数据库表或视图。

上述扩展的主要好处之一是,在使用T-SQL和SQL时,你有更多的可编程性。例如,存储过程允许你将编程逻辑合并到数据库中。你可以将一个或多个参数传递给存储过程,存储过程将返回一个输出,该输出根据参数的值而变化。

T-SQL还包含大量内置函数,以及支持用户定义的函数。

一个内置函数的例子

下面是另一个基本的例子,这次使用的是T-SQL的内置函数之一:

SELECT GETDATE();

输出:

2018-05-06 23:30:37.003

在本例中,我们使用T-SQL的GETDATE()函数返回当前日期和时间。这与SELECT语句一起使用,SELECT语句是返回数据的常用SQL语句。

我们也可以用这个函数作为另一个函数的参数。这里有一个例子:

SELECT FORMAT(GETDATE(), 'MMM');

结果:

May

T-SQL的历史

虽然Transact-SQL(和SQL Server)最广为人知的名称是Microsoft,但它实际上是Microsoft和Sybase于1987年开始合作的结果。这一伙伴关系于1994年解散。

此后,T-SQL继续得到两家公司发布的数据库产品的支持,但是,每家公司都按照自己的方向开发了自己的数据库产品。因此,Sybase T-SQL和Microsoft T-SQL之间存在一些差异。

T-SQL和GUI工具

Transact-SQL是SQL Server的核心。SQL Server中的大多数操作都是使用T-SQL完成的。即使您使用GUI工具(如SSMS或DBeaver)而实际上不进行任何编程,这也是正确的。无论何时使用应用程序与SQL Server交互,应用程序都会在后台使用T-SQL执行指定的任务。

但SQL Server并不是唯一支持Transact-SQL的数据库管理系统。Microsoft Azure SQL数据库也支持T-SQL。应用程序使用的大多数T-SQL特性在Microsoft SQL Server和Azure SQL数据库中都得到了完全支持(尽管有一些例外)。

关于GO命令

任何使用过T-SQL的人都可能熟悉GO命令。这个关键字通常放在一批语句的末尾。例如,上面的第一个例子也可以这样写:

CREATE DATABASE Movies;
GO

然而,GO命令实际上不是Transact-SQL的一部分。事实上,GO命令甚至不能占用Transact-SQL语句的同一行。

GO是sqlcmd和osql实用程序以及SQL Server Management Studio代码编辑器可以识别的命令之一,这些命令可以促进批处理和脚本的可读性和执行。GO命令将一批Transact-SQL语句的结束信号发送给SQL Server实用程序。

SQL Server实用程序将GO解释为一个信号,表示它们应该将当前这批Transact-SQL语句发送到SQL Server的一个实例。当前这批语句由自上次执行操作以来输入的所有语句组成,如果这是第一次执行操作,则由自特别会话或脚本开始执行以来输入的所有语句组成。

其他专有SQL扩展

Transact-SQL不是SQL标准的唯一扩展。各种数据库系统都有自己的扩展。例如,Oracle使用一种私有的过程语言PL/SQL, PostgreSQL使用一种过程语言PL/pgSQL。

尽管专有SQL扩展有其优点(比如扩展功能),但它们也有缺点。一个主要缺点是,如果你需要将数据库从一个系统移植到另一个系统,它们可能会使事情变得困难。例如,如果你的组织突然决定使用Oracle而不是SQL Server,你可能需要遍历所有SQL Server代码并为Oracle重写它。这还要求你熟悉这两个系统的语法。

相关推荐:《MySQL教程》

以上就是什么是T-SQL?的详细内容,更多请关注php中文网其它相关文章!

主题测试文章,只做测试使用。发布者:云大使,转转请注明出处:https://www.xp8.net/data/3461.html

(0)
打赏 微信扫一扫 微信扫一扫
云大使的头像云大使
上一篇 2019年4月9日 下午8:57
下一篇 2019年4月9日 下午8:57

相关推荐

  • centos解决mysql-bin.000*占用超大空间的问题

    本站(也就是安全者)网站数据库挂了一下午,也没时间处理,晚上回来后尝试restart mysql,发现一直提示shutting down……….关闭不了,也stop不了,服务器重启也不行。可以确信肯定是mysql出问题了。 进入mysql的data目录一大堆名字为mysql-bin.000001 — mysql…

    数据库运维 2018年7月9日
    2.3K00
  • 宝塔centos系统导入-ssh命令导入mysql大数据库文件方法教程

    今天主要写mysql在centos下 通过命令导出  导入教程分享 服务器:腾讯云https://curl.qcloud.com/zdLkHNeS 开始: 备份: mysqldump -u数据库名 -p”密码” -h localhost 数据名 > /www/wwwroot/ceshi.com/aiqutui.sq(备份路径) 恢复命令: m…

    2019年4月10日
    4.3K00
  • mysql的20条优化教程-mysql教程-学派吧

    本篇文章给大家带来的内容是关于mysql的优化总结,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 前言 现如今,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显。所以,我整理了MySQL优化的几点建议,希望这些优化技巧对您有用,总结不到的,欢迎大家补充。 SQL执行慢的原因 网络速度慢,内存不足,I/O吞吐量小,磁盘空…

    数据库运维 2018年11月24日
    2.6K00
  • MySQL执行过程以及查询缓存的详细介绍-mysql教程-学派吧

    本篇文章给大家带来的内容是关于MySQL执行过程以及查询缓存的详细介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 MySQL执行一个查询过程:当我们向MySQL发送一个请求的时候,MySQL到底做了什么: 1.客户端发送一条查询给服务器2.服务器先检查查询缓存,如果命中了缓存,则立刻返回存储在缓存中的结果。否则进入下一阶段。3.服务器端…

    2019年4月9日
    1.9K00
  • MYSQL查询怎么优化?mysql查询优化的方法教程-mysql教程-学派吧

    本篇文章给大家带来的内容是关于python中进程池的简单实现代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助 1. 在所有用于where,order by和group by的列上添加索引 索引除了能够确保唯一的标记一条记录,还能是MySQL服务器更快的从数据库中获取结果。索引在排序中的作用也非常大。 Mysql的索引可能会占据额外的空间,并…

    数据库运维 2018年11月24日
    2.4K00

发表回复

登录后才能评论
联系我们

联系我们

18838889666

在线咨询: QQ交谈

邮件:xinyun@88.com

工作时间:周一至周五,9:30-18:30,节假日休息

添加微信
添加微信
分享本页
返回顶部
---------官方优惠叠加渠道折扣:通过我们购买腾讯云/阿里云,价格更低,服务更优。更有专业配置指导与服务。微信同步:18838889666----