Procédure : créer un entrepôt avec un classement qui ne respecte pas la casse
S'applique à :✅ Entrepôt dans Microsoft Fabric
Tous les entrepôts Fabric sont configurés par défaut avec un classement qui respecte la casse Latin1_General_100_BIN2_UTF8. Vous pouvez également créer des entrepôts avec un classement qui ne respecte pas la casse - Latin1_General_100_CI_AS_KS_WS_SC_UTF8.
Pour le moment, la seule méthode disponible pour créer un entrepôt de données qui ne respecte pas la casse consiste à utiliser l’API REST. Cet article fournit un guide pas à pas sur la création d’un entrepôt avec un classement qui ne respecte pas la casse via l’API REST. Il explique également comment utiliser Visual Studio Code avec l’extension REST Client pour faciliter le processus.
Important
Une fois qu’un entrepôt est créé, le paramètre de classement ne peut plus être changé. Réfléchissez soigneusement à vos besoins avant de lancer le processus de création.
Prérequis
- Un espace de travail Fabric avec une capacité active ou une capacité d’essai.
- Téléchargez et installez Visual Studio Code pour télécharger et installer l’application.
- Installez l’extension REST Client - Visual Studio Marketplace.
Point de terminaison d’API
Pour créer un entrepôt avec l’API REST, utilisez le point de terminaison d’API : POST https://api.fabric.microsoft.com/v1/workspaces/<workspace-id>/items
Voici un exemple de corps de la demande JSON pour la création d’un entrepôt :
{
"type": "Warehouse",
"displayName": "CaseInsensitiveAPIDemo",
"description": "New warehouse with case-insensitive collation",
"creationPayload": {
"defaultCollation": "Latin1_General_100_CI_AS_KS_WS_SC_UTF8"
}
}
Utiliser Visual Studio Code pour appeler l’API REST
Vous pouvez facilement créer un entrepôt avec un classement qui ne respecte pas la casse à l’aide de Visual Studio Code (VS Code) et l’extension REST Client. Effectuez les étapes suivantes :
Créez un fichier texte dans VS Code avec l’extension
.http
.Entrez les détails de la requête dans le corps du fichier. Notez qu’un espace vide doit être présent entre l’en-tête et le corps, après la ligne « Authorization ».
POST https://api.fabric.microsoft.com/v1/workspaces/<workspaceID>/items HTTP/1.1 Content-Type: application/json Authorization: Bearer <bearer token> { "type": "Warehouse", "displayName": "<Warehouse name here>", "description": "<Warehouse description here>", "creationPayload": { "defaultCollation": "Latin1_General_100_CI_AS_KS_WS_SC_UTF8" } }
Remplacez les valeurs d’espace réservé :
<workspaceID>
: recherchez le GUID de l’espace de travail dans l’URL après la section/groups/
, ou en exécutantSELECT @@SERVERNAME
dans un entrepôt existant.<bearer token>
: obtenez-le en procédant comme suit :- Ouvrez votre espace de travail Microsoft Fabric dans un navigateur (Microsoft Edge ou Google Chrome).
- Appuyez sur F12 pour ouvrir les Outils de développement.
- Sélectionnez l’onglet Console. Si nécessaire, sélectionnez Développer Affichage rapide pour faire apparaître l’invite de console
>
. - Tapez la commande
copy(powerBIAccessToken)
, puis appuyez sur Entrée. Même si la console répond « undefined », le jeton du porteur est copié dans votre Presse-papiers. - Collez-le à la place de
<bearer token>
.
Remarque
Dans certains scénarios,
copy(powerBIAccessToken)
peut échouer avec l’erreuruncaught TypeError: copy is not a function
s’il existe un ID d’élément nommé « copy » dans la page. Dans ce cas, supprimez manuellement l’ID d’élément à l’aide de la commande suivante avant d’utiliser la fonction « copy » :document.querySelector('#copy').remove()
.<Warehouse name here>
: entrez le nom souhaité pour l’entrepôt.<Warehouse description here>
: entrez la description souhaitée pour l’entrepôt.
Sélectionnez le lien Envoyer la demande affiché au-dessus de votre commande POST dans l’éditeur VS Code.
Vous devez recevoir une réponse avec le code d’état 202 Accepted ainsi que des détails supplémentaires sur votre requête POST.
Accédez à l’entrepôt qui vient d’être créé dans le portail Fabric.
Exécutez l’instruction T-SQL suivante dans l’Éditeur de requête pour vérifier que le classement de votre entrepôt correspond à ce que vous avez spécifié dans le contenu JSON ci-dessus :
SELECT name, collation_name FROM sys.databases;