La fonction CONCAT est généralement utilisée pour la fusion de plusieurs champs en une seule chaîne. Cependant, lorsque l'un des champs concaténés contient une valeur NULL, le résultat de la concaténation est NULL. Ce comportement est particulièrement important au moment de travailler avec des données pouvant avoir des valeurs manquantes ou vides.
Observez la requête SQL suivante :
SELECT
CONCAT(ssot__Individual__dlm.ssot__FirstName__c, ' - ', ssot__Individual__dlm.KQ_Id__c) AS FullName_KQId__c,
COUNT(ssot__Individual__dlm.ssot__Id__c) AS RecordCount__c
FROM ssot__Individual__dlm
GROUP BY CONCAT(ssot__Individual__dlm.ssot__FirstName__c, ' - ', ssot__Individual__dlm.KQ_Id__c);
Dans cette requête :
FullName_KQId__c is created by concatenating ssot__FirstName__c and KQ_Id__c avec un trait d'union (-) comme séparateur.
Si ssot__FirstName__c ou KQ_Id__c est NULL, tout le champFullName_KQId__c sera NULL.
| ssot__FirstName__c | KQ_Id__c | FullName_KQId__c |
|---|---|---|
| John | 123 | John - 123 |
| Jane | NULL | NULL |
| NULL | 456 | NULL |
Pour éviter que les valeurs NULL impactent le résultat concaténé, pensez à utiliser une instruction CASE pour remplacer les valeurs NULL par une chaîne vide. Par exemple :
SELECT
CONCAT(
CASE WHEN ssot__Individual__dlm.ssot__FirstName__c IS NULL THEN '' ELSE ssot__Individual__dlm.ssot__FirstName__c END,
' - ',
CASE WHEN ssot__Individual__dlm.KQ_Id__c IS NULL THEN '' ELSE ssot__Individual__dlm.KQ_Id__c END
) AS FullName_KQId__c,
COUNT(ssot__Individual__dlm.ssot__Id__c) AS RecordCount__c
FROM ssot__Individual__dlm
GROUP BY
CONCAT(
CASE WHEN ssot__Individual__dlm.ssot__FirstName__c IS NULL THEN '' ELSE ssot__Individual__dlm.ssot__FirstName__c END,
' - ',
CASE WHEN ssot__Individual__dlm.KQ_Id__c IS NULL THEN '' ELSE ssot__Individual__dlm.KQ_Id__c END
);
Si un champ dans la fonction CONCAT est NULL, tout le résultat est NULL.
Utilisez une instruction CASE pour remplacer les valeurs NULL par une chaîne vide et assurez-vous que la concaténation se passe comme prévu.
Une gestion appropriée des valeurs vides peut empêcher une perte de données imprévue et améliorer la précision des rapports.
En implémentant ces meilleures pratiques, vous pouvez vous assurer que vos connaissances calculées restent fiables et utiles, et ce même lorsque vous avez affaire à des données incomplètes.
004269012

We use three kinds of cookies on our websites: required, functional, and advertising. You can choose whether functional and advertising cookies apply. Click on the different cookie categories to find out more about each category and to change the default settings.
Privacy Statement
Required cookies are necessary for basic website functionality. Some examples include: session cookies needed to transmit the website, authentication cookies, and security cookies.
Functional cookies enhance functions, performance, and services on the website. Some examples include: cookies used to analyze site traffic, cookies used for market research, and cookies used to display advertising that is not directed to a particular individual.
Advertising cookies track activity across websites in order to understand a viewer’s interests, and direct them specific marketing. Some examples include: cookies used for remarketing, or interest-based advertising.