​oracle存储过程怎样重命名,除了用or replace 还有什么

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了​oracle存储过程怎样重命名,除了用or replace 还有什么相关的知识,希望对你有一定的参考价值。

oracle存储过程怎样重命名,除了用or replace 还有啥

    create or replace 不是用来重命名的,是用来建立或替换同一名称存储过程。

    重命名先可以复制旧的代码,建立新的存储过程再把旧的drop掉

参考技术A 把原有的存储过程备份一下,然后删除,重新创建存储过程
希望可以帮到你!
参考技术B drop procedure 旧名;
create procedure 新名;追问

你这不是删了又建吗?我只想改一下名字

追答

不好意思。别的方法我就不太知道了。
但是,or replace是肯定不好用的。因为它只是覆盖同名的方法。
你的目的是改名,与它的功能不一致,所以还是试一试其它的方法吧。

mysql存储过程怎样批量插入数据

一下代码运行通过:

delimiter $$;
create procedure lucia_proc16(count int)
begin
DECLARE name_proc VARCHAR(20) CHARACTER SET utf8;
DECLARE sex_proc VARCHAR(4) CHARACTER SET utf8;
DECLARE age_proc INT(10);
DECLARE class_proc VARCHAR(20) CHARACTER SET utf8;
DECLARE Addr_proc VARCHAR(50) CHARACTER SET utf8;
DECLARE i INT;
set i = 1;
set sex_proc = '女';
set age_proc = 20;
set class_proc = '山治班';
set Addr_proc = '北京市朝阳区';
while i<count do
set name_proc = CONCAT('露西亚',i);
insert into students(Name,Sex,age,class,Addr)values(name_proc,sex_proc,age_proc,class_proc,Addr_proc);
set i = i+1;
end while;
end
$$;
delimiter;

代码功能:

传入一个行数,控制插入多少条数据

运行效果:

参考技术A

用mysql储存过程批量插入数据

#数据表的结构为stu_id(学号) ,stu_name(姓名),stu_sex(性别),cla_id(班级编号),stu_phone(手机号)
 
drop procedure if exists insertt;#如果存在储存过程则删除
delimiter $$                     #创建一个储存过程
create procedure insertt()
begin
set @a=2000000001;     #学号
set @d=20000001;       #班级编号
set @e=18200000000;   #手机号
while @a<2000010001 do     #如果@a<2000010001则返回true,继续执行
set @b=rand_string(5);     #姓名,随即赋值,值为5位a-zA-Z的任意组合
set @c=rand_sex(1);           #性别,随即赋值,值为1位,0或者1
insert into students values(@a,@b,@c,@d,@e);
set @a=@a+1;
set @e=@e+1;
    if @a%100=0 
    then
        set @d=@d+1 ;
     end if;
end while;
end$$
delimiter ;
 
#执行存储过程插入数据
call insertt();
 
#创建一个随机产生字符串的函数
set global log_bin_trust_function_creators = 1;
DROP FUNCTION IF EXISTS rand_string;
DELIMITER //  
CREATE FUNCTION rand_string(n INT)
RETURNS VARCHAR(255)
BEGIN
                DECLARE chars_str varchar(100) DEFAULT 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
                DECLARE return_str varchar(255) DEFAULT '';
                DECLARE i INT DEFAULT 0;
                WHILE i < n DO
                                SET return_str = concat(return_str,substring(chars_str , FLOOR(1 + RAND()*52 ),1));#52代表在52个字母中随即找出一个
                                SET i = i +1;
                END WHILE;
                RETURN return_str;
END //
delimiter ; 
 
#创建一个随机产生字符串的函数,0和1随机出现
set global log_bin_trust_function_creators = 1;
DROP FUNCTION IF EXISTS rand_sex;
DELIMITER //   
CREATE FUNCTION rand_sex(n INT)
RETURNS VARCHAR(255)
BEGIN
                DECLARE chars_str varchar(100) DEFAULT '01';
                DECLARE return_str varchar(255) DEFAULT '';
                DECLARE i INT DEFAULT 0;
                WHILE i < n DO
                                SET return_str = concat(return_str,substring(chars_str , FLOOR(1 + RAND()*2 ),1));
                                SET i = i +1;
                END WHILE;
                RETURN return_str;
END //
delimiter ;

以上是关于​oracle存储过程怎样重命名,除了用or replace 还有什么的主要内容,如果未能解决你的问题,请参考以下文章

oracle 如何终止存储过程的运行!

重命名 SQL Server 中的存储过程

Oracle创建存储过程

oracle存储过程怎样批量插入新数据

怎样在sql语句中oracle调用存储过程

重命名mysql过程