mercredi 29 décembre 2021

[SQL] How to hanlde NULL values in the SELECT statement and convert them to 0?

Introduction

SQL est un langage de programmation de base de données largement utilisé pour stocker, interroger et manipuler des données. Cependant, lors de l’utilisation de SQL, les utilisateurs peuvent rencontrer un problème courant : la présence de valeurs NULL dans les colonnes des bases de données.

Problème

Une valeur NULL est une valeur inconnue ou indéfinie qui peut être présente dans une colonne de base de données. Ces valeurs NULL peuvent causer des problèmes lors de l’exécution de certaines requêtes SQL, car elles peuvent produire des résultats inattendus ou des erreurs. En particulier, les opérations mathématiques et les comparaisons logiques ne peuvent pas être effectuées sur des valeurs NULL, ce qui peut rendre difficile le traitement des données.
Si vous essayez d'effectuer une opération mathématique ou une comparaison logique sur une valeur NULL, le résultat sera également NULL. Cela peut rendre difficile le traitement des données dans certaines situations, en particulier lorsqu'il est nécessaire de faire des calculs sur les données ou de les comparer avec d'autres valeurs.

Solution

Pour résoudre ce problème, SQL fournit la fonction ISNULL. Cette fonction permet de remplacer les valeurs NULL par une valeur par défaut lors de l’exécution d’une requête

Par exemple, si vous avez une table “orders” avec une colonne “total” contenant le montant total de la commande, vous pouvez utiliser ISNULL pour remplacer les valeurs NULL par 0

La requête serait alors :

SELECT SUM(ISNULL(total, 0)) AS total_amount FROM orders;

Discussion

En utilisant la fonction ISNULL, vous pouvez manipuler et traiter efficacement les valeurs NULL dans vos requêtes SQL et éviter les erreurs potentielles qui pourraient survenir si vous ne traitez pas correctement ces valeurs. 

En résumé, bien que la présence de valeurs NULL en SQL puisse causer des problèmes lors de l’exécution de certaines requêtes SQL, il existe des moyens efficaces pour gérer ces situations et éviter les erreurs potentielles.

https://stackoverflow.com/questions/16840522/replacing-null-with-0-in-a-sql-server-query

mardi 28 décembre 2021

[Postgresql] pg_stat_activity

La table pg_stat_activity de PostgreSQL permet de surveiller les activités en cours dans la base de données. Il est important de surveiller l'état de la transaction dans cette table pour s'assurer que les transactions sont possibles. Si l'état est "idle", il est important de vérifier que le mode manuel de commit est activé pour permettre l'utilisation des transactions.

Voici un tableau comparatif des différents états de la table pg_stat_activity :

ÉtatSignification
activeLa session est en train d'exécuter une requête
idleLa session est connectée à la base de données mais n'exécute pas de requête
idle in transactionLa session est en mode manuel de commit et est en train d'exécuter une transaction
idle in transaction (aborted)La session a été annulée en raison d'une erreur de transaction

Pour passer en mode manuel de commit, il suffit d'exécuter la commande suivante :

sql
BEGIN;

Cette commande active le mode de transaction et permet de valider ou d'annuler les requêtes manuellement. Lorsque le mode manuel de commit est activé, l'état de la transaction dans la table pg_stat_activity passe de "idle" à "idle in transaction".

Exemple pratique : pour s'assurer que les transactions sont possibles, il faut vérifier que l'état de la transaction dans la table pg_stat_activity est "idle in transaction". Si ce n'est pas le cas, il faut activer le mode manuel de commit en exécutant la commande BEGIN.

En résumé, en surveillant attentivement la table pg_stat_activity et en comprenant les différents états de la transaction, il est possible de garantir l'utilisation efficace des transactions dans PostgreSQL.

lundi 26 juillet 2021

Configuring Elastic Common Schema (ECS) & OpenTelemetry for Spring Boot Application


Introduction

Le Elastic Common Schema (ECS) est un standard ouvert qui définit un ensemble commun de champs pour être utilisés lors de l’ingestion de données dans Elasticsearch1. Il a été conçu pour aider les utilisateurs à normaliser leurs données afin de faciliter leur analyse1.


Problème

Auparavant, il y avait deux standards séparés pour la structuration des données : le Elastic Common Schema (ECS) et les Conventions Sémantiques OpenTelemetry. Cela pouvait créer des problèmes de compatibilité et rendre plus difficile l’analyse des données provenant de différentes sources1.

Solution

Elastic et OpenTelemetry ont annoncé une convergence entre le Elastic Common Schema (ECS) et les Conventions Sémantiques OpenTelemetry1. L’objectif est d’atteindre une convergence de l’ECS et des Conventions Sémantiques OpenTelemetry en un seul schéma ouvert maintenu par OpenTelemetry1. Cela signifie que les Conventions Sémantiques OpenTelemetry sont véritablement un successeur du Elastic Common Schema1.

Pour utiliser le ECS dans une application Java Spring, vous pouvez configurer Logback, le logger par défaut pour Spring, pour utiliser le logging Java ECS2. Les logs générés de cette manière seront structurés en tant qu’objets JSON et utiliseront des noms de champs conformes à l’ECS2.

Discussion

La convergence du ECS et des Conventions Sémantiques OpenTelemetry est une étape importante pour améliorer la convergence de l’observabilité et de la sécurité1. Cela apporte une grande valeur à la communauté open source car l’ECS a des années de succès prouvés dans les schémas de logs, de métriques, de traces et d’événements de sécurité, offrant une grande couverture des domaines problématiques communs1.

De plus, la configuration du logging Java ECS dans une application Spring Boot est relativement simple et peut aider à améliorer l’observabilité et la traçabilité de l’application2.

 https://www.elastic.co/guide/en/ecs-logging/java/current/setup.html


mardi 20 juillet 2021

mardi 29 juin 2021

[Java] Enum lookup values by label

L'utilisation des énumérations (enums) pour les valeurs de recherche est une pratique courante en Java, et pour de bonnes raisons. Dans cet article, nous allons discuter des avantages de cette pratique et expliquer comment elle peut améliorer la lisibilité, la sécurité et la maintenabilité de votre code.

  • Lisibilité améliorée

Lorsque vous utilisez des énumérations pour définir des valeurs de recherche, vous donnez à votre code une signification claire et facilement compréhensible. Par exemple, au lieu de définir une chaîne de caractères telle que "M" pour représenter un mois, vous pouvez utiliser une énumération telle que "Janvier", "Février", etc. Cela rend votre code plus lisible et plus facile à comprendre pour les autres développeurs qui peuvent travailler sur votre code.

  • Sécurité renforcée

Les énumérations offrent également une sécurité supplémentaire à votre code. En effet, elles garantissent que seules les valeurs prédéfinies peuvent être utilisées pour une recherche donnée. Cela évite les erreurs de saisie ou les valeurs incorrectes, qui peuvent entraîner des résultats inattendus ou des exceptions lors de l'exécution. Les énumérations sont également plus sûres que les chaînes de caractères, qui peuvent facilement être modifiées ou corrompues.

  • Maintenabilité améliorée

En utilisant des énumérations pour les valeurs de recherche, vous pouvez également améliorer la maintenabilité de votre code. Si vous devez modifier une valeur de recherche, vous n'aurez qu'à le faire dans une seule classe, plutôt que de rechercher et de remplacer cette valeur dans plusieurs endroits du code. Cela rend les modifications plus rapides et moins risquées, car vous n'avez pas besoin de vous soucier des effets de bord ou des modifications involontaires dans d'autres parties du code.

  • Exemple de code

Voici un exemple de code qui utilise une énumération pour les valeurs de recherche :

public enum SortOrder {

    ASC("asc"),
    DESC("desc");

    private static final HashMap<String, SortOrder> MAP = new HashMap<String, SortOrder>();

    private String value;

    private SortOrder(String value) {
        this.value = value;
    }

    public String getValue() {
        return this.value;
    }

    public static SortOrder getByName(String name) {
        return MAP.get(name);
    }

    static {
        for (SortOrder field : SortOrder.values()) {
            MAP.put(field.getValue(), field);
        }
    }
}

After that, just call:

SortOrder asc = SortOrder.getByName("asc");

https://www.baeldung.com/java-enum-values#caching

lundi 28 juin 2021

[Java] String format() Format Specifiers

From Javadoc : https://docs.oracle.com/en/java/javase/11/docs/api/java.base/java/util/Formatter.html 

 Example :

Suppose we have int x = 123, and we want to pad 0 .

String.format("%1$013d", x);
  • The format specifiers for general, character, and numeric types have the following syntax:
       %[argument_index$][flags][width][.precision]conversion
     

    The optional argument_index is a decimal integer indicating the position of the argument in the argument list. The first argument is referenced by "1$", the second by "2$", etc.

    The optional flags is a set of characters that modify the output format. The set of valid flags depends on the conversion.

    The optional width is a positive decimal integer indicating the minimum number of characters to be written to the output.

    The optional precision is a non-negative decimal integer usually used to restrict the number of characters. The specific behavior depends on the conversion.

    The required conversion is a character indicating how the argument should be formatted. The set of valid conversions for a given argument depends on the argument's data type.

  • The format specifiers for types which are used to represents dates and times have the following syntax:
       %[argument_index$][flags][width]conversion
     

    The optional argument_indexflags and width are defined as above.

    The required conversion is a two character sequence. The first character is 't' or 'T'. The second character indicates the format to be used. These characters are similar to but not completely identical to those defined by GNU date and POSIX strftime(3c).

  • The format specifiers which do not correspond to arguments have the following syntax:
       %[flags][width]conversion
     

    The optional flags and width is defined as above.

    The required conversion is a character indicating content to be inserted in the output.

Format SpecifierData TypeOutput
%afloating point (except BigDecimal)Returns Hex output of floating point number.
%bAny type"true" if non-null, "false" if null
%ccharacterUnicode character
%dinteger (incl. byte, short, int, long, bigint)Decimal Integer
%efloating pointdecimal number in scientific notation
%ffloating pointdecimal number
%gfloating pointdecimal number, possibly in scientific notation depending on the precision and value.
%hany typeHex String of value from hashCode() method.
%nnonePlatform-specific line separator.
%ointeger (incl. byte, short, int, long, bigint)Octal number
%sany typeString value
%tDate/Time (incl. long, Calendar, Date and TemporalAccessor)%t is the prefix for Date/Time conversions. More formatting flags are needed after this. See Date/Time conversion below.
%xinteger (incl. byte, short, int, long, bigint)

Hex string.    


Source : 

https://www.javatpoint.com/java-string-format

https://stackoverflow.com/questions/5762836/what-does-1-mean-when-used-in-string-format-java

https://www.geeksforgeeks.org/format-specifiers-in-java/

vendredi 25 juin 2021

[Java 8] Iterating over enum values in java using Java 8 findAny to find from string

public enum ContratType {

CDD,

CDI,

TEMPORARY;

public static ContratType fromString(String type) {

    return Stream.of(ContratType .values())

.filter(typec -> typec.name().equals(type))

.findAny().orElse(null);

}

}

dimanche 4 avril 2021

Docker : How to run docker-compose in detached mode ?

 docker-compose -f ymlfile up -d

[Linux] Compresser et décompresser en tar.gz sous Linux

Compresser

 

tar czvf < nom_archive >.tar.gz < nom_rep >    

§  "c" : créer une nouvelle archive

§  "z" : permet d'activer la compression "gzip" pour un taux de compression plus important

§  "v" : mode verbeux, permet d'afficher dans le détail les fichiers compressés

§  "f" : indication de la donnée à compresser

 

Décompresser

 

tar xzvf < nom_archive >.tar.gz

§  "x" : extraire une archive

§  "z" : permet de décompresser le "gzip"

§  "v" : mode verbeux, permet d'afficher dans le détail les fichiers décompressés

§  "f" : indication de la donnée à décompresser 

mercredi 10 février 2021

Maven : Setting MAVEN_OPTS

Configuration de l'utilisation de la mémoire par Maven à partir de Java 8+

-Xmx : pour définir la mémoire MAX

-XX:MaxPermSize : pour d'information sur l'utilité et les modifications à partir de Java 8 + voir cet article : Où est passée la PermGen Java ?

 Linux:

export MAVEN_OPTS="-Xmx1024m -XX:MaxPermSize=1024m"


Windows

set MAVEN_OPTS="-Xmx1024m -XX:MaxPermSize=1024m"



Docker : Running Maven in Docker container via current user as non-root

Maven needs the user home to download artifacts to, and if the user does not exist in the image an extra user.home Java property needs to be set.

For example, to run as user 1000 mounting the host' Maven repo

$ docker run -v ~/.m2:/var/maven/.m2 -ti --rm -u 1000 -e MAVEN_CONFIG=/var/maven/.m2 maven mvn -Duser.home=/var/maven archetype:generate
Source : https://hub.docker.com/_/maven
https://stackoverflow.com/questions/52780802/run-maven-in-docker-container-via-current-user/52781822

mercredi 3 février 2021

Javascript : Object.defineProperty() add a new function property to an Object

 // For example Define the Product class -  the Constructor function 

function Product(idnamepriceexpiryDate) {
   this.id = id;
   this.name = name;
   this.price = price;
   this.expiryDate = expiryDate;
  }
// Here, use Object.defineProperty to create property 
Object.defineProperty(Product'daysToExpire',{
    get() {
    return this.daysToExpire;
  }});

JavaScript / TypeScript: Object Writbale attribute, have more control on your properties

En JavaScript / TypeScript, chaque propriété d’un objet est liée à un descripteur (qui est lui-même un objet). 

Celui-ci donne plusieurs informations sur une propriété à l'aide la méthode Object.getOwnPropertyDescriptor()

  • Est-elle configurable? 
  • Est-elle énumérable ?
  • Est-elle modifiable ? 
  • Quelle est sa valeur ?
  • etc
Exemple : 
const object1 = {
  property1: 42
};

const descriptor1 = Object.getOwnPropertyDescriptor(object1, 'property1');

console.log(descriptor1.configurable);
// expected output: true

console.log(descriptor1.value);
// expected output: 42

La méthode statique Object.defineProperty() permet de définir une nouvelle propriété ou de modifier une propriété existante, directement sur un objet. 

La méthode renvoie l'objet modifié.

Exemple de modification de proprieté: 

Object.defineProperty(object1, 'property1', {
  value: 42,
  writable: false
});

object1.property1 = 77;
// throws an error in strict mode

console.log(object1.property1);

Quelques cas d'usage pour les test avec Angular :

lundi 18 janvier 2021

How to Handle Java 8 Dates and Time with Jackson in Spring Boot (JSR-310)

When you use Spring Boot, you can add the following line to the application.properties file:

spring.jackson.serialization.write-dates-as-timestamps=false

Spring Boot enables the configuration of the default ObjectMapper with properties under the spring.jackson prefix. Read the jackson section in the Spring Boot docs for more info on this.

more details :

https://www.baeldung.com/spring-boot-customize-jackson-objectmapper

https://codeboje.de/jackson-java-8-datetime-handling/

How to Trace Transaction Behavior Details in Spring Boot

1. Introduction

Dans le développement d'applications avec Spring, les tests unitaires et d'intégration jouent un rôle central pour garantir la fiabilité et la stabilité du code. Cependant, tester du code qui s'exécute dans un contexte transactionnel peut devenir complexe, notamment lorsqu’on souhaite comprendre pourquoi certaines transactions échouent ou se comportent de manière inattendue. Spring fournit une API puissante pour la gestion des transactions, mais lors des tests, des erreurs subtiles peuvent survenir et il devient nécessaire de traquer la gestion des transactions.

2. Problématique

Les transactions gérées par Spring, surtout lorsqu’elles sont imbriquées dans des couches complexes, peuvent parfois entraîner des comportements inattendus lors des tests. Par exemple :

  • Transactions annulées : Lors de l'exécution d'un test avec @Rollback, des données peuvent être supprimées à la fin, rendant difficile la vérification de certaines assertions.
  • Erreurs de commit : Dans certains cas, une transaction peut échouer sans explication claire dans les logs par défaut.
  • Faible visibilité : Les logs par défaut ne fournissent souvent pas assez de détails pour comprendre les étapes exactes du cycle de vie d’une transaction.

Pour résoudre ces problèmes, configurer les logs de Spring spécifiquement pour les transactions permet de capturer plus de détails et d'obtenir une vue plus fine des opérations.

3. Solution

Pour diagnostiquer les transactions dans vos tests, il est utile de configurer un niveau de log approprié pour le contexte transactionnel de Spring. Voici comment faire :

Étape 1 : Modifier le fichier de configuration application.properties ou application.yml

Pour activer les logs détaillés, ouvrez votre fichier application.properties (ou application.yml) et ajoutez-y la ligne suivante :

logging.level.org.springframework.test.context.transaction.TransactionContext=DEBUG

Cela configure le niveau de log pour TransactionContext à DEBUG. Pour un niveau de détail encore plus élevé, TRACE peut être utilisé :

logging.level.org.springframework.test.context.transaction.TransactionContext=TRACE
Étape 2 : Comprendre les niveaux de log

Dans cette configuration, voici ce que les différents niveaux de log apportent :

  • INFO : Affiche les étapes essentielles de la gestion des transactions, comme l’ouverture et la fermeture.
  • DEBUG : Affiche des informations détaillées sur le début, la fin, et les rollback éventuels des transactions.
  • TRACE : Montre chaque étape de la transaction, incluant des détails sur les rollbacks et commits.
Étape 3 : Lancer vos tests et observer les logs

En configurant le niveau à DEBUG ou TRACE, exécutez vos tests. Vous verrez des logs plus détaillés relatifs aux transactions, vous permettant de :

  • Suivre chaque transaction, de sa création jusqu’à sa validation ou annulation.
  • Identifier des erreurs liées aux transactions, telles que les problèmes de commit, ou comprendre pourquoi une transaction a été annulée.

4. Conclusion

Configurer les logs pour le contexte transactionnel dans Spring permet de mieux comprendre les opérations de transaction dans vos tests et d’identifier rapidement les problèmes liés à leur gestion. En adaptant le niveau de verbosité de log pour TransactionContext, vous pouvez obtenir une vue détaillée des étapes de chaque transaction, facilitant ainsi le débogage et le suivi des tests. Cette pratique est particulièrement utile dans des environnements de tests complexes où les transactions jouent un rôle important.

To log transaction details in a Spring Boot application simply add the following settings in application.properties:

 logging.level.org.springframework.transaction.interceptor=TRACE