Table des matières
解剖SQLSERVER 第八篇  OrcaMDF 现在支持多数据文件的数据库(译)
Maison base de données tutoriel mysql 解剖SQLSERVER 第八篇 OrcaMDF 现在支持多数据文件的数据库(译

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

Jun 07, 2016 pm 03:20 PM
sqlserver 支持 Maintenant

解剖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>
Copier après la connexion

这会引起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>
Copier après la connexion

运行之后的结果是

解剖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>
Copier après la connexion

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

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

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

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

将会一直到100

 

第八篇完

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment résoudre le problème selon lequel l'objet nommé existe déjà dans la base de données sqlserver Comment résoudre le problème selon lequel l'objet nommé existe déjà dans la base de données sqlserver Apr 05, 2024 pm 09:42 PM

Pour les objets du même nom qui existent déjà dans la base de données SQL Server, les étapes suivantes doivent être suivies : Confirmez le type d'objet (table, vue, procédure stockée). IF NOT EXISTS peut être utilisé pour ignorer la création si l'objet est vide. Si l'objet contient des données, utilisez un nom différent ou modifiez la structure. Utilisez DROP pour supprimer des objets existants (soyez prudent, sauvegarde recommandée). Vérifiez les modifications de schéma pour vous assurer qu'il n'y a aucune référence à des objets supprimés ou renommés.

Comment importer un fichier mdf dans sqlserver Comment importer un fichier mdf dans sqlserver Apr 08, 2024 am 11:41 AM

Les étapes d'importation sont les suivantes : Copiez le fichier MDF dans le répertoire de données de SQL Server (généralement C:\Program Files\Microsoft SQL Server\MSSQL\DATA). Dans SQL Server Management Studio (SSMS), ouvrez la base de données et sélectionnez Attacher. Cliquez sur le bouton Ajouter et sélectionnez le fichier MDF. Confirmez le nom de la base de données et cliquez sur le bouton OK.

Que faire si le service sqlserver ne peut pas être démarré Que faire si le service sqlserver ne peut pas être démarré Apr 05, 2024 pm 10:00 PM

Lorsque le service SQL Server ne parvient pas à démarrer, voici quelques étapes à résoudre : Consultez le journal des erreurs pour déterminer la cause première. Assurez-vous que le compte de service est autorisé à démarrer le service. Vérifiez si les services de dépendance sont en cours d'exécution. Désactivez le logiciel antivirus. Réparez l'installation de SQL Server. Si la réparation ne fonctionne pas, réinstallez SQL Server.

Comment vérifier le numéro de port sqlserver Comment vérifier le numéro de port sqlserver Apr 05, 2024 pm 09:57 PM

Pour afficher le numéro de port SQL Server : Ouvrez SSMS et connectez-vous au serveur. Recherchez le nom du serveur dans l'Explorateur d'objets, cliquez dessus avec le bouton droit et sélectionnez Propriétés. Dans l'onglet Connexion, affichez le champ Port TCP.

Où est la base de données sqlserver ? Où est la base de données sqlserver ? Apr 05, 2024 pm 08:21 PM

Les fichiers de base de données SQL Server sont généralement stockés à l'emplacement par défaut suivant : Windows : C:\Program Files\Microsoft SQL Server\MSSQL\DATALinux : /var/opt/mssql/data L'emplacement du fichier de base de données peut être personnalisé en modifiant le chemin du fichier de base de données. paramètre.

Comment récupérer une base de données supprimée accidentellement dans SQLserver Comment récupérer une base de données supprimée accidentellement dans SQLserver Apr 05, 2024 pm 10:39 PM

Si vous supprimez accidentellement une base de données SQL Server, vous pouvez suivre les étapes suivantes pour la récupérer : arrêter l'activité de la base de données ; sauvegarder les fichiers journaux ; vérifier les options de récupération : restaurer à partir d'une sauvegarde ; utiliser DBCC CHECKDB ; outils de fête. Veuillez sauvegarder régulièrement votre base de données et activer la journalisation des transactions pour éviter toute perte de données.

Comment supprimer sqlserver si l'installation échoue ? Comment supprimer sqlserver si l'installation échoue ? Apr 05, 2024 pm 11:27 PM

Si l'installation de SQL Server échoue, vous pouvez la nettoyer en suivant ces étapes : Désinstaller SQL Server Supprimer les clés de registre Supprimer les fichiers et dossiers Redémarrer l'ordinateur

Comment changer l'installation anglaise de sqlserver en chinois Comment changer l'installation anglaise de sqlserver en chinois Apr 05, 2024 pm 10:21 PM

L'installation de SQL Server en anglais peut être modifiée en chinois en suivant les étapes suivantes : téléchargez le module linguistique correspondant ; arrêtez le service SQL Server ; modifiez la langue de l'instance ; modifiez la langue de l'interface utilisateur ;

See all articles