資料庫SQL,NoSQL之小感悟

来源:http://www.cnblogs.com/5207/archive/2017/02/09/6382860.html
-Advertisement-
Play Games

遇到1000萬數據表 最近遇到一個問題,就是單表數據過1000萬的存儲及查詢問題。舉個例子:1000萬的數據存在一個表中,欄位4 5個樣子,日常 開發中難免要做過濾、排序、分頁。如果把這幾個放在一起即要過濾又要排序,還要分頁那麼數據量大一些就會發現特別慢。 10多年前剛入行時就聽許多的人討論分頁,說 ...


遇到1000萬數據表

最近遇到一個問題,就是單表數據過1000萬的存儲及查詢問題。舉個例子:1000萬的數據存在一個表中,欄位4-5個樣子,日常 開發中難免要做過濾、排序、分頁。如果把這幾個放在一起即要過濾又要排序,還要分頁那麼數據量大一些就會發現特別慢。

10多年前剛入行時就聽許多的人討論分頁,說什麼1000萬大表分頁存儲過程啥的。我之後一直工作中也沒怎麼遇到大數據量的開發工作,也真是慚愧啊,現在算是補補課吧。

1000萬數據分個頁吧

常用的資料庫產品對分頁都是有一些支持的,SQL語句肯定是OK的,同樣的問題在於如何高效。因為分頁查詢最大的問題在於查詢越往後的數據就越慢,因為要掃描的數據多。比如要查詢第9999900-10000000之前的記錄,就得將前面的數據找起。

為什麼會這樣呢?因為數據存在存儲介質里,是一種數據結構的,電腦通過指令來查找想要的數據就要有一種演算法,因為機器本身不知道你想要哪些數據。所以在數據寫入時的自然順序會在具體查找時變成麻煩。

換句話說,如果不在乎時間長短,那麼分頁查詢其實也沒多大事,大不行等個幾十秒也能出來數據。但現實是這很難被接受。所以現在有一些方法來加快這個過程。

比如人們就想出一個方法,在分頁查詢前記錄一下最後那頁的記錄的ID,然後查詢時直接從這個ID往後找數據,這種方法就解決了上面說的掃描問題,利用資料庫的數據檢索功能大大提升性能。

但這種方法有弊端,畢竟這個ID需要有順序啊,所取的數據也要是排過序的。但這說明想要提升效率方法是有的。

索引

我也不知道為什麼,一直以來就很懼怕資料庫方面的開發,我心中索引一直是個很複雜的東西,所以工作許久也沒有好好去學習一下。最近正好親密接觸了一下,才發現這東西真是好東西,也沒有想象中的那麼可怕。

所謂索引其實就是對特定的數據進行一種排序,然後與實際的數據記錄作映射,這樣的好處就是掃描數據時可以在一個有序的集合里查找,那麼演算法自然就簡單高效啦。在實際應用中也發現,通過索引查詢性能可以大幅提升。

當然索引並沒有這麼簡單,在什麼欄位上建索引很有講究,要根據實際業務情況來決定。這也就是為什麼一些電商的網站很少會有所有欄位都給排序的原因,因為這種成本是很昂貴的,甚至不可實現。大家註意淘寶是不是只給了特定的一些排序方式?

NoSQL

N多年前在NoSql開始流行時我就想學習來著,但可能是自己太懶的原因,直到今年我才開始瞭解了NoSql。目前聽的最多的Mongodb,甚至還有Redis也稱為Nosql,HBase之類的。它們有什麼特別呢?

我覺得Nosql最大的特點在於基於Key-value,這個特點的好處就是易於數據的擴展。傳統資料庫一旦遇到數據大了要麼就是分庫、分表,還有垂直,水平分的。但是NoSql天然解決這個問題,因為數據可以通過演算法進行橫向擴展。而且Nosql通常保存的數據結構也比較特別。另外Nosql通常是利用記憶體多於磁碟,這樣可以大大提升讀寫效率吧。

在K-V的基礎上提供一些類SQL的功能,就變得非常好用了。比如Mongodb可以實現過濾、排序、分頁等操作,這對於開發人員來說簡直神了,不用擔心跨庫或者跨表查詢啦。

但是也有弊端,比如join操作可能就沒這麼好玩啦。

SQL+NoSQL

最近看到國內有個團隊在做一處TiDB的開源項目,是基於google的論文開發的一套資料庫,特點就是相容mysql,同時又有nosql的高效和擴展性。這簡直更神了,我只能膜拜。只不過我連mongodb都還不會,所以這種好東西我暫時也沒有去瞭解。有空要學習學習吧。

結語

看起來複雜的東西其實道理不複雜,對,簡單的就是好的。



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

-Advertisement-
Play Games
更多相關文章
  • 個人微信公眾號:zhaoyanjun125 , 歡迎關註 QQ交流群:431048982 ...
  • Paint類的常用的方法 1.setColor方法,用於設置畫筆的顏色,public void setColor(int color)//參數color為顏色值,也可以使用Color類定義的顏色Color.BLACK:黑色Color.BLUE:藍色Color.CYAN:青綠色Color.DKGRAY ...
  • 知識點: 1.UIScrollView使用 2.UIPageControl使用 @interface RootViewController ()<UIScrollViewDelegate> UIScrollView使用 1.UIScrollView創建 2.常用屬性 1)滾動內容大小 2)是否分頁滾 ...
  • 知識點: 1.UITableView搜索功能 <UITableViewDataSource,UITableViewDelegate,UISearchResultsUpdating,UISearchControllerDelegate> UITableView搜索功能 1.UISearchContro ...
  • 一、引言在iOS開發中使用動畫時,可以通過設置動畫的duration、speed、begintime、offset屬性,來設置動畫的時長、速度、起始時間及起始偏移。用一個簡單的例子來說明各個參數的的作用。動畫很簡單,一個紅色的方塊從左移到右邊。動畫的持續時間是1s,沒有重覆,效果如下。 CFTime... ...
  • 首先看一下界面: SharedPreferencesUtils.java ...
  • 一個小故事 某天,小王正在和HR妹妹閑聊,正HAPPY時,,突然收到系統告警消息,資料庫磁碟被剩餘空間500M,OMG,不行,磁碟快滿了,要是業務要停了,,那就小王只能刪庫到跑路了,,, 先檢查下,有沒有可以刪除的不用的文件,結果都是重要的或者拿不准的。先收縮下資料庫吧,點擊運行。等收縮完成就可以繼 ...
  • 1、 " DUAL 表 " 2、 " ROWID 類型 " 2.1、 "利用 ROWID 查詢數據" 2.2、 "利用 ROWID 更新數據" 3、 " NULL 值 " 3.1、 "NULL 與空字元串" 3.2、 "NULL 與函數" 3.3、 "NULL 與索引" 3.4、 "NULL 與 S ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...