Developpez.com - Rubrique Excel

Le Club des Développeurs et IT Pro

La mise en forme conditionnelle dans Microsoft Access 2010 dévoilée,

Par Christophe Warin

Le 2009-07-01 19:37:05, par Tofalu, Expert éminent sénior
Bonjour à tous,

A travers ce fil rouge, nous vous proposons la possibilité de découvrir un peu plus tous les jours une nouvelle facette de ce que sera Microsoft Access 2010.

Nouvelle interface, nouvelles fonctionnalités ?

Nous vous accompagnons jusqu'à l'ouverture officielle du programme béta.

Liens :

http://warin.developpez.com/tutoriel...10/nouveautes/

Mise à jour du 01/07/2009 : La nouvelle interface
Mise à jour du 02/07/2009 : Les évènements sur les tables (Triggers)

N'hésitez pas à laisser vos commentaires
  Discussion forum
21 commentaires
  • Tofalu
    Expert éminent sénior
    Comme promis, et avec quelques heures d'avance, une nouvelle fonctionnalité vous est dévoilée aujourd'hui.

    Nul doute qu'elle fera couler beaucoup d'encre dans les mois à venir. En effet, si Microsoft Access tend à devenir plus orienté utilisateur "novice", le moteur Jet intègre quelques spécifités des plus grands SGBD dont notamment un mécanisme de trigger que je vous propose de découvrir :

    http://warin.developpez.com/tutoriel...p/?page=page_2

  • Tofalu
    Expert éminent sénior
    J'imagine que ça permet de ne pas avoir d'avertissements de sécurité liés au VBA.
    Et en plus, la gestion d'erreur des macros a été revue pour laisser place à un Journal d'Erreurs : une table Log.

  • A cette fameuse MFC.

    Il est vrai que la limite de 3 à toujours été un frein, même s'il y avait la possibilité d'aller plus loin : http://starec.developpez.com/tuto/msfcillimitee/.

    Cette nouvelles limite devrait permettre de pouvoir répondre à la plupart des cas, et il semble qu'il y ait des nouveautés intéressantes.
  • Tofalu
    Expert éminent sénior
    Bonjour à Tous,

    Alors que l'on croyait le VBA complètement exclu des Triggers c'était sans compter la possibiliter d'utiliser une astuce tellement évidente qu'elle est passait totalement inaperçue ...

    Comment exécuter du code VBA alors qu'aucune commande des évenements de table Access n'y font référence ? Il y a bien une commande RunDataMacro mais jusqu'à présent, les macros habituelles sont des RunClientMacro.

    Il faut en fait s'arréter sur la commande SetLocalVar qui permet d'affecter une variable dans la portée de l'évènement. Et si on tentait d'affecter le résultat d'une fonction VBA à cette variable ? Passera, passera pas ? Un seul moyen de le savoir, il faut tester.



    Un petit module VBA :

    Code :
    1
    2
    3
    Public Function MaFonction() As String
    MsgBox "hello"
    End Function
    Le résultat :



    Bien entendu, il y a une limitation :

    Impossible de lancer ce déclencheur depuis autre chose qu'une instance Access capable d'interpréter le VBA mais cela ouvre des portes assez importante, notamment dans la création de table de log qui stockeront par exemple les informations de l'environnement Windows (utilisateur, heure d'ouverture de session) sans avoir à se soucier du déclenchement de l'évènement. Toute information que le moteur de base de données ne peut intercepter, VBA peut l'atteindre.
  • Tofalu
    Expert éminent sénior
    Bonjour,

    Suite et fin de cet article avec la conclusion marquant la fin du programme Technical Preview.

    Je vous propose donc une critique d'Access 2010, à la manière dont j'aurais critiqué un livre ...

    L'ouverture du programme bêta au grand public dans les semaines à venir marque avant tout la fin de la Technical Preview. L'heure sera alors essentiellement à la vérification de la localisation, les fonctionnalités quant à elles ne devraient pas subir de grands bouleversements. Comme cela a été fait pour Access 2007, il est temps de réaliser un premier bilan des nouveautés et surtout de déterminer si, oui ou non, cette nouvelle mouture se veut indispensable.

    Si, de prime abord, j'avais été littéralement conquis par Access 2007, je me suis finalement un peu ravisé, constatant que la plupart des nouveautés n'étaient pas vraiment orientées vers le développement professionnel : les développeurs envisageant la montée en puissance de leur application ont en effet tendance à fuir des fonctions aussi spécifiques que les champs à valeurs multiples ou les champs pièces-jointes. Il ne restait guère plus que le ruban comme lot de consolation bien que celui-ci ne soit pas paramétrable dans l'environnement de développement.

    De ce fait, c'est avec un peu de retenue que j'ai entamé la Technical Preview 2010...

    Et j’ai été agréablement surpris.
    D'une part, au niveau de l'interface, l'ergonomie du ruban reste de mise et est renforcée par l'amélioration des nombreux assistants et plus particulièrement l'éditeur de macros. Celui-ci se voit complètement métamorphosé améliorant la clarté des actions en comparaison à l'obsolète tableau illisible. C'est aussi le cas de la mise en forme conditionnelle (dont le nombre d'expressions a augmenté), du générateur d'expressions...

    D'autre part, sur le plan technique, il faut noter une réelle volonté de rapprocher Access des plus grands SGBD tels que SQL Server. Tout d'abord, les champs calculés viennent apporter une simplification de la présentation des données permettant d'afficher des calculs simples sans avoir recours systématiquement à des requêtes. Ensuite, les événements de tables combinés aux datamacros qui, bien que l'on puisse regretter qu'ils ne soient pas développés en SQL mais à base de langage macro, se révèlent particulièrement efficaces. Ils permettent de confier au moteur de base de données des règles de gestion fondamentales qui, par le passé, étaient traitées en VBA avec un risque d'incohérence en cas d'attaque depuis un programme tiers. Enfin, la table USysApplicationLog, véritable journal répertoriant les erreurs des macros de données à l'instar des observateurs d'événements des plus gros systèmes.

    Pour conclure, en quelques mots, Access 2010 semble marquer un véritable tournant dans le développement d'applications Access professionnelles garantissant encore un peu plus l'intégrité et la cohérence des données sans pour autant négliger l'aspect graphique des productions (look des nouveaux contrôles) ni le confort du développeur. En bref, un produit à ne pas manquer pour tous ceux qui désirent des applications plus belles, plus puissantes et plus stables.
  • Maxence HUBICHE
    Expert éminent
    Et maintenant...
    une petite vidéo sur l'éditeur de macros
    http://www.developpez.net/forums/d83...diteur-macros/

    Bon visionnage, et, surtout, n'hésitez pas à laisser vos commentaires !
  • Maxence HUBICHE
    Expert éminent
    Et au fait, il y avait une petite question en suspend...
    Vaut-il mieux travailler avec Access ou Excel ?

    Alors, la solution à la problématique est ici :
    http://www.developpez.net/forums/d78...-1-partie-2-a/
  • Maxence HUBICHE
    Expert éminent
    Allez... une petite 3ème, pour la route

    Une nouveauté concernant le positionnement des contrôles sur Access 2010. Franchement sympa !

    C'est ici : http://www.developpez.net/forums/d83...ent-controles/
  • Tofalu
    Expert éminent sénior
    Pour ce premier jour, nous vous proposons de découvrir le nouveau ruban :

    http://warin.developpez.com/tutoriel...page=page_1#LI

  • Excellente idée.