重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
常量就是数值固定不变的或者被赋予固定值的量,如数字'100'、字母'abc'、符号'?/-'等。
10余年的芦淞网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。网络营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整芦淞建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联公司从事“芦淞网站设计”,“芦淞网站推广”以来,每个客户项目都认真落实执行。
变量即数值会发生变化的量,变量分为全局变量和局部变量。
局部变量(Local Variable)是用户可以定义的、作用范围仅在程序内部的变量。通常情况下,局部变量在程序中被用来存储查询结果,或者被当作程序执行过程中的暂存变量来使用。局部变量定义时要以@开头,定义方式为:Declare @变量名 变量类型。
全局变量(Global Variable)是MS SQLServer系统内部使用的变量,作用范围是系统内的所有程序,而并非局限于某些程序。它不是由用户来定义的,而是系统中预先定义好的。使用全局变量时,要以@@开头,如:select@@VERSION as w 用来查询SQL服务器安装的日期、版本和处理器类型;select@@CONNECTIONS 用来查询自上次SQL启动以来连接或试图连接的次数。
关于局部变量和全局变量详细定义及用法,下面库友的文章写得很棒,请参考:
set @id=(GetsystemNo 'CXD')
修改为
set @id=GetsystemNo ('CXD')
看看?
if @srID0
set @condition =@condition+' and srID='+convert(varchar(10),@srID)
if len(@srName)0
set @condition =@condition+' and srName='+@srName
declare @sql varchar(max)
set @sql=' select srID,srName,srNotes,cTime from SourceRegion where '+@condition
exec(@sql)
用动态语句
/*\x0d\x0a Sql server 存储过程中怎么将变量赋值\x0d\x0a*/\x0d\x0a\x0d\x0a--SQL赋值语句\x0d\x0aDECLARE @test1 INT\x0d\x0aSELECT @test1 = 111\x0d\x0aSET @test1 = 222\x0d\x0a\x0d\x0a--SQL函数赋值,假定count()是自定义函数\x0d\x0aDECLARE @test2 INT\x0d\x0aSELECT @test2 = COUNT(*) FROM sys.sysobjects\x0d\x0a\x0d\x0a--SQL存储过程赋值,直接传参处理(类似C语言中的指针吗)\x0d\x0aIF OBJECT_ID('sp_test') IS NOT NULL DROP PROCEDURE sp_test\x0d\x0aGO\x0d\x0aCREATE PROCEDURE sp_test(@test INT OUTPUT)\x0d\x0aAS\x0d\x0aBEGIN\x0d\x0a SELECT @test = 999\x0d\x0aEND\x0d\x0aGO\x0d\x0a\x0d\x0aDECLARE @test3 INT\x0d\x0aEXEC sp_test @test3 OUTPUT\x0d\x0aSELECT @test3\x0d\x0a\x0d\x0aDROP PROCEDURE sp_test\x0d\x0aGO
1、 创建语法
create proc | procedure pro_name
[{@参数数据类型} [=默认值] [output],
{@参数数据类型} [=默认值] [output],
....
]
as
SQL_statements
2、 创建不带参数存储过程
--创建存储过程
if (exists (select * from sys.objects where name = 'proc_get_student'))
drop proc proc_get_student
go
create proc proc_get_student
as
select * from student;
--调用、执行存储过程
exec proc_get_student;
3、 修改存储过程
--修改存储过程
alter proc proc_get_student
as
select * from student;
4、 带参存储过程
--带参存储过程
if (object_id('proc_find_stu', 'P') is not null)
drop proc proc_find_stu
go
create proc proc_find_stu(@startId int, @endId int)
as
select * from student where id between @startId and @endId
go
exec proc_find_stu 2, 4;
5、 带通配符参数存储过程
--带通配符参数存储过程
if (object_id('proc_findStudentByName', 'P') is not null)
drop proc proc_findStudentByName
go
create proc proc_findStudentByName(@name varchar(20) = '%j%', @nextName varchar(20) = '%')
as
select * from student where name like @name and name like @nextName;
go
exec proc_findStudentByName;exec proc_findStudentByName '%o%', 't%';
扩展资料:
SQL存储过程优点:
1、重复使用。存储过程可以重复使用,从而可以减少数据库开发人员的工作量。
2、减少网络流量。存储过程位于服务器上,调用的时候只需要传递存储过程的名称以及参数就可以了,因此降低了网络传输的数据量。
3、安全性。参数化的存储过程可以防止SQL注入式攻击,而且可以将Grant、Deny以及Revoke权限应用于存储过程。
参考资料来源:百度百科—存储过程
查询计划缓存及各种 SET 选项(与 showplan 相关及其他)
各种 SET 选项——多数与 showplan 相关——以多种复杂的方式影响着查询计划和执行上下文的编译、缓存和重用。下表汇总了相关的详细信息。
应按如下顺序阅读该表中的内容。批处理通过表中第一列所指定的特定模式提交给 SQL Server。已提交的批处理的计划缓存中可能存在、也可能不存在已缓存的查询计划。第 2 列和第 3 列描述了存在已缓存的查询计划时的情况;第 4 列和第 5 列说明了不存在已缓存的查询计划时的情况。在每个类别中,查询计划和执行上下文的各种情况都是独立的。表中说明了结构(查询计划或执行上下文)所发生的情况:是否被缓存、重用和使用。
模式名称 存在已缓存的查询计划时 存在已缓存的查询计划时 不存在已缓存的查询计划时 不存在已缓存的查询计划时
查询计划
执行上下文
查询计划
执行上下文
showplan_text, showplan_all, showplan_xml
被重用(无编译)
被重用
被缓存(编译)
生成一个执行上下文,对其进行缓存但不使用它
statistics profile, statistics xml, statistics io, statistics time
被重用(无编译)
不被重用生成并使用一个全新的执行上下文,但不对其进行缓存
被缓存(编译)
生成并使用一个全新的执行上下文,但不对其进行缓存
noexec
被重用(无编译)
被重用
被缓存(编译)
不生成执行上下文(由于“noexec”模式)。
parseonly(例如,在查询分析器或 Management Studio 中按“分析”按钮)
无
无
无
无
查询计划和执行上下文的相关成本