Agilité, Développement Java, Nouvelles technologies et plus…
  • rss
  • Accueil
  • Management
  • Programmation agile
  • Technologie
  • Linux
  • Evénement
  • App Android
  • Contact
  • A propos de l'auteur
  • English
  • Francais

Gérer une séquence de base de données avec Spring

Fabian Piau | dimanche 22 septembre 2013 - 19:36
  • Cliquer pour imprimer(ouvre dans une nouvelle fenêtre) Imprimer
  • Cliquer pour partager sur X(ouvre dans une nouvelle fenêtre) X
  • Cliquez pour partager sur LinkedIn(ouvre dans une nouvelle fenêtre) LinkedIn
  • Cliquez pour partager sur Facebook(ouvre dans une nouvelle fenêtre) Facebook
  • Cliquez pour partager sur WhatsApp(ouvre dans une nouvelle fenêtre) WhatsApp

 English version available

Remarque
Il vaut mieux laisser Hibernate gérer tout seul les identifiants techniques (clés primaires). Par contre, il peut arriver que vous ayez besoin de générer un identifiant fonctionnel et qu’un générateur Hibernate ne réponde pas à vos besoins. Dans mon cas, l’identifiant fonctionnel n’était pas tout le temps généré, il pouvait aussi être setté à la main. Malheureusement, au moment d’insérer l’élément en base de données (sauf erreur, mais je n’ai pas trouvé…), le générateur écrase toujours la valeur de mon identifiant fonctionnel même si je l’ai settée manuellement auparavant.

Base de données

Un petit mémo (très technique) utile si vous avez Spring sur votre projet.

C’est dans le cas assez spécifique où l’on souhaite récupérer / incrémenter la valeur d’une séquence et que le Sequence Generator d’Hibernate ne répond pas à vos besoins (voir la remarque).

Plutôt que de passer par une DAO avec du code Hibernate (ou pire JDBC), Spring peut le faire pour vous en 2 minutes…


  • Pour cela, il suffit de déclarer un nouveau bean dans la configuration Spring de votre projet:
           <bean id='mySequenceIncrementer' class='org.springframework.jdbc.support.incrementer.H2SequenceMaxValueIncrementer'>
    	       <property name='dataSource' ref='<Nom de votre datasource>' />
    	       <property name='incrementerName' value='<Nom de votre sequence>' />
           </bean>
    

    A noter: il existe plusieurs implémentations d’incrémenteur pour différentes bases de données (j’utilise H2DB, mais MySQL, PostgreSQL, Oracle, etc. sont également disponibles)

  • Injecter ce bean dans la classe de votre choix.
  • Et désormais, vous pouvez faire:
    final Long newIdSequence = mySequenceIncrementer.nextLongValue();
    


Testé et approuvé!

Articles similaires

Java EE vs SpringJava EE & CDI vs. Spring springQCon London 2016 – Spring Framework 5 – Preview et Roadmap
Commentaires
5 Commentaires »
Catégories
Programmation agile
Tags
base de données, hibernate, séquence, spring
Flux rss des commentaires Flux rss des commentaires

Optimiser votre site web pour l’impression en 5 minutes

Fabian Piau | dimanche 15 septembre 2013 - 13:23
  • Cliquer pour imprimer(ouvre dans une nouvelle fenêtre) Imprimer
  • Cliquer pour partager sur X(ouvre dans une nouvelle fenêtre) X
  • Cliquez pour partager sur LinkedIn(ouvre dans une nouvelle fenêtre) LinkedIn
  • Cliquez pour partager sur Facebook(ouvre dans une nouvelle fenêtre) Facebook
  • Cliquez pour partager sur WhatsApp(ouvre dans une nouvelle fenêtre) WhatsApp

 English version available

Est-ce vraiment utile? Je pense que oui! Les gens qui impriment des pages sur internet sont sans doute plus nombreux que ce que l’on peut penser. Et puis franchement, si ça prend 5 minutes, autant le faire!


Imprimante

Prenons un scénario digne d’un film hollywoodien (presque):

Monsieur Toutlemonde n’aura accès ni à internet ni à son ordinateur ce weekend et il n’a pas eu le temps de finir de lire un article assez long, mais primordial pour la suite. Il décide donc de l’imprimer pour le lire plus tard dans l’avion (oui, Mr Toutlemonde a de la chance, il part en vacances). L’impression terminée, il se rend compte, un peu blasé (car oui ce n’est pas la première fois que ça lui arrive), qu’absolument toute la page internet est ressortie. Il se retrouve avec 7 pages imprimées pour un article qui en comptait peut-être 3… Le menu de navigation du site, les articles similaires, les liens de partage vers les réseaux sociaux… Tout est là! Mais bon, Monsieur Toutlemonde est tout de même rassuré, il pourra lire son article « Comment affronter sa phobie de l’avion? ».

Dans la continuité de l’article expliquant comment rendre votre site responsive, je vais vous montrer comment rendre votre site optimisé pour l’impression.


Le principe est le même, on utilise le langage CSS.


Il faut déclarer un fichier de style CSS dédié pour l’impression. Dans le header de vos pages, vous ajoutez un lien vers ce fichier en spécifiant « print » pour l’attribut « media », contrairement aux autres qui spécifient en général le media « all » (écran, imprimante, etc.). Consultez cette page pour en savoir plus sur les medias.

Par exemple, j’utilise le fichier « print.css » pour mon blog, j’ai donc ajouté cette ligne:

<link rel="stylesheet" href="https://blog.fabianpiau.com/wp-content/themes/freshy2/print.css" type="text/css" media="print">

Ce fichier de styles sera utilisé seulement dans le cas d’une impression. Ainsi, vous allez donc pouvoir l’utiliser pour supprimer tous les contenus « parasites » tels que:

  • Header
  • Sidebars
  • Footer
  • Articles similaires
  • Etc.

Voici un extrait de mon fichier « print.css »:

@media print {
	.sidebar div div {
		display:none !important;
	}
	#header {
		display:none !important;
	}
	#footer {
		display:none !important;
	}
	.yarpp-related {
		display:none !important;
	}
	.meta {
		display:none !important;
	}
	.wp-pagenavi {
		display:none !important;
	}
	.sharedaddy {
		display:none !important;
	}
	#breadcrumbs {
		display:none !important;
	}
	.navigation {
		display:none !important;
	}
	.noprint {
		display:none !important;
	}
}

Logo impression garantie

A noter: j’utilise le mot clé « !important » pour redéfinir un style déjà présent. La valeur spécifiée avec le « !important » écrasera toujours les autres.

@media print { [mon code CSS ici] } permet de rendre un code CSS interprétable uniquement dans le cas d’une impression. Si vous utilisez cette annotation autour d’un bout de code CSS, rien ne vous empêche donc de l’intégrer dans un fichier CSS utilisé pour tout media (media="all"). J’ai utilisé à la fois l’annotation et le media pour l’impression, comme cela je suis sûr, mais ce n’est absolument pas une obligation.


Une autre solution (souvent complémentaire) est d’ajouter une classe CSS dédiée pour cacher des éléments en particulier à l’impression. Cela est utile dans le cas où l’élément en question n’a pas d’attribut qui lui est propre (pas d’identifiant ou une classe trop générique qu’on ne souhaite pas cacher partout…).

Par exemple, la classe « noprint »:

.noprint {
	display:none !important;
}

Désormais, n’importe quel élément de mon site qui utilisera la classe « noprint » sera invisible à l’impression. On ne peut pas faire plus simple!


Pour voir le résultat en action, vous pouvez imprimer cet article (un aperçu avant impression ou une impression vers une imprimante PDF sera suffisant, pensez à la planète…).

Articles similaires

wordpress-hackerConseils pour sécuriser votre site WordPress Clean browser cacheLes fichiers CSS et Javascript jouent à cache-cache avec les navigateurs client WordPress qTranslateRendre son site WordPress multilingue avec qTranslate Responsive Web DesignFaire du Responsive Web Design: oui, mais simplement!
Commentaires
Pas de Commentaires »
Catégories
Programmation agile
Tags
css, design, impression, imprimante, mobilité informatique
Flux rss des commentaires Flux rss des commentaires
Page 2 sur 3123
Télécharger l'app CarmaBlog

Flux RSS

  • Flux RSS RSS - Articles
  • Flux RSS RSS - Commentaires

Articles les plus vus

  • Changer la langue de Firefox - 116 514 vues
  • Réaliser un sondage en ligne avec Google Forms / Drive / Docs - 64 609 vues
  • FAQ – Sondage en ligne avec Google Forms / Drive / Docs - 56 657 vues
  • Personnaliser Gnome 3 (Shell) - 30 939 vues
  • La signification d’URL, URI et URN - 18 543 vues
  • Java EE & CDI vs. Spring - 16 039 vues
  • Open Street Map, une meilleure carte que Google Maps? - 16 002 vues
  • Comparaison NoSQL: Couchbase et MongoDB - 14 759 vues
  • API, REST, JSON, XML, HTTP, URI… Vous parlez quelle langue en fait? - 13 809 vues
  • Une première approche du Camel d’Apache - 13 780 vues

Commentaires récents

  • Fabian Piau sur FAQ – Sondage en ligne avec Google Forms / Drive / DocsOui, dans Google Forms, vous pouvez empêcher les p…
  • BENECH Fabien sur FAQ – Sondage en ligne avec Google Forms / Drive / DocsBonjour, J'ai crée 1 questionnaire via Forms,…
  • SANKARA TIDIANE sur Formation en ligne gratuite sur MongoDBJ'aimerai suivre
  • Pauline sur FAQ – Sondage en ligne avec Google Forms / Drive / DocsMerci Fabian, mais le but étant que nos clients pu…
  • Fabian Piau sur FAQ – Sondage en ligne avec Google Forms / Drive / DocsProbablement mais ces options sont en général paya…

Articles récents

  • Comment écrire un article de blog? En tout cas à ma façon! - Il y a 2 ans et 10 mois
  • Attaques de robots: vous n’êtes pas seul… - Il y a 4 ans et 5 mois
  • Flagger – Monitorer vos déploiements Canary avec Grafana - Il y a 5 ans et 3 mois
  • Flagger – Déploiements Canary sur Kubernetes - Il y a 5 ans et 4 mois
  • Flagger – Premiers pas avec Istio et Kubernetes - Il y a 5 ans et 5 mois
  • CoderDojo Expedia à Londres - Il y a 6 ans et 2 mois
  • Etre bénévole à Devoxx4Kids - Il y a 6 ans et 5 mois
  • Une migration Java 11 réussie - Il y a 6 ans et 9 mois
  • Conseils pour sécuriser votre site WordPress - Il y a 7 ans et 3 jours
  • Devoxx UK 2018 – Jour 2 - Il y a 7 ans et 4 mois
  • Devoxx UK 2018 – Jour 1 - Il y a 7 ans et 4 mois
  • Wise, Revolut et Monzo, une petite révolution dans le monde des expatriés et voyageurs - Il y a 7 ans et 8 mois
  • Autocomplétion pour Git - Il y a 8 ans et 4 mois
  • Swagger, la documentation API automatisée - Il y a 8 ans et 7 mois
  • Architecture Microservices – Les bonnes pratiques - Il y a 9 ans et 1 semaine
Offre moi un café

Langue

  • Français
  • English

Suivez-moi!

Suivez-moi sur Linkedin
Suivez-moi sur Twitter
Suivez-moi sur Stackoverflow
Suivez-moi sur Github
Suivez-moi sur Rss
Link to my Contact

Abonnement email

Saisissez votre adresse email pour être informé des nouveaux articles.

Étiquettes

.net agile agilité android bash blog bonnes pratiques cache cloud conférence css devoxx docker développeur eclipse extreme programming firefox flagger google helm hibernate informatique intégration continue istio java jug kubernetes londres mobilité informatique métier outil panorama partage performance plugin programmeur script société spring sécurité tdd test ubuntu windows wordpress

Liens

  • Blog Ippon Technologies
  • Blog Publicis Sapient
  • Blog Zenika
  • Classpert
  • CommitStrip
  • Coursera
  • Le Touilleur Express
  • Les Cast Codeurs Podcast
  • OCTO talks !
  • The Twelve-Factor App

Catégories

  • Evénement (15)
  • Linux (3)
  • Management (8)
  • Programmation agile (29)
  • Technologie (45)

Archives

  • décembre 2022 (1)
  • avril 2021 (1)
  • juin 2020 (1)
  • mai 2020 (2)
  • juillet 2019 (1)
  • mai 2019 (1)
  • décembre 2018 (1)
  • octobre 2018 (1)
  • juin 2018 (1)
  • mai 2018 (1)
  • janvier 2018 (1)
  • mai 2017 (1)
  • mars 2017 (1)
  • octobre 2016 (1)
  • avril 2016 (2)
  • mars 2016 (1)
  • novembre 2015 (1)
  • mai 2015 (1)
  • février 2015 (1)
  • décembre 2014 (1)
  • novembre 2014 (1)
  • septembre 2014 (2)
  • août 2014 (1)
  • juillet 2014 (2)
  • juin 2014 (1)
  • avril 2014 (1)
  • mars 2014 (1)
  • février 2014 (2)
  • janvier 2014 (1)
  • décembre 2013 (1)
  • novembre 2013 (1)
  • octobre 2013 (3)
  • septembre 2013 (5)
  • juillet 2013 (1)
  • juin 2013 (1)
  • mai 2013 (1)
  • avril 2013 (1)
  • mars 2013 (2)
  • février 2013 (1)
  • janvier 2013 (2)
  • décembre 2012 (2)
  • octobre 2012 (1)
  • septembre 2012 (1)
  • juillet 2012 (1)
  • mai 2012 (1)
  • avril 2012 (1)
  • mars 2012 (1)
  • février 2012 (1)
  • janvier 2012 (2)
  • décembre 2011 (1)
  • novembre 2011 (2)
  • octobre 2011 (2)
  • septembre 2011 (1)
  • juillet 2011 (1)
  • juin 2011 (2)
  • avril 2011 (1)
  • mars 2011 (1)
  • février 2011 (1)
  • janvier 2011 (2)
  • novembre 2010 (2)
  • septembre 2010 (1)
  • août 2010 (1)
  • juillet 2010 (1)
  • juin 2010 (1)
  • mai 2010 (1)
  • avril 2010 (1)
  • mars 2010 (1)
  • février 2010 (1)
  • décembre 2009 (1)
  • novembre 2009 (1)
  • octobre 2009 (2)
  • septembre 2009 (2)
  • août 2009 (3)
  • juillet 2009 (1)
  • juin 2009 (2)
Suivez-moi sur Twitter
Suivez-moi sur Linkedin
Suivez-moi sur Stackoverflow
Suivez-moi sur Rss
Link to my Contact
Suivez-moi sur Github
 
Fabian Piau | © 2009 - 2025
Tous droits réservés | Haut ↑