函数,自定义函数,存储过程比较
来源:互联网 发布:公司招聘美工的要求 编辑:程序博客网 时间:2024/05/12 18:16
1.Sqlserver 系统常用函数
SELECT SUBSTRING('iTalkbb',2,4)--从第二个字符起,长度为4SELECT LOWER('AAbbCC')SELECT UPPER('aaaa')SELECT RTRIM(LTRIM(STR(123)))+RTRIM(LTRIM(STR(456)))SELECT CHARINDEX('a','italk')--查找子串位置,没有返回0,位置从1开始SELECT REPLACE('italkbb','bb','mobo')--字符串替换,将1原有字符串中的2一部分,替换成3新的SELECT LEN('abcde')
2. 函数与存储过程的比较
1. 一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。
2. 对于存储过程来说可以返回参数,而函数只能返回值或者表对象。
3. 存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。
4. 当存储过程和函数被执行的时候,SQL Manager会到procedure cache中去取相应的查询语句,如果在procedure cache里没有相应的查询语句,SQL Manager就会对存储过程和函数进行编译。
Procedure cache中保存的是执行计划 (execution plan) ,当编译好之后就执行procedure cache中的execution plan,之后SQL SERVER会根据每个execution plan的实际情况来考虑是否要在cache中保存这个plan,评判的标准一个是这个execution plan可能被使用的频率;其次是生成这个plan的代价,也就是编译的耗时。保存在cache中的plan在下次执行时就不用再编译了。
3. 自定义函数 语法
--标量函数的创建CREATE FUNCTION dbo.GetCount(/*定义输入参数*/)RETURNS intASBEGINDECLARE @c INT;SELECT @c=COUNT(*) FROM dbo.user_info;RETURN @c;END--调用SELECT dbo.getcount()--必须加dboDECLARE @t INT;SET @t=dbo.getcount();PRINT(@t);
- 函数,自定义函数,存储过程比较
- 存储过程与函数比较
- 存储过程与函数比较
- 存储过程调用自定义函数
- 自定义存储过程和函数
- oracle自定义函数、存储过程
- 自定义存储过程和函数
- 【MySQL】MySQL函数、自定义函数、存储过程
- MySQL基础知识----自定义函数,存储过程/函数,存储引擎
- oracle存储过程及自定义函数(存储函数)初学
- 如何导出存储过程和自定义函数?
- oracle自定义函数和存储过程
- 存储过程和自定义函数的区别
- 存储过程和自定义函数的区别
- 常用sql自定义函数以及存储过程
- 存储过程和自定义函数的优缺点
- orcl中的存储过程,自定义函数,触发器
- mysql创建自定义函数和存储过程
- 52.windbg-Call Function调试技巧(调用函数)
- android http请求
- 自定义ListView使用的Adapter
- UCOSII信号量
- 上篇日本人经营之道 一商道三洞悉人性攻心为上
- 函数,自定义函数,存储过程比较
- javascript获取浏览器宽度和高度
- android LayoutInflater 使用
- 归并排序(merge sort)的实现
- x264和FFMPEG 编译后遇到的一些问题:UINT64_C,
- Linux下Qt与mysql建立连接
- 民生银行-北京管理部运营支持类(笔试题)
- android ListView 使用
- SQL执行过程