觸發器正確用法

来源:https://www.cnblogs.com/13yan/archive/2018/09/18/9671938.html
-Advertisement-
Play Games

關鍵字:架構設計 軟體質量保證 資料庫完整性 1、資料庫完整性討論 有許多同學認為開發階段沒必要建立外鍵約束,更不用建立檢查約束,因為會影響單表數據寫入做測試。 這個想法是非常錯誤的,不規範的,不專業的。 首先影不影響測試是無稽之談,說明這類同學開發時不會寫單元測試,通過野路子來測試,質量不保。 然 ...


關鍵字:架構設計 軟體質量保證 資料庫完整性

 

1、資料庫完整性討論

有許多同學認為開發階段沒必要建立外鍵約束,更不用建立檢查約束,因為會影響單表數據寫入做測試。

這個想法是非常錯誤的,不規範的,不專業的。

首先影不影響測試是無稽之談,說明這類同學開發時不會寫單元測試,通過野路子來測試,質量不保。

然後完整性約束包含主外鍵約束的,是數據反應現實世界真實情況的保證,如果沒有完整性約束,數據可能是無意義的,那麼無意義的數據寫入了也是無意義,測試也是無意義,測試通過的只是一段無意義但結果湊巧對了的代碼。

 

所以嚴格設計資料庫,除了遵循範式之外,完整性約束是必須的。

 

2、觸發器的作用

很多時候代碼更加面向對象了,要求業務邏輯都能在代碼的業務邏輯層體現,是不推薦將業務邏輯分散到代碼、資料庫等多處,集中寫,集中管理。

所以觸發器和存儲過程將會更少地使用,那麼觸發器在當今代碼界還有什麼作用呢?

一般情況是用來保證數據完整性和安全性。

 

我們知道可以給表中某個欄位建立檢查約束(check),有一種情況是檢查約束做不到的。

不能因為難做,就放棄了完整性的控制,檢查約束做不到,就用觸發器(插入性能損失,怕什麼!觸發器是可以停用的,不能將鍋都甩給性能)。

 

我們來看一個需求:

現在有一個游戲,然後游戲策劃搞了一次活動推出一個禮包,這個禮包只允許在活動期間充值5000元以上的用戶才能下單購買,活動期間等於禮包上架時間到下架時間,那麼除了在業務代碼中下單前檢查用戶在活動期間充值情況以外,如何在資料庫完整性設計中體現呢?

---------------------------------------------

用戶(用戶id,用戶名)

用戶充值(用戶id,充值金額,充值時間)

禮包訂單(訂單id,用戶id,禮包id)

禮包(禮包id,禮包名,上架時間,下架時間,價格)

---------------------------------------------

通常,我們在下訂單的時候,寫入禮包訂單表記錄,然後有外鍵約束的存在,驗證了禮包、用戶,那麼如何驗證用戶的充值呢?

沒辦法使用檢查約束吧,因為充值金額和禮包上下架時間並不包含在禮包訂單里。

這個時候用觸發器就是正解了。


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

-Advertisement-
Play Games
更多相關文章
  • 半年前跳槽, 新公司主要研發傾向於小程式的開發。由於之前並沒有接觸小程式,所以經過半年的實際開發,才敢來做一點筆記。 小程式提供很多組件給開發者使用,但是,實際使用中還是會有很多的問題。 老生常談的不能使用npm開發??? (雖然,已知的很多小程式框架可以實現。例如:mpvue等。但是讓我們先討論討 ...
  • 在 JavaScript 中正確使用地使用 Array 的方法如下: 用 Array.includes 代替 Array.indexOf “如果你要在數組中查找元素,請使用 Array.indexOf”。 MDN 文檔寫道,Array.indexOf 將“返回第一次出現給定元素的索引”。因此,如果我 ...
  • 今天是我們介紹數組系列文章的第五篇,也是我們數組系列的最後一篇文章,只是數據系列的結束,所以大家不用擔心,我們會持續的更新乾貨文章。 生命不息,更新不止! 今天我們就不那麼多廢話了,直接乾貨開始。 我們在《Javascript數組系列一之棧與隊列》中描述我們是如何利用 push、pop、shift、 ...
  • 什麼是斷點操作(Breakpoint action) 做前端開發的小伙伴,或許對這個斷點操作不是很熟悉。不過你要是問其他語言(比如C,C++ ,C #等)的開發者,他們應該都挺熟悉斷點操作,這種斷點操作在諸如XCode或者Visual Studio的IDE中都會有提供。 以下一段話來自知乎 斷點操作 ...
  • JavaScript語言從設計之初就是考慮帶分號的,使用不帶分號的編碼規則就要小心點啦。 ...
  • 1、解決HTML中的編碼問題 2、列表的使用 3、HTML中的表格標記 4、表單標記 ...
  • 一.Bootstrap 概述Bootstrap 是由 Twitter 公司(全球最大的微博)的兩名技術工程師研發的一個基於HTML、CSS、JavaScript 的開源框架。該框架代碼簡潔、視覺優美,可用於快速、簡單地構建基於 PC 及移動端設備的 Web 頁面需求。2010 年 6 月,Twitt ...
  • 原文出自: "http://cmsblogs.com" 獲取 Document 對象後,會根據該對象和 Resource 資源對象調用 方法,開始註冊 BeanDefinitions 之旅。如下: 首先調用 方法實例化 BeanDefinitionDocumentReader 對象,然後獲取統計前 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...