Le déterminisme est une idée selon laquelle pour un ensemble d'entrées valides donné, une procédure va toujours renvoyer le même résultat. Avant SQL Server 2000, le déterminisme n'était pas très important, mais avec l'arrivée de l'indexation des vues et des colonnes calculées, cette notion devient capitale. Pour construire un index
Comprendre le déterminisme
sur quelque chose, SQL Server a besoin de définir avec déterminisme (définir
avec certitude) l’élément qui sera indexé.
Les UDF peuvent être déterministes ou non déterministes. C’est le rôle de la fonction,
plus que de ses paramètres, qui définit son déterminisme. SUM() est une fonction
intégrée déterministe : la somme de 3, 5 et 10 reste toujours 18, à chaque fois
que la fonction est invoquée avec ces valeurs. GETDATE(), à l’inverse, est non
déterministe : la valeur que renvoie la fonction change pratiquement à chaque
appel.
Pour être déterministe, une fonction doit remplir trois critères. Premièrement,
la fonction doit être liée à un schéma. Tout objet dont dépend la fonction possède
une dépendance répertoriée et aucune modification de cet objet n’est permise (via
une instruction ALTER par exemple) à moins que l’on n’exécute la fonction DROP
au préalable sur la fonction dépendante. Ensuite, toutes les autres fonctions
auxquelles la fonction fait référence, qu’elles soient programmées par l’utilisateur
ou par le système, doivent aussi être déterministes. Enfin, la fonction ne peut
pas faire référence à un objet non déterministe (ce qui élimine tous les objets
à l’exception des autres fonctions) en dehors de l’étendue de la fonction.
Si on construit une vue ou une colonne calculée faisant référence à une fonction
non déterministe, on ne peut pas construire d’index sur cette vue ou colonne calculée.
Cette limitation n’est pas la fin du monde en soi, mais il faudra déterminer si
une fonction est déterministe ou non avant de créer des index sur des vues ou
des colonnes utilisant cette fonction.
Téléchargez cette ressource
Créer des agents dans Microsoft 365 Copilot
Insight vous guide dans l’utilisation de la nouvelle expérience de création d’agents dans Microsoft Copilot Studio, disponible dans Copilot Chat. Découvrez les étapes clés pour concevoir, configurer et déployer ces nouveaux agents et injecter la puissance de l’IA directement dans le flux de travail.
Les articles les plus consultés
- Activer la mise en veille prolongée dans Windows 10
- N° 2 : Il faut supporter des langues multiples dans SharePoint Portal Server
- Cybersécurité Active Directory et les attaques de nouvelle génération
- Partager vos images, vidéos, musique et imprimante avec le Groupe résidentiel
- IBM i célèbre ses 25 ans
Les plus consultés sur iTPro.fr
- Souveraineté numérique : réinvestir les fondations pour sortir de la dépendance à Microsoft
- L’essor de l’IA propulse les cyberattaques à des niveaux records
- L’IA sous contrôle : un impératif pour la souveraineté des entreprises
- CESIN : un baromètre qui mesure le risque cyber réel
Articles les + lus
CES 2026 : l’IA physique et la robotique redéfinissent le futur
Les 3 prédictions 2026 pour Java
Semi-conducteurs : comment l’Irlande veut contribuer à atténuer la pénurie mondiale de puces
Face à l’urgence écologique, l’IT doit faire sa révolution
D’ici 2030, jusqu’à 90 % du code pourrait être écrit par l’IA, pour les jeunes développeurs, l’aventure ne fait que commencer
À la une de la chaîne Tech
- CES 2026 : l’IA physique et la robotique redéfinissent le futur
- Les 3 prédictions 2026 pour Java
- Semi-conducteurs : comment l’Irlande veut contribuer à atténuer la pénurie mondiale de puces
- Face à l’urgence écologique, l’IT doit faire sa révolution
- D’ici 2030, jusqu’à 90 % du code pourrait être écrit par l’IA, pour les jeunes développeurs, l’aventure ne fait que commencer
