存储过程编写
㈠ 存储过程怎么写啊
//创建存储过程
CREATE PROCEDURE userData(
IN id INT
)
BEGIN
SELECT * from userdata WHERE userflag = id;
END;
其中IN是传进去的变量;
drop procere userData;//销毁这个存储过程。
call userData(2) //调用存储过程。
(1)存储过程编写扩展阅读:
sql中的存储过程及相关介绍:
CREATE PROCEDURE [拥有者.]存储过程名[;程序编号]
[(参数#1,…参数#1024)]
[WITH
{RECOMPILE | ENCRYPTION | RECOMPILE, ENCRYPTION}
]
[FOR REPLICATION]
AS 程序行
其中存储过程名不能超过128个字。每个存储过程中最多设定1024个参数
(SQL Server 7.0以上版本),参数的使用方法如下:
@参数名数据类型[VARYING] [=内定值] [OUTPUT]。
每个参数名前要有一个“@”符号,每一个存储过程的参数仅为该程序内部使用,参数的类型除了IMAGE外,其他SQL Server所支持的数据类型都可使用。
[内定值]相当于我们在建立数据库时设定一个字段的默认值,这里是为这个参数设定默认值。[OUTPUT]是用来指定该参数是既有输入又有输出值的,也就是在调用了这个存储过程时,如果所指定的参数值是我们需要输入的参数。
同时也需要在结果中输出的,则该项必须为OUTPUT,而如果只是做输出参数用,可以用CURSOR,同时在使用该参数时,必须指定VARYING和OUTPUT这两个语句。
参考资料来源:网络-储存过程
㈡ sql怎样新建存储过程
一:创建没有参数的存储过程:
CREATE PROCEDURE select_all
AS
BEGIN
SELECT * from T_login1
GO
二:创建带参数的存储过程:
CREATE PROCEDURE select_name
@id uniqueidentifier
AS
BEGIN
SELECT * from T_login1 where PSN0001A=@id
GO
(2)存储过程编写扩展阅读:
创建存储过程的注意事项:
1、保持事务简短,事务越短,越不可能造成阻塞。
2、在事务中尽量避免使用循环while和游标,以及避免采用访问大量行的语句。
3、在启动事务前完成所有的计算和查询等操作,避免同一事务中交错读取和更新。可以使用表变量预先存储数据。即存储过程中查询与更新使用两个事务实现。
4、超时会让事务不执行回滚,超时后如果客户端关闭连接sqlserver自动回滚事务。如果不关闭,将造成数据丢失,而其他事务将在这个未关闭的连接上执行,造成资源锁定,甚至服务器停止响应。
㈢ 用SQL怎样编写一个存储过程
create proc 要定义的视图名 as select 参数 from 视图名
㈣ sql 存储过程语句编写
要到达你的要求,在存储过程中必须使用动态SQL语句。
一个简化的例子:
createprocereMyDynamicSQL
@tblwherenvarchar(200)--a==aora==xxx
as
begin
declare@sqlnvarchar(max)
--动态拼接sql语句
set@sql=N'select*from[表一]where'+@tblwhere
--执行
executesp_executesql@sql
end
㈤ 如何编写数据库存储过程
存储过程代码参考如下:
create
or
replace
procere
bak_pay_list_xxx(local_net
in
varchar2,bak_month
in
varchar2,ret
out
varchar2)
is
ls_sql
varchar2(1024);
ls_sql_del
varchar2(1024);
begin
...
end
bak_pay_list_xxx;
㈥ 存储过程的编写
我是这样理解的:
1、要求根据UserId,查T_Mail_User表,得到MailId,再查T_Mail表获得邮件。
2、同时可以获得用户的收藏邮件。即不但提供UserId输入,而且提供“是否要取收藏记录”的输入参数。
3、同时支持条件查询,比如,按发送日期等查询,默认1=1,即没有条件语句。
这样,存储过程中关键的语句为
if(@filterString is null)
set @filterString='1=1'
declare cmdStr char(256)
if(isGetFavorite)
set cmdStr='select b.* from T_Mail_User a,T_Mail b
where a.isFavorite=1 and a.UserId=@userId and a.MailId=b.MailId and a.MailType=0 and '+@filterString
else
...a.isFavorite=0...
exec(cmdStr)
上面假设收件箱标识为0,如果参数化,此存储过程也可用于查用户的发件箱等。
上面的@filterString就是条件字符串,或者‘1=1’可能由前台提供,此时不必要第一个if。
㈦ 新手学习 Oracle存储过程怎么编写
示例参考:
建立存储过程
CREATE OR REPLACE PROCEDURE P_name--存储过程名字
(
i_var in int, --输入参数1
o_var OUT varchar2 --输出参数1
)
IS
v_STR VARCHAR2(200); --定义存储过程内部的局部变量
BEGIN
--下面是存储过程的主体实现部分
v_STR := i_var;
dbms_output.put_line(v_STR);
o_var := v_STR;
exception--错误异常处理部分
when others then
dbms_output.put_line(sqlerrm);--打印错误信息
END P_name
㈧ 编写存储过程
1 select PersonName from tb_职员 z
left join tb_考勤 k on z.PersonID=k.PersonID
where (k.Cio=i and k.Ctime>N'0830') or (k.Cio=O and k.Ctime<N'1730')
2 select count(*) as num,PersonName,z.PersonID from tb_职员 z
left join tb_考勤 k on z.PersonID=k.PersonID
where (k.Cio=i and k.Ctime>N'0830') or (k.Cio=O and k.Ctime<N'1730') and num>=10
group by z.PersonID
㈨ 编写一个存储过程,急急
不需要存储过程
一个sql就行
select 起运港 ,目的地, 船名, 航次 , sum(case when 箱类 = 'GP' then 1 else 0 end ) as GP,
sum(case when 箱类 = 'HQ' then 1 else 0 end ) as HQ,
SUM(case when 箱类 = 'FR' then 1 else 0 end ) as FR,
SUM(case when 箱类 = 'TK' then 1 else 0 end ) as TK
from tcard