Mysql数据库创建存储过程实现往数据表中新增字段的方法
本文实例讲述了mysql创建存储过程实现往数据表中新增字段的方法,结合实例形式对比分析了通过存储过程新增字段相关操作技巧,需要的朋友可以参考下。...
本文实例讲述了MySQL创建存储过程实现往数据表中新增字段的方法,结合实例形式对比分析了通过存储过程新增字段相关操作技巧,需要的朋友可以参考下。
需求:
往某数据库的某个表中新增一个字段(若该字段已存在,则不做操作;若该字段不存在,则新增)
百度了n久,没有符合要求的例子,只有参考加自己琢磨,最终终于给弄出来了,以下是几个版本的更迭
第一版:
DELIMITER $
CREATE
PROCEDURE
insert_column()
BEGIN
IF
NOT
EXISTS(
SELECT
1
FROM
information_schema.columns
WHERE
table_schema=
'ltivalley'
AND
table_name=
't_luck'
AND
column_name=
'sss'
)
THEN
alter
table
ltivalley.t_luck
add
sss
varchar
(255)
not
Null
;
end
if;
END
$
DELIMITER ;
此存储过程可以做到往ltivalley数据库的t_luck表中新增一个sss的字段,但写死了,毫无灵活性,故没用!
第二版:
DELIMITER $
CREATE
PROCEDURE
insert_column(
in
dbname
varchar
(255),
in
tbname
varchar
(255),
in
colname
varchar
(255))
set
@sql_1= concat(
"IF NOT EXISTS(SELECT 1 FROM
information_schema.columns WHERE table_schema="
,dbname,
"
AND table_name="
,tbname,
" AND column_name="
,colname,
")
THEN
alter table "
,dbname,
"."
,tbname,
" add "
,colname,
"
varchar(255) not null;
end if;"
);
PREPARE
stmt
FROM
@sql_1;
EXECUTE
stmt;
DEALLOCATE
PREPARE
stmt;
END
$
DELIMITER ;
创建存储过程没有问题,但当调用的时候就会出错,报 "IF"左右出错,原因是在mysql中IF只能存在于存储过程中,此处用EXECUTE stmt来执行,等于是不在存储过程里面执行if语句,所以报错,执行不了!故没用!
第三版
DELIMITER $
CREATE
PROCEDURE
insert_column(
in
dbname
varchar
(255),
in
tbname
varchar
(255),
in
colname
varchar
(255))
BEGIN
SET
@selec=CONCAT(
'SELECT 1 FROM information_schema.columns WHERE table_schema="'
,dbname,
'" AND table_name="'
,tbname,
'" AND column_name="'
,colname,
'"'
);
PREPARE
selec
FROM
@selec;
SET
@addcol=CONCAT(
'ALTER TABLE '
,dbname,
'.'
,tbname,
' ADD '
,colname,
' VARCHAR(255)'
);
PREPARE
addcol
FROM
@addcol;
IF
NOT
EXISTS(
EXECUTE
selec;)
THEN
EXECUTE
addcol;
END
IF;
END
$
DELIMITER ;
无法创建存储过程,原因是在IF NOT EXISTS()中,不能执行EXECUTE selec语句,原因未知。故没用!
终极版
DROP
PROCEDURE
IF EXISTS insert_column;
DELIMITER $
CREATE
PROCEDURE
insert_column(
in
dbname
varchar
(255),
in
tbname
varchar
(255),
in
colname
varchar
(255))
BEGIN
set
@iscolexists = 0;
SET
@selec=CONCAT(
'SELECT count(*) into @iscolexists FROM information_schema.columns WHERE table_schema="'
,dbname,
'" AND table_name="'
,tbname,
'" AND column_name="'
,colname,
'"'
);
PREPARE
selec
FROM
@selec;
EXECUTE
selec;
DEALLOCATE
PREPARE
selec;
SET
@addcol=CONCAT(
'ALTER TABLE '
,dbname,
'.'
,tbname,
' ADD '
,colname,
' VARCHAR(255)'
);
PREPARE
addcol
FROM
@addcol;
IF(@iscolexists=0)
THEN
EXECUTE
addcol;
END
IF;
END
$
DELIMITER ;
最终的结果,先执行EXECUTE selec,将结果存放到一个变量@iscolexists中,然后再在IF()中判断@iscolexists的值,做相应操作。可用!
以上就是Mysql数据库创建存储过程实现往数据表中新增字段的方法的全部内容了,希望本文所述对大家MySQL数据库计有所帮助。
-
Mysql数据库自定义函数的定义、使用方法及操作注意事项
文章主要介绍了MySQL自定义函数简单用法,结合实例形式分析了mysql自定义函数的基本定义、使用方法及操作注意事项,需要的朋友可以参考下。...
-
Mysql数据库的max_allowed_packet设定方法
小编为大家分享一篇关于Mysql的max_allowed_packet设定,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...
-
Mysql数据库乱码出现的各个阶段以及对应方法
MySQL中数据库乱码一般进行字符集的设定即可,但是乱码可以出现在各个阶段,所以这篇文章整理一下乱码出现的各个阶段以及对应方法。...
-
MySQL数据库的事务处理用法与实例代码详解
文章主要介绍了mysql事务处理用法与实例代码详解,详细的介绍了事物的特性和用法并实现php和mysql事务处理例子,非常具有实用价值,需要的朋友可以参考下...
-
Mysql数据库使用from与join两表查询的方法区别总结
文章主要给大家介绍了关于mysql使用from与join两表查询的区别的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面...
-
Sql Server数据库类似正则表达式的字符处理问题
SQL Serve提供了简单的字符模糊匹配功能,比如:like, patindex,不过对于某些字符处理场景还显得并不足够,日常碰到的几个问题有:...
-
SQL Server数据库中表和索引结构存储的原理及如何加快搜索速度分析
本文详细分析了SQL Server中表和索引结构存储的原理以及对于如何加快搜索速度和提高效率等方面做了详细的分析,以下是主要内容。...
-
SQL Server Page数据库结构深入分析
SQL Server存储数据的基本单元是Page,每一个Page的大小是8KB,数据文件是由Page构成的。在同一个数据库上,每一个Page都有一个唯一的资源标识,标识符由三部分组成...
-
基于Sql server数据库的四种分页方式总结
下面小编就为大家分享一篇基于sqlserver的四种分页方式总结,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧。...
-
SQL Server 2016数据库快照代理过程详解
本文我们通过SQL Server 2016一个实例数据表,给大家详细分析了快照代理过程遇到的问题和解决办法,并对快照生成过程做了详细说明,以下是全部内容:...