SQL存储过程

    写在最前面

在存储过程中,经常用到SET NOCOUNT ON;

作用:阻止在结果集中返回显示受T-SQL语句或则usp影响的行计数信息。
当SET ONCOUNT ON时候,不返回计数,当SET NOCOUNT OFF时候,返回计数;

即使当SET NOCOUNT ON 时候,也更新@@RowCount;

当SET NOCOUNT on时候,将不向客户端发送存储过程每个语句的DONE_IN_proc消息,如果存储过程中包含一些并不返回实际数据的语句,网络通信流量便会大量减少,可以显著提高应用程序性能;

SET NOCOUNT 指定的设置时在执行或运行时候生效,分析时候不生效。

USE Summer
GO
SET NOCOUNT ON;
SELECT *  FROM User
GO

1.1.数据查询功能的不带参数的存储过程

CREATE PROCEDURE Summer_s  
AS  
BEGIN  
SET NOCOUNT ON  SELECT * FROM ES_LOG WHERE OpTime like '%2019%' END --Summer_s 为存储过程名字 GO EXEC Summer_s

1.2.在存储过程中可以包含多个select语句

CREATE PROCEDURE Summer_es  
AS  
BEGIN  
SET NOCOUNT ON  SELECT count (*) FROM ES_Log WHERE OpTime LIKE '%2019%' SELECT * FROM ES_Log WHERE OpTime LIKE '%2019%' END --Summer_s 为 存储过程名字 GO EXEC Summer_es

2.带有输入参数的数据查询功能的存储过程,使用LIKE 模糊查询

CREATE PROC Summer_like
@para1 nvarchar(50)
AS  
BEGIN  
SET NOCOUNT ON  SELECT count (*) FROM ES_Log WHERE OpTime LIKE ('%'+@para1+'%') SELECT * FROM ES_Log WHERE OpTime LIKE ('%'+@para1+'%') END --Summer_ like 为 存储过程名字 GO EXEC Summer_like 2019
原文地址:https://www.cnblogs.com/Summer6/p/11143371.html