sql中创建关于更新的存储过程

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql中创建关于更新的存储过程相关的知识,希望对你有一定的参考价值。

参考技术A 关于delphi调用存储过程,用sql
server自带的“创建存储过程向导”给表login建立一个更新存储过程。
悬赏分:100
|
离问题结束还有
12

18
小时
|
提问者:风风我依
|
检举
存储过程代码如下:已知表login有passname和password两个字段。
create
procedure
[update_login_1]
(@passname_1
[varchar],
@passname_2
[varchar](50),
@password_3
[varchar](50))
as
update
[wqzx].[dbo].[login]
set
[passname]
=
@passname_2,
[password]
=
@password_3
where
(
[passname]
=
@passname_1)
go
-------------------------------------------------------------------------------------
在delp调用该存储过程,要求只该改字段中的password,即建一个文本框将里面内容替换一个记录中的password,而保持passname不变,简单讲就是修改一个用户名的密码。怎么写代码?问题补充:
"强唐华"我试过这样写存储过程了,没用的,如果可以,那在delphi中怎么写代码调用这个存储过程?
强调下:这是sql自带建立的存储过程,就是由“创建存储过程向导”生成,我觉得不会错的,问题是怎么在delphi中调用该存储过程,代码呢?
我建立了一个插入的存储过程,代码如下:
with
storedproc1
do
begin
parambyname('@passname_1').asstring:=edit1.text;
parambyname('@password_2').asstring:=edit2.text;
execproc;
if
params[0].asinteger=0
then
messagedlg('添加新用户名成功!',mtinformation,[mbok],0)
else
messagedlg('添加用户失败!',mterror,[mbok],0);
end;
这段代码是可以成功插入一个记录的。现在是想修改某个记录。
回答
共1条
create
procedure
[dbo].[update_login]
(@name
varchar(50),
@password
[varchar](50))
as
update
useres
set
password=@password
where
name=
@name
这么简单的存储过程,都不会用?
sqlconnection
conn
=
new
sqlconnection("data
source=tq-pc;initial
catalog=tq;user
id=sa;password=123");
sqlcommand
cmd
=
new
sqlcommand("update_login",
conn);
cmd.commandtype
=
commandtype.storedprocedure;
cmd.parameters.addwithvalue("@name",
textbox3.text.trim());
cmd.parameters.addwithvalue("@password",
textbox4.text.trim());
conn.open();
int
i
=
cmd.executenonquery();
if
(i
>
0)
response.write("密码修改成功!");
else
response.write("密码修改失败!");

在存储过程中创建动态表而在 PL/SQL 块表中创建时权限不足[重复]

【中文标题】在存储过程中创建动态表而在 PL/SQL 块表中创建时权限不足[重复]【英文标题】:Insufficient privilege when create dynamic table in stored procedure while in PL/SQL block table has been created [duplicate] 【发布时间】:2019-07-22 11:53:59 【问题描述】:

当我在存储过程中执行包含EXECUTE IMMEDIATEcreate table 语句的存储过程时,然后在执行此存储过程时出错。 这是存储过程-

create or replace sp_exec
 as
 .......
 v_mth date;
 .......
begin
 select to_char(add_months(current_DATE, -1), 'MON_YY') INTO v_mth FROM dual;
  execute immediate 'create table tbl_mon_' ||v_mth|| ' as select ............... from ..... ';
end;

当我尝试执行此存储过程时,在使用此代码执行存储过程的第二行最后一行出现错误“Insufficient Privilege”。

 begin
  sp_exec;
 end;

然后得到下面提到的错误:-

 ORA-01031: Insufficient privilege
 ORA-06512: at sp_exec line 11  --here line 11 mention for Execute immediate
 ORA-06512: at line 2         -- here mention for sp_exec in the PLSQL block

我在用户模式本身中工作,所以我拥有所有类型的权限,甚至CREATE TABLE 语句也是如此。当我在存储过程(PL/SQL 块)之外运行时,动态表已创建。

【问题讨论】:

动态创建月表似乎是一个很糟糕的设计。 例如物化视图或分区 【参考方案1】:

显然,您通过角色获得了create table 权限。它不适用于命名的 PL/SQL 过程,这意味着您必须将其直接授予用户。

【讨论】:

您是否有权从作为您动态创建的表的源的表中进行选择?您发布的代码表明您正在选择from v_mth,其中˙v_mth日期;您不能从名称为 01-JUN-19 的表中进行选择,可以吗? 好的,但是您的代码显示:as select ............... from '|| v_mth ||' ..... 'v_mth 等于 01-JUN-19(或数据库中默认返回的任何格式 TO_DATE)。这是一个无效的表名。当然,除非您过度简化了您发布的代码。尝试创建一个我们能够重现的简单示例。

以上是关于sql中创建关于更新的存储过程的主要内容,如果未能解决你的问题,请参考以下文章

怎样在Sql server中创建,执行和删除存储过程

在存储过程中创建动态表而在 PL/SQL 块表中创建时权限不足[重复]

如何在sql server中创建一个存储过程中的varchar型的输入参数默认值为空

SQL Server:尝试在存储过程中创建视图

PL/Sql 中创建调试调用存储过程

如何使用 cmd 在 SQL 中创建存储过程?