Localisation efficace de l'instance de sous-chaîne finale dans SQL Server
Un défi fréquent dans la manipulation de chaînes SQL Server consiste à identifier la dernière occurrence d'une sous-chaîne particulière. Bien qu'une fonction dédiée "LastIndexOf" soit absente, des méthodes efficaces existent.
Méthode traditionnelle : inversion et analyse de chaînes
Une approche typique, bien que lourde, consiste à inverser la chaîne, à trouver la première instance de la sous-chaîne cible dans la chaîne inversée (en utilisant CHARINDEX
), puis à inverser l'index pour obtenir la position d'origine. Cette technique, bien que fonctionnelle, est complexe et manque de lisibilité.
Approche améliorée : tirer parti de RIGHT()
et de LEFT()
Les fonctions RIGHT()
et LEFT()
de SQL Server offrent une solution plus simple et plus efficace. Pour extraire la partie d'une chaîne après le dernier trait de soulignement ("_"), utilisez RIGHT()
:
<code class="language-sql">SELECT RIGHT(db_name(), CHARINDEX('_', REVERSE(db_name() + '_') ) - 1)</code>
À l'inverse, pour obtenir la sous-chaîne avant le trait de soulignement final, employez LEFT()
:
<code class="language-sql">SELECT LEFT(db_name(), LEN(db_name()) - CHARINDEX('_', REVERSE(db_name() + '_')) )</code>
Ces expressions utilisent intelligemment CHARINDEX()
pour localiser le trait de soulignement dans la chaîne inversée et LEN()
pour déterminer la longueur de la chaîne. Cette combinaison permet une extraction rapide et précise des sous-chaînes sans le processus alambiqué d'inversion de chaîne.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!