Fonctionnement du moteur des rapports

Révision de 5 décembre 2017 à 14:52 par Jcheng (discuter | contributions) (Afficher/cacher des colonnes en fonction des champs)

Aller à : navigation, rechercher

Présentation

L'objet de cette page est de présenter le fonctionnement du moteur des rapports.

Bibliothèque des rapports

Requête dynamique

La présence du tag "[OF_DYNAMIC_SQL]" dans un rapport, permet d'identifier une requête dynamique.

Une requête dynamique est une requête SELECT construisant une autre requête SELECT à l'intérieur d'elle-même. L'on nomme cette autre requête, une requête imbriquée.

Les requêtes dynamiques sont principalement utilisées pour afficher sous forme de colonne, des données provenant de champs métiers comme par exemple, pour le rapport Coordonnées (avec profil X et/ou validité Y expirant à une date postérieure ou égale à Z).

Exemple de requête dynamique avec des variables : La requête imbriquée sert à obtenir les utilisateurs d'un certain profil.

[OF_DYNAMIC_SQL]
SELECT '
  SELECT *
  FROM person
  LEFT profile ON person.profile & profile.id
  WHERE profile.id=\'$profileId\'
'
FROM ma_table
WHERE mon_champ='$monId'

Pour les variable associé à un champ de type dbObject::Multi, l'utilisation de la variable dans la requête imbriquée doit être écrite de telle sorte :

[OF_DYNAMIC_SQL]
SELECT CONCAT('
  SELECT *
  FROM person
  LEFT profile ON person.profile & profile.id
  WHERE ( profile.id IN (', IF('-' IN ($profileId), '\'-\'', '$profileId'), ') OR \'-\' IN (', IF('-' IN ($profileId), '\'-\'', '$profileId'), ') )')
FROM ma_table
WHERE mon_champ='$monId'

La requête imbriquée permet d'obtenir cela :

SELECT *
FROM person
LEFT profile ON person.profile & profile.id
WHERE ( profile.id IN ($profileId) OR '-' IN ($profileId) )

Afficher/cacher des colonnes en fonction des champs

L'utilisation de requête dynamique permet d'afficher/cacher des colonnes en fonction des champs.

C'est dans la requête imbriquée où se fait le choix d'afficher ou non, les colonnes désirées.

Par exemple, le rapport Coordonnées (avec profil X et/ou validité Y expirant à une date postérieure ou égale à Z) cache les colonnes liées aux validités lorsqu'aucun type de validité n'est sélectionné.

Exemple de requête de base qui récupère les utilisateurs et leurs validités :

SELECT person.id AS ID, last_name AS Nom, first_name AS Prénom,
    validity_type.name AS 'Validité'
FROM person
LEFT JOIN validity ON (person.id=validity.person_id)
LEFT JOIN validity_type ON (validity_type.id=validity.validity_type_id)
WHERE person.activated=1
  AND (
      (validity.validity_type_id IN ($validityTypeId) AND validity_type.time_limitation=1)
      OR
      '-' IN ($validityTypeId)
  )
ORDER BY last_name, first_name

Exemple de la requête transformée en requête dynamique :

[OF_DYNAMIC_SQL]
SELECT CONCAT('
    SELECT person.id AS ID, last_name AS Nom, first_name AS Prénom,
        validity_type.name AS \'Validité\'
    FROM person
    LEFT JOIN validity ON (person.id=validity.person_id)
    LEFT JOIN validity_type ON (validity_type.id=validity.validity_type_id)
    WHERE person.activated=1
      AND (
          (validity.validity_type_id IN ($validityTypeId) AND validity_type.time_limitation=1)
          OR
          \'-\' IN (', IF('-' IN ($validityTypeId), '\'-\'', '$validityTypeId'), ')
      )
    ORDER BY last_name, first_name
')

Exemple pour cacher la colonne "Validité" lorsque rien n'est sélectionné pour la variable $validityTypeId :

[OF_DYNAMIC_SQL]
SELECT CONCAT('
    SELECT person.id AS ID, last_name AS Nom, first_name AS Prénom',
        IF('-' IN ($validityTypeId), '', ', validity_type.name AS \'Validité\', )', ' 
    FROM person
    LEFT JOIN validity ON (person.id=validity.person_id)
    LEFT JOIN validity_type ON (validity_type.id=validity.validity_type_id)
    WHERE person.activated=1
      AND (
          (validity.validity_type_id IN ($validityTypeId) AND validity_type.time_limitation=1)
          OR
          \'-\' IN (', IF('-' IN ($validityTypeId), '\'-\'', '$validityTypeId'), ')
      )
    ORDER BY last_name, first_name
')

Remplacement des variables

Variable associé à un champ de type dbObject

Une variable associée à ce type de champ recevra comme valeur possible :

  • Lorsque "Pas de filtre" est sélectionné, le caractère : -
  • Lorsqu'une valeur est sélectionnée, un id sous forme de nombre

Exemple de rapport : Liste des utilisateurs actifs possédant le profil "$profileId"

SELECT person.*
FROM person
LEFT JOIN profile ON person.profile & profile.id
WHERE profile.id='$profileId'
  AND activated=1

Exemple de remplacement :

SELECT person.*
FROM person
LEFT JOIN profile ON person.profile & profile.id
WHERE profile.id='1'
  AND activated=1

Exemple de rapport : Liste des utilisateurs actifs avec ou non, un filtrage sur le profil "$profileId"

SELECT *
FROM person
LEFT JOIN profile ON person.profile & profile.id
WHERE ( profile.id='$profileId' OR '-'='$profileId' )

Dans ce rapport, cette partie permet d'assurer le filtrage :

profile.id='$profileId'

Et cette partie s'assurer le non-filtrage :

'-'='$profileId'

Exemple de remplacement assurant le filtrage :

SELECT *
FROM person
LEFT JOIN profile ON person.profile & profile.id
WHERE ( profile.id='1' OR '-'='1' )

Exemple de remplacement assurant le non-filtrage :

SELECT *
FROM person
LEFT JOIN profile ON person.profile & profile.id
WHERE ( profile.id='-' OR '-'='-' )

Exemple de rapport avec une requête dynamique :

[OF_DYNAMIC_SQL]
SELECT 'SELECT *
  FROM person
  LEFT JOIN profile ON person.profile & profile.id
  WHERE ( profile.id=\'$profileId\' OR \'-\'=\'$profileId\' )'
FROM ma_table
WHERE mon_champ='$unId'

Variable associé à un champ de type dbObjectMulti

Une variable associée à ce type de champ recevra comme valeur possible :

  • Lorsque rien n'est coché, la chaîne : '-'. Cela est considéré comme "Pas de filtre".
  • Lorsqu'une valeur est cochée, un id sous forme de nombre
  • Lorsque plusieurs valeurs sont cochées, plusieurs id sous forme de chaîne suivante : 1,2,3

Exemple de rapport : Liste des utilisateurs actifs avec ou non, un filtrage sur le(s) profil(s) "$profileId"

SELECT *
FROM person
LEFT JOIN profile ON person.profile & profile.id
WHERE ( profile.id IN ($profileId) OR '-' IN ($profileId) )

Dans ce rapport, cette partie permet d'assurer le filtrage :

profile.id IN ($profileId)

Et cette partie s'assurer le non-filtrage :

'-' IN ($profileId)

Exemples de remplacement assurant le filtrage :

SELECT *
FROM person
LEFT JOIN profile ON person.profile & profile.id
WHERE ( profile.id IN (1) OR '-' IN (1) )
SELECT *
FROM person
LEFT JOIN profile ON person.profile & profile.id
WHERE ( profile.id IN (1,2,4) OR '-' IN (1,2,4) )

Exemple de remplacement assurant le non-filtrage :

SELECT *
FROM person
LEFT JOIN profile ON person.profile & profile.id
WHERE ( profile.id IN ('-') OR '-' IN ('-') )

Exemple de rapport avec une requête dynamique :

[OF_DYNAMIC_SQL]
SELECT CONCAT('SELECT *
  FROM person
  LEFT JOIN profile ON person.profile & profile.id
  WHERE ( profile.id IN (', IF('-' IN ($profileId), '\'-\'', '$profileId'), ') OR \'-\' IN (', IF('-' IN ($profileId), '\'-\'', '$profileId'), ') )')
FROM ma_table
WHERE mon_champ='$unId'

Visualisation de rapport

Lors d'une demande de visualisation de rapport, le moteur des rapports :

  • Récupère les valeurs des champs de saisie affichées dans le formulaire et stocke ces valeurs dans les variables correspondantes à ces champs de saisie
  • Extrait la requête du rapport
  • Remplace dans la requête, chaque variable par leur valeur correspondante
  • Interprète la requête. Lors d'une requête dynamique, celle-ci est interprété une seconde fois
  • Affiche le résultat sous forme de tableau

Exemple de rapport :

SELECT *
FROM ma_table
WHERE mon_champ='$maVariable'

Exemple de rapport après remplacement des variables :

SELECT *
FROM ma_table
WHERE mon_champ='1'
SELECT *
FROM ma_table
WHERE mon_champ='test'