1、打开SQL Database Studio。
2、点击展开数据库连接和数据库。
3、右击要修改的存储过程,然后点击【alter procedure】。
4、此时进入存储过程编辑界面。
5、修改存储过程语句。
6、点击左侧的【execute】。
7、此时显示执行结果,成功表示存储过程的定义修改完成了。
CREATE PROCEDURE jiafa
@a VARCHAR(2000)
AS
BEGIN
EXECute('select ' + @a)
END
GO
EXEC jiafa '22+33'
这个为什么不声明呢, 我就是想知道什么情况下用 什么情况下不用声明
看到你这样问我哭了,本来我还想打给你什么是传入的形参呢!
正常的程序中有这样的:(javascript为例)
function sfuction(obj)
{
objXXXXXXX;
}
试问一下其中的obj进行了赋值或是声明了吗?
其中@a VARCHAR(2000)表示为存储过程传入的形参,也就是说,这个参数是用来接收的,是形参显然不用定义了!如果这样写你可能看的更新楚些:
create proc procname
( @intvalue int,
@stringtemp nvarchar(100)
)
as
begin
XXXXXX
end
其中括号中的内容就是形参,也就是说传入值让这个参数进行接收,而此时还没有任何的执行,就必须先让这个参数接收,这样的就是形参,不是自定义的变量!只是表示要传入的值而已,显然这样的值是不可能进行定义的!而在begin段中可以直接进行处理的!
所以形参不能算是自定义的参数!他只表示传入的第一个值按在处理中按参数@a进行引用,该类型必须为Nvarchar(2000)而已。
所以注意一下形参是不须也是不能定义的!
能给个实例讲解一下否?
追答set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
go
ALTER PROC [dbo].[S] ( @TBL VARCHAR(100),
@WHERE VARCHAR(100) = NULL ) --这两个是调用的时候传进来的参数,不用声明
AS
DECLARE @SQLSTRING NVARCHAR(500) --这个是存储过程里需要这样一个变量,不是传入的所以需要声明
IF @WHERE IS NULL
SELECT @WHERE = ''
ELSE
SELECT @WHERE = ' WHERE '+@WHERE
SELECT @SQLSTRING = N'SELECT * FROM '+@TBL+' '+@WHERE
EXEC sp_executesql @SQLSTRING
sql 存储过程中 如何使用declare 有的存储过程声明了,有的没有声明...
存储过程既可以有declare语句,也可以没有,declare声明的是一个语句块,是pl\/sql执行的基本单位,案例:一个基本的declare语句块 DECLARE e_invalid_department EXCEPTION; -- 声明部分,给例外命名BEGIN UPDATE departments SET department_name = 'Oracle Technology Center' WHERE department_id ...
在存储过程中使用参数什么时候要用declare声明,什么情况下不要,麻烦高...
如果你是说sql server的话, 外部传入的不用declare,系统已有的不用declare(这部分具体可以上网下载sqlserver online help 参阅),其他都要。
declare在sql中的用法
在SQL中,DECLARE语句主要用于声明局部变量、游标、条件变量等,在存储过程、函数或批处理中非常有用。使用DECLARE,可以指定变量的名称、数据类型,并可选择性地为其赋一个初始值。这样做可以在SQL代码执行期间临时存储数据,以便于后续的引用或处理。例如,在SQL Server中,你可以这样声明一个整型变量@MyVa...
SQL SERVER的存储过程的declare函数的使用?谁知道!
变量是在批处理或过程的主体中用 DECLARE 语句声明的,并用 SET 或 SELECT 语句赋值。游标变量可使用此语句声明,并可用于其他与游标相关的语句。所有变量在声明后均初始化为 NULL。 <\/IMG>Transact-SQL 语法约定<\/IMG>语法 DECLARE {{ @local_variable [AS] data_type } | { @cursor_vari...
SQLServer中的存储过程中declare的问题
用declare声明的变量是局部变量是自己定义的,不用declare声明的变量是全局变量,是系统中已经有的,直接拿来使用就可以了。
ORACLE 定义存储过程时,什么时候需要使用DECLARE? 可以不用它吗 请...
oracle 的存储过程里没有declare的语法,触发器和plsql块才是declare 如果要定义变量,后面直接跟is的 CREATE OR REPLACE PROCEDURE c(xxx)IS para number;BEGIN end;
sql中declare是什么意思
在SQL中,"declare"是一个关键词,其主要作用是声明变量。这个语句类似于在编程中预先设定一个容器,用来存放存储过程执行时需要临时存储的数据。例如,想象一个存储过程,它接受一个输入参数,如学生编号,目的是查询对应学生的班级。在这个过程中,学生编号就是输入的参数,根据提供的编号,存储过程会返回...
存储过程declare用法问题
start_Quantity 肯定是自定义类型啦,SQL里面没有这种类型的 自定义类型的好处你自己baidu一下吧,不怎么好解释了 其实这句话的意思很简单,就是定义一个start_Quantity的类型,他的名字就是SrcQty,只是定义的时候名字必须用@开头,如果还不能理解的话,你就这样理解好了:declare @temp datetime,这句...
SQL语句中的declare 是什么意思,具体怎么用啊
是声明的意思,具体用法是declare @声明的变量名称 变量类型 如:declare @intDeclare int
sql中declare是什么意思
mysql存储过程中,定义变量有两种方式:1.使用set或select直接赋值,变量名以 @ 开头.例如:set @var=1;可以在一个会话的任何地方声明,作用域是整个会话,称为会话变量。2.以 DECLARE 关键字声明的变量,只能在存储过程中使用,称为存储过程变量,例如:DECLARE var1 INT DEFAULT 0; 主要用在存储...