Installer Microsoft ODBC Driver for SQL Server (macOS)
Cet article explique comment installer Microsoft ODBC Driver for SQL Server sur macOS. Il contient également des instructions pour les outils en ligne de commande facultatifs pour SQL Server (bcp
et sqlcmd
) et les en-têtes de développement unixODBC.
Cet article fournit des commandes pour installer le pilote ODBC à partir de l’interpréteur de commandes bash. Si vous souhaitez télécharger les packages directement, consultez Télécharger ODBC Driver for SQL Server.
Notes
Le pilote Microsoft ODBC pour SQL Server sur macOS est pris en charge uniquement sur l’architecture x64 jusqu’à la version 17.7. La prise en charge d’Apple ARM64 a été ajoutée à partir de la version 17.8. L’architecture est détectée et le package approprié est automatiquement installé par la formule Homebrew. Si votre invite de commandes s’exécute en mode émulation x64 sur ARM64, le package x64 est installé. Si vous n’êtes pas en mode émulation dans votre invite de commandes, le package ARM64 est installé.
En outre, le répertoire par défaut Homebrew a changé avec l’architecture ARM64, en /opt/homebrew
. Les chemins d’accès spécifiés dans la section Fichiers de pilote utilisent x64 Homebrew, qui sont par défaut /usr/local
, de sorte que vos chemins d’accès aux fichiers varient en conséquence.
Microsoft ODBC 18
Pour installer Microsoft ODBC Driver 18 for SQL Server sur macOS, exécutez les commandes suivantes :
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
brew tap microsoft/mssql-release https://github.com/Microsoft/homebrew-mssql-release
brew update
HOMEBREW_ACCEPT_EULA=Y brew install msodbcsql18 mssql-tools18
Versions précédentes
Les sections suivantes fournissent des instructions pour l’installation des versions précédentes du pilote Microsoft ODBC sur macOS.
Microsoft ODBC 17
Pour installer le pilote Microsoft ODBC 17 pour SQL Server sur macOS, exécutez les commandes suivantes :
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
brew tap microsoft/mssql-release https://github.com/Microsoft/homebrew-mssql-release
brew update
HOMEBREW_ACCEPT_EULA=Y brew install msodbcsql17 mssql-tools
Important
Si vous avez installé le package msodbcsql
v17 qui n’a pas été disponible longtemps, vous devez le supprimer avant d’installer le package msodbcsql17
. Cette opération évitera les conflits. Le package msodbcsql17
peut être installé côte à côte avec le package msodbcsql
v13.
ODBC 13.1
Utilisez les commandes suivantes pour installer le pilote Microsoft ODBC 13.1 pour SQL Server sur OS X 10.11 (El Capitan) et macOS 10.12 (Sierra) :
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
brew tap microsoft/mssql-release https://github.com/Microsoft/homebrew-mssql-release
brew update
brew install msodbcsql@13.1.9.2 mssql-tools@14.0.6.0
Fichiers de pilote
Le pilote ODBC sur macOS est constitué des composants suivants :
Composant | Description |
---|---|
libmsodbcsql.18.dylib ou libmsodbcsql.17.dylib ou libmsodbcsql.13.dylib | Fichier de bibliothèque dynamique (dylib ) contenant l’ensemble des fonctionnalités du pilote. Ce fichier est installé dans /usr/local/lib/ . |
msodbcsqlr18.rll ou msodbcsqlr17.rll ou msodbcsqlr13.rll |
Fichier de ressources qui accompagne la bibliothèque du pilote. Ce fichier est installé dans [driver .dylib directory]../share/msodbcsql18/resources/en_US/ pour Driver 18, [driver .dylib directory]../share/msodbcsql17/resources/en_US/ pour Driver 17 et [driver .dylib directory]../share/msodbcsql/resources/en_US/ pour Driver 13. |
msodbcsql.h | Fichier d’en-tête qui contient toutes les nouvelles définitions nécessaires à l’utilisation du pilote. Remarque : Vous ne pouvez pas référencer msodbcsql.h et odbcss.h dans le même programme. msodbcsql.h est installé dans /usr/local/include/msodbcsql18/ pour Driver 18, /usr/local/include/msodbcsql17/ pour Driver 17 et /usr/local/include/msodbcsql/ pour Driver 13. |
LICENSE.txt | Fichier texte qui contient les termes du contrat de licence utilisateur final. Ce fichier est placé dans /usr/local/share/doc/msodbcsql18/ pour Driver 18, /usr/local/share/doc/msodbcsql17/ pour Driver 17 et /usr/local/share/doc/msodbcsql/ pour Driver 13. |
RELEASE_NOTES | Fichier texte qui contient les notes de publication. Ce fichier est placé dans /usr/local/share/doc/msodbcsql18/ pour Driver 18, /usr/local/share/doc/msodbcsql17/ pour Driver 17 et /usr/local/share/doc/msodbcsql/ pour Driver 13. |
Chargement du fichier de ressources
Le pilote doit charger le fichier de ressources pour pouvoir fonctionner. Ce fichier est appelé msodbcsqlr18.rll
, msodbcsqlr17.rll
ou msodbcsqlr13.rll
selon la version du pilote. L’emplacement du fichier .rll
est relatif à l’emplacement du pilote lui-même (so
ou dylib
), comme indiqué dans le tableau des composants. Depuis la version 17.1, le pilote tente aussi de charger le fichier .rll
à partir du répertoire par défaut si le chargement échoue à partir du chemin d’accès relatif. Le chemin du fichier de ressources par défaut sur macOS est /usr/local/share/msodbcsql18/resources/en_US/
.
Dépannage
Certains utilisateurs rencontrent un problème lors de la tentative de connexion après l’installation du pilote ODBC et reçoivent une erreur semblable à la suivante : "[01000] [unixODBC][Driver Manager]Can't open lib 'ODBC Driver 18 for SQL Server' : file not found (0) (SQLDriverConnect)"
. Cela peut être le cas si unixODBC n’est pas configuré correctement pour trouver les pilotes inscrits. Dans ce cas, la création de liens symboliques peut résoudre le problème.
sudo ln -s /usr/local/etc/odbcinst.ini /etc/odbcinst.ini
sudo ln -s /usr/local/etc/odbc.ini /etc/odbc.ini
Si vous ne parvenez pas à établir de connexion à SQL Server à l’aide du pilote ODBC, consultez l’article sur les problèmes connus pour résoudre les problèmes de connexion.
Si brew n’arrive pas à trouver les formules, vérifiez que vous n’avez pas manqué l’étape d’installation : brew tap microsoft/mssql-release https://github.com/Microsoft/homebrew-mssql-release