mysql做運算還是程序做運算(mysql算數運算)

  • 1、數字技術是用mysql sum還是java計算哪個快
  • 2、mysql數據庫可以進行怎樣的數學運算
  • 3、mysql不能分析數據嗎
  • 4、做邏輯運算時,寫程序里好還是sql數據庫里好
  • 5、MySQL高性能SQL注意事項簡述
  • 6、數據庫中的數據運算,有的SQL能實現,程序語言同樣能實現,是用SQL運算?還是用程序語言?

sum函數在數據庫是number類型的,你的代碼中可以使用任何裝的下數字型都可以接收。如:sum的值小於java中int的最大值,你就可以用int接收;如果大於Int的最大值而小於double的最大值,你就可以用double。一般在程序設計時,如果不確定它的值範圍,可以用long型接收。

$sql=”SELECT COUNT(*) AS count FROM mark WHERE hID = ‘$hid'”;$result = mysql_fetch_array(mysql_query($sql));$count  = $result[‘count’];$count++;$numOfScore = $count;    

12    $count = mysql_result(mysql_query(“SELECT COUNT(*) AS count FROM mark WHERE hID = $hid”),0);$numOfScore = $count + 1;

可以分析數據 ,像一些運算可以直接在Mysql裡面操作,比如:底薪+獎金+績效 等等分析 ,業務邏輯複雜的話,Mysql是不能做的,只能靠一些服務器端程序去操作

邏輯運算

時,寫程序里好還是

sql數據庫

里好

如果你的數據庫服務比較繁忙,還是放到CS中處理較好。

數據庫的任務主要是保存數據/查詢數據

計算的事,能放在CS中盡量放到CS中。

數據庫作為應用開發中必不缺少的基礎設施,其性能直接影響應用的整體運行速度。MySQL是目前最廣泛使用的關係型數據庫之一,對於開發人員寫出性能良好的SQL是必備的基本技能之一。下面簡單描述下編寫SQL的注意事項。

編寫高質量的SQL需要從以下幾個方面注意,基本原則、表字段注意事項、索引使用注意事項、SQL注意事項。

基本原則

一、盡量不要在數據庫里做運算。如果遇到運算儘可能在應用程序層進行計算。

二、控制數據庫表數量、控制單表數據量、控制表的字段數。建議單庫不要超過四百張表,建議單表字段不要超過五十個,建議單表的數據量不要超過一千萬。

三、不要編寫大SQL、不要使用大事務。SQL盡量寫的簡單點拒絕編寫大SQL,可以將大SQL拆分成多個小SQL,在應用層聚合。大事務拆分成多個小事務,快速提交。

表字段注意事項

一、選擇合適數值字段類型。能用小字段類型的就用小字段類型,如tinyint就比int(1)在表示小數據時合適。

二、能用數字表示就不要用字符。如可以用無符號INT存儲IP而不是字符串表示。

三、避免使用NULL字段。原因NULL字段查詢優化難,含NULL複合索引失效。

四、少用或拆分TEXT/BLOB字段。字段太大需要更多的空間,性能低下,如需使用拆分到單獨表。

五、不要在表字段中存儲圖片。

索引使用注意事項

一、合理添加索引。索引添加太多會影響更新速度。能夠使用複合索引的避免加多個單獨索引。

二、字符字段建立前綴索引。

三、不在索引列做運算。索引列做運算會導致索引失效。

四、盡量不使用外建。

SQL類注意事項

一、 SQL語句儘可能簡單。大SQL拆分成多個小SQL。

二、事務編寫盡量短小。事務即開即用用完立即關閉。

三、盡量不要使用select *。只取需要的列。

四、改寫OR為IN或者改寫為UNION操作。OR在數據量大的時候性能低於IN。

五、避免NOT、!=、、NOT IN、NOT EXISTS、NOT LIKE等查詢。

六、避免%前綴模糊查詢。

七、能用UNION ALL不要用UNION。

八、GROUP BY中去除排序。自帶排序。

九、同類型的字段做比較。字符類和字符類比較,數值類和數值類比較,不要混在一起比較。

十、盡量單表查詢,盡量不要多表關聯查詢。多表關聯查詢可以拆分成單表查詢在應用程序中聚合數據。

十一、複合索引的多列注意最左原則。

上述注意事項能避免很多性能低下的SQL,希望在開發過程中能引起注意。

一般來說,在sql端運算效率肯定是比程序運算要高的。

至於怎麼選擇是根據系統的特性而言的,假如應用程序非常龐大,或者業務邏輯相對複雜,又或者訪問壓力大,這時候,你如果將計算的工作放在服務端程序中,這會加大服務端的處理壓力,從而影響到應用程序的性能。

這時候,你可以讓數據庫來分擔運算壓力,是個不錯的選擇。

同樣的道理,如果你的應用程序的服務端壓力不大,而數據庫方面每時每刻都要處理和統計許多報表數據,那麼用程序來完成某部分的運算也不錯。

撇開性能問題,還有一點也要考慮到,數據運算肯定會跟業務邏輯耦合在一起的,如果處理數據不用擔心性能問題,那麼不妨在架構上做出一些考慮:盡量讓業務邏輯集中在兩端,要不在SQL的存儲過程中,要不在程序的業務類中,這樣顯得各層之間耦合度更松,架構更為清晰、合理,便於維護和擴展。

原創文章,作者:簡單一點,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/127290.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
簡單一點的頭像簡單一點
上一篇 2024-10-03 23:13
下一篇 2024-10-03 23:13

相關推薦

  • 如何修改mysql的端口號

    本文將介紹如何修改mysql的端口號,方便開發者根據實際需求配置對應端口號。 一、為什麼需要修改mysql端口號 默認情況下,mysql使用的端口號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • Python程序需要編譯才能執行

    Python 被廣泛應用於數據分析、人工智能、科學計算等領域,它的靈活性和簡單易學的性質使得越來越多的人喜歡使用 Python 進行編程。然而,在 Python 中程序執行的方式不…

    編程 2025-04-29
  • python強行終止程序快捷鍵

    本文將從多個方面對python強行終止程序快捷鍵進行詳細闡述,並提供相應代碼示例。 一、Ctrl+C快捷鍵 Ctrl+C快捷鍵是在終端中經常用來強行終止運行的程序。當你在終端中運行…

    編程 2025-04-29
  • Python程序文件的拓展

    Python是一門功能豐富、易於學習、可讀性高的編程語言。Python程序文件通常以.py為文件拓展名,被廣泛應用於各種領域,包括Web開發、機器學習、科學計算等。為了更好地發揮P…

    編程 2025-04-29
  • Python購物車程序

    Python購物車程序是一款基於Python編程語言開發的程序,可以實現購物車的相關功能,包括商品的添加、購買、刪除、統計等。 一、添加商品 添加商品是購物車程序的基礎功能之一,用…

    編程 2025-04-29
  • 爬蟲是一種程序

    爬蟲是一種程序,用於自動獲取互聯網上的信息。本文將從如下多個方面對爬蟲的意義、運行方式、應用場景和技術要點等進行詳細的闡述。 一、爬蟲的意義 1、獲取信息:爬蟲可以自動獲取互聯網上…

    編程 2025-04-29
  • Vb運行程序的三種方法

    VB是一種非常實用的編程工具,它可以被用於開發各種不同的應用程序,從簡單的計算器到更複雜的商業軟件。在VB中,有許多不同的方法可以運行程序,包括編譯器、發布程序以及命令行。在本文中…

    編程 2025-04-29
  • Python一元二次方程求解程序

    本文將詳細闡述Python一元二次方程求解程序的相關知識,為讀者提供全面的程序設計思路和操作方法。 一、方程求解 首先,我們需要了解一元二次方程的求解方法。一元二次方程可以寫作: …

    編程 2025-04-29
  • 如何使用GPU加速運行Python程序——以CSDN為中心

    GPU的強大性能是眾所周知的。而隨着深度學習和機器學習的發展,越來越多的Python開發者將GPU應用於深度學習模型的訓練過程中,提高了模型訓練效率。在本文中,我們將介紹如何使用G…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL數據庫 在使用Python操作MySQL之前,我們需要先連接MySQL數據庫。在Python中,我…

    編程 2025-04-29

發表回復

登錄後才能評論