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一個實例數據表,給大家詳細分析了快照代理過程遇到的問題和解決辦法,并對快照生成過程做了詳細說明,以下是全部內容:... 

