Mysql - 增量腳本中修改欄位屬性

来源:http://www.cnblogs.com/elvinle/archive/2017/12/21/8081456.html
-Advertisement-
Play Games

在增量部署系統的時候, 經常需要提供增量修改的腳本, 如果是修改存儲過程或者自定義函數, 那還是很好改的, 不用擔心表功能收到影響. 如果是改欄位呢? 首先不知道欄位是不是已經在系統裡面, 沒有的話, 需要新增上去, 有的話, 需不需要修改? 其次, 腳本如果報錯, 是否會重覆執行一下腳本? 會不會 ...


在增量部署系統的時候, 經常需要提供增量修改的腳本, 如果是修改存儲過程或者自定義函數, 那還是很好改的, 不用擔心表功能收到影響. 

如果是改欄位呢?

首先不知道欄位是不是已經在系統裡面, 沒有的話, 需要新增上去, 有的話, 需不需要修改?

其次, 腳本如果報錯, 是否會重覆執行一下腳本? 會不會導致別的問題呢? 看腳本裡面執行結果報了好多錯, 總覺得, 會被運維鄙視一遍. 做開發的, 真受不了別人鄙視自己的東西.

直接用sql去新增, 修改欄位, 好像不太行, 經常會有問題.

正所謂, 條條大路通羅馬. 一條路走不通, 我們換一條路走吧.

那麼, 換一種思路, 不直接用表操作sql去改欄位, 而是通過存儲過程的方式來改. 對欄位進行判斷, 再修改, 那麼你提供的腳本就是可重覆執行腳本, 且不會報錯.

delimiter $
drop procedure if exists pro_put_column;
create procedure pro_put_column()
BEGIN

    if not exists(select * from information_schema.COLUMNS where TABLE_SCHEMA=database() 
    and table_name='表名' and COLUMN_NAME='欄位名') 
    THEN
        alter table 表名 add column 欄位名 varchar(50);
    ELSE
        alter table 表名 MODIFY COLUMN 欄位名 varchar(51);
    end if;

END $
delimiter ;

call pro_put_column();

可以先查詢欄位是否存在, 再決定要不要加, 或者要不要改. 後面的邏輯, 就根據實際需要去修改就可了.

如果確定是新增欄位, 那麼else部分完全可以刪除掉. 

就是每改一個欄位, 都要去查詢一次, 有點不方便. 寫的東西更多了.  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1,什麼是負載均衡? 由於目前現有網路的各個核心部分隨著業務量的提高,訪問量和數據流量的快速增長,其處理能力和計算強度也相應地增大,使得單一的伺服器設備根本無法承擔。在此情況下,如果扔掉現有設備去做大量的硬體升級,這樣將造成現有資源的浪費,而且如果再面臨下一次業務量的提升時,這又將導致再一次硬體升級 ...
  • 1.搜尋執行檔——which which指令主要是在PATH所包含的目錄中去搜尋執行檔的檔名,若加上-a參數就可以搜尋除所有包含檔案的信息 上面列出root賬號的PATH包含的目錄,which命令會在這些目錄中去查看文件 如果文件不在這些目錄中就會提示找不到,如下 cd檔案用which找不到,因為c ...
  • 初學Redhat,有不對的地方見諒 man手冊用法 man(選項)(參數) 其中man手冊主體分為以下幾個部分 man手冊部分 代號 內容說明 NAME 簡短的命令、數據名稱說明(命令名稱及功能簡要說明) SYNOPSIS 簡短的命令執行語法簡介(用法說明,包括可用的選項) DESCRIPTION ...
  • 最近因為要學習Python,於是把放在家裡接了一年灰的樹莓派又給搜出來了,剛買那會也搗鼓了好一陣子, 基本操作都學會了,但現在又忘光了,只能又從頭開始搞了,首先第一個要解決的是怎麼把文件從電腦傳輸到樹莓派 ,記得以前是在Windows上傳的,直接在網上下載了一個軟體,filezilla,打開輸入板卡 ...
  • 通過啟用屏幕共用來開啟遠程桌面登錄,開啟後需要關閉encryption,否則會出現無法連接的情況。關閉encryption可以使用系統配置工具dconf來完成。所以先安裝dconf-editor。 更新源並安裝系統配置工具(不更新源無法進行安裝) 1、查看系統版本 2、添加更新源,更新源內容可以從網 ...
  • 一、環境 VMware12 Pro CentOS-6.7-i386-bin-DVD1 jdk-8u151-linux-i586 二、詳細安裝步驟 前提:需要卸載自己Linux上的jdk rpm -qa | grep jdk 會顯示你所有包含jdk這個字元串的安裝包 rpm -e --nodeps 對 ...
  • 目錄 一、概述 二、MySQL安裝 三、安裝成功驗證 四、NavicatforMySQL下載及使用 一、概述 MySQL版本:5.7.17 下載地址:http://rj.baidu.com/soft/detail/12585.html?ald 客戶端工具:NavicatforMySQL 綠色版下載地 ...
  • 項目需要定時備份資料庫,以下是自己的操作筆記 1.檢查磁碟空間 這是我當前linux伺服器的情況,至於為什麼是這樣子,我也不清楚(我是半路接過來的,無奈) 根據上面的信息,我就把備份文件放在/dev目錄下麵 2.創建備份目錄 3.創建備份shell命令 輸入如下內容 對備份進行壓縮 註意: 把 us ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...