目次
解剖SQLSERVER 第八篇  OrcaMDF 现在支持多数据文件的数据库(译)
ホームページ データベース mysql チュートリアル 解剖SQLSERVER 第八篇 OrcaMDF 现在支持多数据文件的数据库(译

解剖SQLSERVER 第八篇 OrcaMDF 现在支持多数据文件的数据库(译

Jun 07, 2016 pm 03:20 PM
sqlserver サポート

解剖SQLSERVER 第八篇 OrcaMDF 现在支持多数据文件的数据库(译) http://improve.dk/orcamdf-now-supports-databases-with-multiple-data-files/ OrcaMDF 其中一个最新特性是支持多数据文件的数据库。这在解析上面需要作出相关的小改变,实际上大部分都是bu

解剖SQLSERVER 第八篇  OrcaMDF 现在支持多数据文件的数据库(译)

http://improve.dk/orcamdf-now-supports-databases-with-multiple-data-files/

 

OrcaMDF 其中一个最新特性是支持多数据文件的数据库。这在解析上面需要作出相关的小改变,实际上大部分都是bug 修复代码

由于之前只支持单个数据文件而引起的。然而这确实需要一些重大的重构而离开MdfFile 的主入口点,现在使用数据库封装类,封装一个数据文件变量

 

 

分配比例填充

OrcaMDF 支持标准的数据库表的比例填充架构,这个数据库表除了有mdf文件之外还有ndf文件,而这些文件都在主文件组里,例如,你可能会创建以下数据文件或者架构

<span>CREATE</span> <span>DATABASE</span>
    <span>[</span><span>SampleDatabase</span><span>]</span>
<span>ON</span>  <span>PRIMARY</span><span> 
    (
        NAME </span><span>=</span> N<span>'</span><span>SampleDatabase_Data1</span><span>'</span><span>,
        FILENAME </span><span>=</span> N<span>'</span><span>C:SampleDatabase_Data1.mdf</span><span>'</span><span>,
        SIZE </span><span>=</span><span> 3072KB,
        FILEGROWTH </span><span>=</span><span> 1024KB
    ), 
    (
        NAME </span><span>=</span> N<span>'</span><span>SampleDatabase_Data2</span><span>'</span><span>,
        FILENAME </span><span>=</span> N<span>'</span><span>C:SampleDatabase_Data2.ndf</span><span>'</span><span>,
        SIZE </span><span>=</span><span> 3072KB,
        FILEGROWTH </span><span>=</span><span> 1024KB
    ), 
    (
        NAME </span><span>=</span> N<span>'</span><span>SampleDatabase_Data3</span><span>'</span><span>,
        FILENAME </span><span>=</span> N<span>'</span><span>C:SampleDatabase_Data3.ndf</span><span>'</span><span>,
        SIZE </span><span>=</span><span> 3072KB,
        FILEGROWTH </span><span>=</span><span> 1024KB
    )
</span><span>LOG</span> <span>ON</span><span>
    (
        NAME </span><span>=</span> N<span>'</span><span>SampleDatabase_log</span><span>'</span><span>,
        FILENAME </span><span>=</span> N<span>'</span><span>C:SampleDatabase_log.ldf</span><span>'</span><span>,
        SIZE </span><span>=</span><span> 3072KB,
        FILEGROWTH </span><span>=</span> <span>10</span><span>%</span><span>
    )
</span><span>GO</span>

<span>USE</span><span> SampleDatabase
</span><span>GO</span>

<span>CREATE</span> <span>TABLE</span><span> MyTable
(
    A </span><span>int</span> <span>identity</span><span>,
    B </span><span>uniqueidentifier</span> <span>default</span>(<span>newid</span><span>()),
    C </span><span>char</span>(<span>6000</span><span>)
)
</span><span>GO</span>

<span>INSERT</span> <span>INTO</span> MyTable <span>DEFAULT</span> <span>VALUES</span>
<span>GO</span> <span>100</span>
ログイン後にコピー

这会引起MyTable 按比例填充三个数据文件(C列的作用为了让SQLSERVER分配100个页面来装载数据,好让填满三个数据文件)

为了解析这种情况,我们需要做下面的工作

<span>var</span> files = <span>new</span><span>[]
    {
        </span><span>@"</span><span>C:SampleDatabase_Data1.mdf</span><span>"</span><span>,
        </span><span>@"</span><span>C:SampleDatabase_Data2.ndf</span><span>"</span><span>,
        </span><span>@"</span><span>C:SampleDatabase_Data3.ndf</span><span>"</span><span>
    };

</span><span>using</span> (<span>var</span> db = <span>new</span><span> Database(files))
{
    </span><span>var</span> scanner = <span>new</span><span> DataScanner(db);
    </span><span>var</span> result = scanner.ScanTable(<span>"</span><span>MyTable</span><span>"</span><span>);

    EntityPrinter.Print(result);
}</span>
ログイン後にコピー

运行之后的结果是

解剖SQLSERVER 第八篇  OrcaMDF 现在支持多数据文件的数据库(译

大家注意看:

A(4个字节)+B(16个字节)+C(6000个字节)=6020字节

解剖SQLSERVER 第八篇  OrcaMDF 现在支持多数据文件的数据库(译

刚好一条记录一页,下面说到,SQLSERVER分配完了一个区之后,一个区8个页面,当一个区分配完毕之后,SQLSERVER

会转到SampleDatabase_Data2.ndf数据文件继续分配页面,分配的值是9~16,一个区分配完毕之后又到

SampleDatabase_Data3.ndf数据文件继续分配页面,分配的值是17~24

解剖SQLSERVER 第八篇  OrcaMDF 现在支持多数据文件的数据库(译

 

自增值会一直到100,注意到A列有间隔,这是由于一个事实我们在每个数据文件的一个区里面以循环赛的方式来分配。

ID1~8在第一个数据文件,9~16在第二个数据文件最后17~24在第三个数据文件。由于这一点,页面25~32分配在第一个数据文件,一直这样下去

由于是堆表,我们使用文件分配顺序扫描,这导致我们获得结果1~8,25~32,49~56,73~80,97~100 全部都是从第一个文件开始,然后9~16,33~40

从第二个数据文件里读取然后到最后一个数据文件的剩余页面。想一下这是不是很怪,好吧,SQLSERVER里面也是完全一样的

解剖SQLSERVER 第八篇  OrcaMDF 现在支持多数据文件的数据库(译

不理解的童鞋可以看一下这篇文章《SQLSERVER中的ALLOCATION SCAN和RANGE SCAN》或者

《Microsoft SQL Server 2008技术内幕:T-SQL查询 笔记》里面有相关介绍

 

文件组支持

OrcaMDF 也支持使用文件组,包括按比例分配填充在一个单独的 文件组里,举个例子,你可能创建下面的数据库和架构

<span>CREATE</span> <span>DATABASE</span>
    <span>[</span><span>SampleDatabase</span><span>]</span>
<span>ON</span>  <span>PRIMARY</span><span> 
    (
        NAME </span><span>=</span> N<span>'</span><span>SampleDatabase_Data1</span><span>'</span><span>,
        FILENAME </span><span>=</span> N<span>'</span><span>C:SampleDatabase_Data1.mdf</span><span>'</span><span>,
        SIZE </span><span>=</span><span> 3072KB,
        FILEGROWTH </span><span>=</span><span> 1024KB
    )
</span><span>LOG</span> <span>ON</span><span>
    (
        NAME </span><span>=</span> N<span>'</span><span>SampleDatabase_log</span><span>'</span><span>,
        FILENAME </span><span>=</span> N<span>'</span><span>C:SampleDatabase_log.ldf</span><span>'</span><span>,
        SIZE </span><span>=</span><span> 3072KB,
        FILEGROWTH </span><span>=</span> <span>10</span><span>%</span><span>
    )
</span><span>GO</span>

<span>ALTER</span> <span>DATABASE</span>
    <span>[</span><span>SampleDatabase</span><span>]</span>
<span>ADD</span><span> FILEGROUP
    </span><span>[</span><span>SecondFilegroup</span><span>]</span>
<span>GO</span>

<span>ALTER</span> <span>DATABASE</span>
    <span>[</span><span>SampleDatabase</span><span>]</span>
<span>ADD</span> <span>FILE</span><span>
    (
        NAME </span><span>=</span> N<span>'</span><span>SampleDatabase_Data2</span><span>'</span><span>,
        FILENAME </span><span>=</span> N<span>'</span><span>C:SampleDatabase_Data2.ndf</span><span>'</span><span>,
        SIZE </span><span>=</span><span> 3072KB,
        FILEGROWTH </span><span>=</span><span> 1024KB
    ),
    (
        NAME </span><span>=</span> N<span>'</span><span>SampleDatabase_Data3</span><span>'</span><span>,
        FILENAME </span><span>=</span> N<span>'</span><span>C:SampleDatabase_Data3.ndf</span><span>'</span><span>,
        SIZE </span><span>=</span><span> 3072KB,
        FILEGROWTH </span><span>=</span><span> 1024KB
    )
</span><span>TO</span><span> FILEGROUP
    </span><span>[</span><span>SecondFilegroup</span><span>]</span>
<span>GO</span>

<span>USE</span><span> SampleDatabase
</span><span>GO</span>

<span>CREATE</span> <span>TABLE</span><span> MyTable
(
    A </span><span>float</span> <span>default</span>(<span>rand</span><span>()),
    B </span><span>datetime</span> <span>default</span>(<span>getdate</span><span>()),
    C </span><span>uniqueidentifier</span> <span>default</span>(<span>newid</span><span>()),
    D </span><span>char</span>(<span>5000</span><span>)
) </span><span>ON</span> <span>[</span><span>SecondFilegroup</span><span>]</span>
<span>GO</span>

<span>INSERT</span> <span>INTO</span> MyTable <span>DEFAULT</span> <span>VALUES</span>
<span>GO</span> <span>100</span>
ログイン後にコピー

这将会引起MyTable去按比例填充分配在第二和第三个数据文件之间(D列用来占位置,确保让SQLSERVER分配100个页面来装载数据,好让对文件组里的两个数据文件进行

分配填充)数据只会分别对第二和第三数据文件进行填充而主数据文件不受影响

跟先前的例子的解释一样,结果如下

解剖SQLSERVER 第八篇  OrcaMDF 现在支持多数据文件的数据库(译

将会一直到100

 

第八篇完

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

指定されたオブジェクトが sqlserver データベースにすでに存在するという問題を解決する方法 指定されたオブジェクトが sqlserver データベースにすでに存在するという問題を解決する方法 Apr 05, 2024 pm 09:42 PM

SQL Server データベースに既に存在する同じ名前のオブジェクトについては、次の手順を実行する必要があります。 オブジェクトの種類 (テーブル、ビュー、ストアド プロシージャ) を確認します。 IF NOT EXISTS を使用すると、オブジェクトが空の場合に作成をスキップできます。オブジェクトにデータがある場合は、別の名前を使用するか、構造を変更してください。既存のオブジェクトを削除するには、DROP を使用します (注意してください。バックアップを推奨します)。スキーマの変更をチェックして、削除または名前変更されたオブジェクトへの参照がないことを確認します。

mdfファイルをsqlserverにインポートする方法 mdfファイルをsqlserverにインポートする方法 Apr 08, 2024 am 11:41 AM

インポート手順は次のとおりです。 MDF ファイルを SQL Server のデータ ディレクトリ (通常は C:\Program Files\Microsoft SQL Server\MSSQL\DATA) にコピーします。 SQL Server Management Studio (SSMS) でデータベースを開き、[アタッチ] を選択します。 「追加」ボタンをクリックして、MDF ファイルを選択します。データベース名を確認し、「OK」ボタンをクリックします。

sqlserver サービスを開始できない場合の対処方法 sqlserver サービスを開始できない場合の対処方法 Apr 05, 2024 pm 10:00 PM

SQL Server サービスの開始に失敗した場合の解決手順は次のとおりです。 エラー ログを確認して、根本原因を特定します。サービス アカウントにサービスを開始する権限があることを確認してください。依存関係サービスが実行されているかどうかを確認します。ウイルス対策ソフトウェアを無効にします。 SQL Server のインストールを修復します。修復が機能しない場合は、SQL Server を再インストールします。

SQLサーバーのポート番号を確認する方法 SQLサーバーのポート番号を確認する方法 Apr 05, 2024 pm 09:57 PM

SQL Server のポート番号を表示するには: SSMS を開いてサーバーに接続します。オブジェクト エクスプローラーでサーバー名を見つけ、右クリックして [プロパティ] を選択します。 「接続」タブで、「TCP ポート」フィールドを表示します。

SQLserver データベースはどこにありますか? SQLserver データベースはどこにありますか? Apr 05, 2024 pm 08:21 PM

SQL Server データベース ファイルは、通常、次のデフォルトの場所に保存されます。 Windows: C:\Program Files\Microsoft SQL Server\MSSQL\DATALinux: /var/opt/mssql/data データベース ファイルの場所は、データベース ファイル パスを変更することでカスタマイズできます。設定。

sqlserverで誤って削除したデータベースを回復する方法 sqlserverで誤って削除したデータベースを回復する方法 Apr 05, 2024 pm 10:39 PM

SQL Server データベースを誤って削除した場合は、次の手順を実行して回復できます: データベース アクティビティの停止、ログ ファイルのバックアップ、データベース ログの確認、回復オプション: バックアップからの復元、トランザクション ログからの復元、DBCC CHECKDB の使用、3 番目の使用パーティーツール。データ損失を防ぐために、データベースを定期的にバックアップし、トランザクション ログを有効にしてください。

インストールが失敗した場合に sqlserver を削除するにはどうすればよいですか? インストールが失敗した場合に sqlserver を削除するにはどうすればよいですか? Apr 05, 2024 pm 11:27 PM

SQL Server のインストールが失敗した場合は、次の手順に従ってクリーンアップできます。 SQL Server をアンインストールする レジストリ キーを削除する ファイルとフォルダーを削除する コンピューターを再起動する

sqlserver 英語インストールを中国語に変更する方法 sqlserver 英語インストールを中国語に変更する方法 Apr 05, 2024 pm 10:21 PM

次の手順に従って、SQL Server の英語インストールを中国語に変更できます: 対応する言語パックをダウンロードする、SQL Server サービスを停止する、言語パックをインストールする、インスタンス言語を変更する、ユーザー インターフェイス言語を変更する、アプリケーションを再起動する。

See all articles