Table des matières

Création des classes métier

Produit :

Ligne :

Commande :

Categorie :

Produits et catégories

A partir de l'observation de cette première implémentation et en utilisant à bon escient la documentation, répondez aux questions suivantes :
  1. Comment est déclarée la table assurant la persistance d’un objet ?
  2. La persistance de la table est assurée par l'héritage de KObject.

  3. Comment est déclaré le mapping entre un membre de la classe et un champ de la table relationnelle ?
  4. Le mapping entre un membre de la classe et un champ de la table relationnelle est déclaré grâce à hasMany et belongsTo.

  5. Comment est déclarée la clé primaire de la table ?
  6. La clé primaire de la table est déclarée par un "keyFields".

  7. Réaliser un tableau montrant la correspondance de type (entier, chaine, etc.) entre les propriétés d’une classe et les champs d’une table.
  8. Java SQL
    Entier int int
    Chaîne de caractères String String
    Flottant Float Float


  9. Montrez à l’aide d’un schéma (par ex. deux classes liées au dessus de deux tables liées) comment se paramètre le lien bidirectionnel entre deux classes (en spécifiant les éléments à fournir dans le constructeur)


Programme de test

Analysez le code du programme et répondez aux questions en vous aidant au besoin de la documentation :
  1. À quoi correspond la méthode kstart() ?
  2. La méthode kstart() permet la démarrage de l'application.

  3. Comment ont été traduits les liens objet entre le membre categorie et produits entre ces classes dans les tables de la base ?
  4. Le lien entre le membre categorie et produits a été traduit par l'affectation d'une catégorie à l'objet produit, ce qui équivalent à une clé étrangère.

  5. Quelles requêtes SQL ont été créées par KObject pour réaliser la persistance ?
  6. Insertion de la catégorie : INSERT INTO categorie(libelle) VALUES('Presse2')
    Insertion du produit : INSERT INTO produit(idCategorie,prix,nom) VALUES('7','10.0','Programmez!!')

  7. Que se passe t-il si l'insertion de la catégorie échoue ?
  8. Si l'insertion de la catégorie échoue, le produit n'est pas inséré.

Chargement d'un objet

A partir de ces 2 programmes et de leur exécution :
  1. Précisez ce que charge exactement KObject lors du chargement d'un Objet
  2. KObject va charger tout les objets qui sont en relation, par exemple, pour une catégorie, il chargera tout les produits de cette catégorie :
    SQL : KDataBase.sendQuery → SELECT * FROM categorie WHERE categorie.id='13'
    SQL : KDataBase.sendQuery → SELECT * FROM produit WHERE idCategorie='13'


  3. Précisez comment sont chargées les instances liées à un objet chargé pour les liens belongsTo et hasMany
  4. En quoi consiste le chargement paresseux de KObject ?

Chargement de listes d'objets

A partir du programme :
  1. Combien de requêtes SQL sont exécutées par KObject ?
  2. Comment l'interprétez vous ?

  1. Combien de requêtes SQL sont maintenant exécutées par KObject ?
  2. Comment l'interprétez vous ?

A partir du programme :
  1. Interprétez les requêtes SQL exécutées par KObject

Sélection avec distinct et projection

A partir du code et de son exécution :
  1. Expliquer ce que fait le programme