Partition1:新建分區表

来源:http://www.cnblogs.com/ljhdo/archive/2016/12/02/5016007.html
-Advertisement-
Play Games

未分區的表,只能存儲在一個FileGroup中;對Table進行分區後,每一個分區都存儲在一個FileGroup,或分散式存儲在不同的FileGroup中。對錶進行分區的過程,是將邏輯上完整的一個表,按照特定的欄位拆分成多個分區,分散到(相同或不同的)FileGroup中,每一個部分叫做表的一個分區 ...


未分區的表,只能存儲在一個FileGroup中;對Table進行分區後,每一個分區都存儲在一個FileGroup,或分散式存儲在不同的FileGroup中。對錶進行分區的過程,是將邏輯上完整的一個表,按照特定的欄位拆分成多個分區,分散到(相同或不同的)FileGroup中,每一個部分叫做表的一個分區(Partition)。

分區(Partition)的特性是:

  • 每一個Partition在FileGroup中都獨立存儲,分區之間是相互獨立的
  • 每一個parititon都屬於唯一的表對象,
  • 每一個Partition 都有唯一的ID,
  • 每一個Partition都有一個編號(Partition Number),同一個表的分區編號是唯一的,從1開始遞增;

對錶進行分區,能夠將數據的操作局限在某一個分區中,從而減少數據查找的IO次數,降低產生Deadlock和阻塞的概率,提供數據更新的併發度,提高查詢性能。

在創建表時,使用On 子句指定table存儲的邏輯位置:

  • ON  filegroup | "default" :表示邏輯存儲位置是單一的FileGroup;
  • ON  partition_scheme_name ( partition_column_name ) :表示邏輯存儲位置是分區架構,按照partition_column將table拆分成多個partition,每一個partition都存儲在一個指定的Filegroup中;
CREATE TABLE  [schema_name . ] table_name 
(  <column_definition>  )
[ ON { partition_scheme_name ( partition_column_name ) | filegroup | "default" } ] 
[ WITH ( <table_option> [ ,...n ] ) ]
[ ; ]

從存儲空間來理解分區,Partition實際上是表的一部分邏輯存儲空間。未分區表的邏輯存儲位置是FileGroup,分區表的邏輯存儲位置是Partition Scheme,但是,FileGroup指定一個特定的邏輯存儲位置,而Partition Scheme是分散式的,能夠將數據分散式存儲到不同的FileGroup中去。

跟邏輯存儲空間相對應的是物理存儲空間,物理存儲空間是由File指定的,FileGroup是File的集合,每一個File都屬於唯一的FileGroup。將table的存儲空間拆分到不同的FileGroup中,將table的物理存儲空間分佈到不同的File中,只不過,不再是某一個FileGroup。實際存儲數據的文件仍然是File。

在SQL Server中,File Group和Partition Scheme統稱為Data Sapce(數據空間),預設的Data Space是Primary,即主文件組。

新建分區表分為三步,分別是:

Step1, 創建分區函數

分區函數的作用是提供分區欄位的類型和分區的邊界值,進而決定分區的數量

CREATE PARTITION FUNCTION [pf_int](int) 
AS RANGE LEFT 
FOR VALUES (10, 20)

分區函數pf_int 的含義是按照int類型分區,分區的邊界值是10,20,left表示邊界值屬於左邊界。兩個邊界值能夠分成三個分區,別是(-infinite,10],(10,20],(20,+infinite)。

Step2,創建分區架構(Scheme)

分區架構的作用是為Parition分配FileGroup,在邏輯上,Partition Scheme和FileGroup是等價的,都是數據存儲的邏輯空間,只不過Partition Scheme指定的是多個FileGroup。

CREATE PARTITION SCHEME [ps_int] 
AS PARTITION [pf_int] 
TO ([PRIMARY], [db_fg1], [db_fg1])

不管是在不同的FileGroup中,還是在相同的FileGroup中,分區都是獨立存儲的。

Step3,新建分區表

新建分區表,實際上是在創建Table時,使用on子句指定數據存儲的邏輯位置是分區架構(Partition Scheme)

create table dbo.dt_test
(
    ID int,
    code int
)
on [ps_int] (id)

 

參考文檔:

Create Partitioned Tables and Indexes


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

-Advertisement-
Play Games
更多相關文章
  • 一個視圖顯示垂直滾動兩級列表中的條目。這不同於列表視圖,允許兩個層次,類似於QQ的好友分組。要實現這個效果的整體思路為: 1.要給ExpandableListView 設置適配器,那麼必須先設置數據源。 2.數據源,就是此處的適配器類,此方法繼承了BaseExpandableListAdapter, ...
  • ...
  • 當下,隨著移動時代的到來,手機功能逐步完善,各個行業針對這一現象紛紛制定了相應的營銷計劃,於是霎時間興起了一股網上訂票/網上訂飯/網上預約的熱潮。 而對於IT行業,成為企業信息化最火的代名詞莫過於移動辦公了,幾乎所有的軟體廠商都把推廣的重點轉移到移動辦公的市場上,幾乎在同一時間,大量的移動辦公APP ...
  • 前言: 目前工作負責兩個醫療APP項目的開發,同時使用LeanCloud進行雲端配合開發,完全單挑。 現大框架已經完成,正在進行細節模塊上的開發 抽空總結一下Android項目的開發規範:1、編碼規範 2、命名規範 註:個人經驗,經供參考 一、Android編碼規範 1、學會使用string.xml ...
  • android6.0之後許可權需要動態申請。 尤其是存儲許可權。 如果不申請會出現各種莫名其妙的bug。 本文說明瞭如何解決許可權申請的問題。 供大家參考和一起學習。 ...
  • 第一範式:確保每列的原子性(欄位不可分). 如果每列(或者每個屬性)都是不可再分的最小數據單元(也稱為最小的原子單元),則滿足第一範式. 例如:顧客表(姓名、編號、地址、……)其中"地址"列還可以細分為國家、省、市、區等。 第二範式:在第一範式的基礎上更進一層,目標是確保表中的每列都依賴於主鍵. 如 ...
  • flume配置: #DBFile DBFile.sources = sources1 DBFile.sinks = sinks1 DBFile.channels = channels1 # DBFile-DB-Source DBFile.sources.sources1.type = spooldi... ...
  • MYSQL保存BOOLEAN值時用1代表TRUE,0代表FALSE,boolean在MySQL里的類型為tinyint(1), MySQL里有四個常量:true,false,TRUE,FALSE,它們分別代表1,0,1,0, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...