SQL SERVER 中存储过程和函数的区别

如题所述

一、多数指令是相同的,包括创建和修正存储过程的指令。二、很多细微的指令有不同,具体如下(不仅):1mysql支持enum,和set类型,sqlserver不支持2mysql不支持nchar,nvarchar,ntext类型3mysql的递增语句是AUTO_INCREMENT,而mssql是identity(1,1)MYSQL:createtablebasic(idintkeyauto_increment,namevarchar(20));MSSQL:createtablebasic(idintidentity(1,1),namevarchar(20))4msms默认到处表创建语句的默认值表示是((0)),而在mysql里面是不允许带两括号的5mysql需要为表指定存储类型6mssql识别符是[],[type]表示他区别于关键字(可选用来包含表名、字段名),但是mysql却是`(重音符,也就是按键1左边的那个符号)7mssql支持getdate()方法获取当前时间日期,但是mysql里面可以分日期类型和时间类型,获取当前日期是cur_date(),当前完整时间是now()函数8mssql不支持replaceinto语句,但是在最新的sql20008里面,也支持merge语法9mysql支持insertintotable1sett1=‘’,t2=‘’,但是mssql不支持这样写10mysql插入多行支持这样写insertintotabl1values(1,1),(1,1),(1,1),(1,1),(1,1),(1,1),(1,1)MSSQL不支持11mssql不支持limit语句,是非常遗憾的,只能用top取代limt0,N,row_number()over()函数取代limitN,M12mysql在创建表时要为每个表指定一个存储引擎类型,而mssql只支持一种存储引擎13mysql不支持默认值为当前时间的datetime类型(mssql很容易做到),在mysql里面是用timestamp类型14mssql里面检查是否有这个表再删除,需要这样:ifexists(select*fromdbo.sysobjectswhereid=object_id(N'uc_newpm')andOBJECTPROPERTY(id,N'IsUserTable')=1)但是在mysql里面只需要DROPTABLEIFEXISTScdb_forums;15mysql支持无符号型的整数,那么比不支持无符号型的mssql就能多出一倍的最大数存储16mysql不支持在mssql里面使用非常方便的varchar(max)类型,这个类型在mssql里面既可做一般数据存储,也可以做blob数据存储17mysql创建非聚集索引只需要在创建表的时候指定为key就行,比如:KEYdisplayorder(fid,displayorder)在mssql里面必须要:createuniquenonclusteredindexindex_uc_protectedmembers_username_appidondbo.uc_protectedmembers(usernameasc,appidasc)18mysqltext字段类型不允许有默认值19mysql的一个表的总共字段长度不超过65XXX。20一个很表面的区别就是mysql的安装特别简单,而且文件大小才110M(非安装版),相比微软这个庞然大物,安装进度来说简直就是..21mysql的管理工具有几个比较好的,mysql_front,和官方那个套件,不过都没有SSMS的使用方便,这是mysql很大的一个缺点。22mysql的存储过程只是出现在最新的版本中,稳定性和性能可能不如mssql。23同样的负载压力,mysql要消耗更少的CPU和内存,mssql的确是很耗资源。24php连接mysql和mssql的方式都差不多,只需要将函数的mysql替换成mssql即可。25mysql支持date,time,year类型,mssql到2008才支持date和time。26变量赋值MYsql:变量赋值SELECT@min_price:=MIN(price),@max_price:=MAX(price)FROMshopMSsql:变量赋值SELECT@min_price=MIN(price),@max_price=MAX(price)FROMshop三、总的来说,如果是简单的存储过程代码,要修改,不会太难。如果是复杂的系统,要移植会很难很难。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2023-04-07

Sql Server 数据库中的存储过程:

解析SQL存储过程:

存储过程(Stored Procedure),是一组为了完成特定功能的SQL 语句,类似一门程序设计语言,也包括了数据类型、流程控制、输入和输出和它自己的函数库。存储过程可以说是一个记录集,它是由一些T-SQL语句组成的代码块,这些T-SQL语句代码像一个方法一样实现一些功能(对单表或多表的增删改查),然后再给这个代码块取一个名字,在用到这个 功能的时候调用他就行了。不过SQL存储过程对于一些初学者来说还是比较抽象难理解的,因此本文将由浅至深地剖析SQL存储过程,帮助你学习它。

存储过程的优点:

    存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度,效率要比T-SQL语句高。

    当对数据库进行复杂操作时,可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。

    一个存储过程在程序在网络中交互时可以替代大堆的T-SQL语句,所以也能降低网络的通信量,提高通信速率。

    存储过程可以重复使用,可减少数据库开发人员的工作量。

    安全性高,可设定只有某些用户才具有对指定存储过程的使用权

    存储过程的缺点:

    存储过程将给server带来额外的压力。

    存储过程多多时维护比较困难。

    移植性差。在升级到不同的数据库时比较困难。

    调试麻烦。SQL语言的处理功能简单。

    Sql Server 数据库中的自定义函数:

    “自定义函数”是我们平常的说法,而“用户定义的函数”是 SQL Server 中书面的说法。

    自定义函数分为:标量值函数或表值函数

    如果 RETURNS 子句指定一种标量数据类型,则函数为标量值函数。可以使用多条 Transact-SQL 语句定义标量值函数。
    如果 RETURNS 子句指定 TABLE,则函数为表值函数。
    表值函数又可分为:内嵌表值函数(行内函数)或多语句函数
    如果 RETURNS 子句指定的 TABLE 不附带列的列表,则该函数为内嵌表值函数。
    如果 RETURNS 子句指定的 TABLE 类型带有列及其数据类型,则该函数是多语句表值函数。

    自定义函数优点:

    可以在SQL语句中调用,直接使用返回值,从而可以形成复杂的SQL应用。

    自定义函数缺点:

    能在函数中使用的语句有严格限制:

    不支持create、ALTER、drop等DDL(Data Definition Language)命令;

    insert、delete、update只能用在临时表上;

    不支持动态SQL;

    不支持“不确定”的函数,比如常用的getdate。不确定函数是指输入参数相同,返回结果可能不同的函数。

    变通办法:
    要解决用户函数的种种限制,可以巧妙运用用户函数调用存储过程。比如,需要在函数中用getdate,就写个存储过程返回getdate的结果。然后从函数里去调用这个存储过程。需要在函数中使用update等,也可类推。

    白雨青工作站发文地址:www.byqws.com/blog/1046.html