解剖SQLSERVER 第八篇 OrcaMDF 现在支持多数据文件的数据库(译
解剖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>
运行之后的结果是
大家注意看:
A(4个字节)+B(16个字节)+C(6000个字节)=6020字节
刚好一条记录一页,下面说到,SQLSERVER分配完了一个区之后,一个区8个页面,当一个区分配完毕之后,SQLSERVER
会转到SampleDatabase_Data2.ndf数据文件继续分配页面,分配的值是9~16,一个区分配完毕之后又到
SampleDatabase_Data3.ndf数据文件继续分配页面,分配的值是17~24
自增值会一直到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中的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个页面来装载数据,好让对文件组里的两个数据文件进行
分配填充)数据只会分别对第二和第三数据文件进行填充而主数据文件不受影响
跟先前的例子的解释一样,结果如下
将会一直到100
第八篇完

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



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.

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.

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.

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.

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.

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.

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

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.
