mysql可重復(fù)執(zhí)行函數(shù)

1.新增字段

CREATE DEFINER=`root`@`%` PROCEDURE `win_add_column`(IN p_table_name VARCHAR(100),
    IN p_column_name VARCHAR(100),
    IN p_stmt VARCHAR(200))
BEGIN

    DECLARE add_column VARCHAR(250);

    SELECT COUNT(1)
    INTO @cnt
    FROM information_schema.columns
    WHERE table_schema = (SELECT DATABASE())
        AND table_name = p_table_name
        AND column_name = p_column_name;

    -- 新增列
    IF @cnt = 0 THEN
        SET @add_column = p_stmt;

        PREPARE stmt FROM @add_column;
        EXECUTE stmt;
        DEALLOCATE PREPARE stmt;
    END IF;

END

2.修改列

CREATE DEFINER=`root`@`%` PROCEDURE `win_change_column_name`(IN p_table_name VARCHAR(100),
    IN p_column_name VARCHAR(100),
    IN p_to_column_name VARCHAR(100),
    IN p_stmt VARCHAR(200))
BEGIN

    DECLARE change_column VARCHAR(250);

    SELECT COUNT(1)
    INTO @cnt
    FROM information_schema.columns
    WHERE table_schema = (SELECT DATABASE())
        AND table_name = p_table_name
        AND column_name = p_column_name;

    SELECT COUNT(1)
    INTO @to_cnt
    FROM information_schema.columns
    WHERE table_schema = (SELECT DATABASE())
        AND table_name = p_table_name
        AND column_name = p_to_column_name;

    -- 新增列
    IF (@cnt > 0 && @to_cnt = 0) THEN
        SET @change_column = p_stmt;

        PREPARE stmt FROM @change_column;
        EXECUTE stmt;
        DEALLOCATE PREPARE stmt;

    END IF;

END

3. 刪除列

CREATE DEFINER=`root`@`%` PROCEDURE `win_delete_column`(IN p_table_name VARCHAR(100),
    IN p_column_name VARCHAR(100))
BEGIN

    DECLARE delete_column VARCHAR(250);

    SELECT COUNT(1)
    INTO @cnt
    FROM information_schema.columns
    WHERE table_schema = (SELECT DATABASE())
        AND table_name = p_table_name
        AND column_name = p_column_name;

    -- 刪除列
    IF @cnt > 0 THEN
        SET @delete_column = concat(' alter table ', p_table_name, ' drop column ', p_column_name);

        PREPARE stmt FROM @delete_column;
        EXECUTE stmt;
        DEALLOCATE PREPARE stmt;
    END IF;

END

4. 修改索引

CREATE DEFINER=`root`@`%` PROCEDURE `win_rebuild_idx`(IN p_table_name VARCHAR(200),
    IN p_idx_name VARCHAR(200),
    IN p_col_name VARCHAR(200))
BEGIN
    DECLARE delete_idx VARCHAR(250);
    DECLARE create_idx VARCHAR(250);

    -- 判斷索引是否存在
    SELECT COUNT(1)
    INTO @cnt
    FROM information_schema.statistics
    WHERE table_schema = (SELECT DATABASE())
        AND table_name = p_table_name
        AND index_name = p_idx_name;

    -- 刪除索引
    IF @cnt > 0 THEN

        IF (p_idx_name = 'PRIMARY') THEN
            SET @delete_idx = concat(' alter table ', p_table_name, ' drop primary key');
        ELSE
            SET @delete_idx = concat(' drop index ', p_idx_name, ' on ', p_table_name);
        END IF;

        PREPARE stmt FROM @delete_idx;
        EXECUTE stmt;
        DEALLOCATE PREPARE stmt;

    END IF;

    -- 重建索引
    IF LENGTH(p_col_name) > 0 THEN

        IF (p_idx_name = 'PRIMARY') THEN
            SET @create_idx = concat(' alter table ', p_table_name, ' add primary key', '(', p_col_name, ')');
        ELSE
            SET @create_idx = concat(' create index ', p_idx_name, ' on ', p_table_name, '(', p_col_name, ')');
        END IF;

        PREPARE stmt FROM @create_idx;
        EXECUTE stmt;
      DEALLOCATE PREPARE stmt;

    END IF;

END

5. 修改主鍵

CREATE DEFINER=`root`@`%` PROCEDURE `win_rebuild_pk`(IN p_table_name VARCHAR(200),
    IN p_col_name VARCHAR(200))
BEGIN
    -- 調(diào)用重建索引
    call win_rebuild_idx(p_table_name, 'PRIMARY', p_col_name);

END

6. 修改唯一索引

CREATE DEFINER=`root`@`%` PROCEDURE `win_rebuild_uk`(IN p_table_name VARCHAR(200),
    IN p_idx_name VARCHAR(200),
    IN p_col_name VARCHAR(200))
BEGIN
    DECLARE delete_idx VARCHAR(250);
    DECLARE create_idx VARCHAR(250);

    -- 判斷索引是否存在
    SELECT COUNT(1)
    INTO @cnt
    FROM information_schema.statistics
    WHERE table_schema = (SELECT DATABASE())
        AND table_name = p_table_name
        AND index_name = p_idx_name;

    -- 刪除索引
    IF @cnt > 0 THEN

        SET @delete_idx = concat(' drop index ', p_idx_name, ' on ', p_table_name);

        PREPARE stmt FROM @delete_idx;
        EXECUTE stmt;
        DEALLOCATE PREPARE stmt;

    END IF;

    -- 重建索引
    IF LENGTH(p_col_name) > 0 THEN

        SET @create_idx = concat(' alter table ', p_table_name, ' add unique key ', p_idx_name, '(', p_col_name, ')');

        PREPARE stmt FROM @create_idx;
        EXECUTE stmt;
      DEALLOCATE PREPARE stmt;

    END IF;

END

7. 修改主鍵

CREATE DEFINER=`root`@`%` PROCEDURE `win_rebuild_pk`(IN p_table_name VARCHAR(200),
    IN p_col_name VARCHAR(200))
BEGIN
    -- 調(diào)用重建索引
    call win_rebuild_idx(p_table_name, 'PRIMARY', p_col_name);

END
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末臂寝,一起剝皮案震驚了整個(gè)濱河市智末,隨后出現(xiàn)的幾起案子篡撵,更是在濱河造成了極大的恐慌热某,老刑警劉巖畴嘶,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異队伟,居然都是意外死亡隧哮,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)稽犁,“玉大人焰望,你說(shuō)我怎么就攤上這事∫押ィ” “怎么了熊赖?”我有些...
    開(kāi)封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)虑椎。 經(jīng)常有香客問(wèn)我震鹉,道長(zhǎng),這世上最難降的妖魔是什么捆姜? 我笑而不...
    開(kāi)封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任传趾,我火速辦了婚禮,結(jié)果婚禮上娇未,老公的妹妹穿的比我還像新娘墨缘。我一直安慰自己,他們只是感情好零抬,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著宽涌,像睡著了一般平夜。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上卸亮,一...
    開(kāi)封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天忽妒,我揣著相機(jī)與錄音,去河邊找鬼兼贸。 笑死段直,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的溶诞。 我是一名探鬼主播鸯檬,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼螺垢!你這毒婦竟也來(lái)了喧务?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤枉圃,失蹤者是張志新(化名)和其女友劉穎功茴,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體孽亲,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡坎穿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片玲昧。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡栖茉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出酌呆,到底是詐尸還是另有隱情衡载,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布隙袁,位于F島的核電站痰娱,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏菩收。R本人自食惡果不足惜梨睁,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望娜饵。 院中可真熱鬧坡贺,春花似錦、人聲如沸箱舞。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)晴股。三九已至愿伴,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間电湘,已是汗流浹背隔节。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留寂呛,地道東北人怎诫。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像贷痪,于是被迫代替她去往敵國(guó)和親幻妓。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容