Table of Contents
解剖SQLSERVER 第八篇  OrcaMDF 现在支持多数据文件的数据库(译)
Home Database Mysql Tutorial 解剖SQLSERVER 第八篇 OrcaMDF 现在支持多数据文件的数据库(译

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

Jun 07, 2016 pm 03:20 PM
sqlserver support Now

解剖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>
Copy after login

这会引起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>
Copy after login

运行之后的结果是

解剖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>
Copy after login

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

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

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

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

将会一直到100

 

第八篇完

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to import mdf file into sqlserver How to import mdf file into sqlserver Apr 08, 2024 am 11:41 AM

The import steps are as follows: Copy the MDF file to SQL Server's data directory (usually C:\Program Files\Microsoft SQL Server\MSSQL\DATA). In SQL Server Management Studio (SSMS), open the database and select Attach. Click the Add button and select the MDF file. Confirm the database name and click the OK button.

How to solve the problem that the object named already exists in the sqlserver database How to solve the problem that the object named already exists in the sqlserver database Apr 05, 2024 pm 09:42 PM

For objects with the same name that already exist in the SQL Server database, the following steps need to be taken: Confirm the object type (table, view, stored procedure). IF NOT EXISTS can be used to skip creation if the object is empty. If the object has data, use a different name or modify the structure. Use DROP to delete existing objects (use caution, backup recommended). Check for schema changes to make sure there are no references to deleted or renamed objects.

What to do if the sqlserver service cannot be started What to do if the sqlserver service cannot be started Apr 05, 2024 pm 10:00 PM

When the SQL Server service fails to start, here are some steps to resolve: Check the error log to determine the root cause. Make sure the service account has permission to start the service. Check whether dependency services are running. Disable antivirus software. Repair SQL Server installation. If the repair does not work, reinstall SQL Server.

How to check sqlserver port number How to check sqlserver port number Apr 05, 2024 pm 09:57 PM

To view the SQL Server port number: Open SSMS and connect to the server. Find the server name in Object Explorer, right-click it and select Properties. In the Connection tab, view the TCP Port field.

Where is the sqlserver database? Where is the sqlserver database? Apr 05, 2024 pm 08:21 PM

SQL Server database files are usually stored in the following default location: Windows: C:\Program Files\Microsoft SQL Server\MSSQL\DATALinux: /var/opt/mssql/data The database file location can be customized by modifying the database file path setting.

How to recover accidentally deleted database in sqlserver How to recover accidentally deleted database in sqlserver Apr 05, 2024 pm 10:39 PM

If you accidentally delete a SQL Server database, you can take the following steps to recover: stop database activity; back up log files; check database logs; recovery options: restore from backup; restore from transaction log; use DBCC CHECKDB; use third-party tools. Please back up your database regularly and enable transaction logging to prevent data loss.

How to delete sqlserver if the installation fails? How to delete sqlserver if the installation fails? Apr 05, 2024 pm 11:27 PM

If the SQL Server installation fails, you can clean it up by following these steps: Uninstall SQL Server Delete registry keys Delete files and folders Restart the computer

How to change sqlserver English installation to Chinese How to change sqlserver English installation to Chinese Apr 05, 2024 pm 10:21 PM

SQL Server English installation can be changed to Chinese by following the following steps: download the corresponding language pack; stop the SQL Server service; install the language pack; change the instance language; change the user interface language; restart the application.

See all articles