En SQLLangage permettant de communiquer avec une base de données., lorsqu’une requête possède une condition sur une colonne sur laquelle porte une clause GROUP BY, cette condition n’est pas exprimée dans la clause WHERE mais dans la clause HAVING.
Si vous savez faire une requête simple avec Hibernate 4, écrire une condition simple et utiliser la clause GROUP BY, la mise en place d’un HAVING ne vous posera pas de problème. Il faut utiliser la méthode having() de votre CriteriaQuery, de la même manière que vous utiliseriez la méthode where() : en lui passant un Predicate en paramètre.
Exemple l’utilisation du multiselect) :
CriteriaBuilder builder = entityManager.getCriteriaBuilder();
CriteriaQuery<Tuple> criteriaQuery = builder.createQuery(Tuple.class);
Root<Commande> root = criteriaQuery.from(Commande.class);
criteriaQuery.multiselect(root.get(Commande_.date), root.get(Commande_.departement), builder.count(root));
List<Expression<?>> groupList = new ArrayList();
groupList.add(root.get(Commande_.date));
groupList.add(root.get(Commande_.departement));
criteriaQuery.groupBy(groupList);
Predicate predicate = builder.notEqual(root.get(Commande_.departement), "75");
criteriaQuery.having(predicate);
TypedQuery<Tuple> typedQuery = entityManager.createQuery(criteriaQuery);
List<Tuple> result = typedQuery.getResultList();
Si vous faites du web depuis quelque temps, vous avez sûrement déjà utilisé des Websockets, et si c'est le cas, vous détestez sûrement ce protocole et son implémentation. Personnellement, je ne le trouve pas fiable, lourd à implémenter et pas du tout performant. C'est cette haine du Websocket qui m'a fait chercher de nouvelles solutions pour faire de la communication bilatérale entre un client et un serveur, et j'ai trouvé mon bonheur : le MQTT.
Découvrez la planche #7 !
13 plugins pour vous faciliter la vie sur Gatsby, c'est par ici !