AFUP AFUP Day 2020 Baromètre Planète PHP

La parole est aux speakers : Lætitia AVROT

Jusqu’à l’AFUP Day 2020, retrouvez nos interviews de speakers pour mieux comprendre leur parcours et le sujet qu’ils ou elles aborderont lors de leur conférence !

La conférence

Le I de ACID

Depuis les années 70, les bases de données relationnelles ont évolué, mais leur base théorique, elle, n'a pas évolué: ACID. Atomicité, Consistance, Isolation et Durabilité. L'isolation des transactions est bien souvent mal comprise alors qu'elle est presque toujours ajustable et permettrait de résoudre beaucoup de problème des développeurs et développeuses.

Après une description des différents niveaux d'isolation, nous verrons quelles anomalies peuvent survenir et quand utiliser quel niveau d'isolation. Votre base de données relationnelle peut faire beaucoup de choses que vous ignorez, changer le niveau d'isolation de certaines requêtes en fait certainement partie!

En ligne
24/06/2020
10:05-10:45

Les visiteurs et visiteuses de l’AFUP Day 2019 Lyon ont eu la chance d’assister à une de tes confs. Tu réédites l’exercice cette année. Quels retours as-tu eus suite à cette journée et as-tu des attentes à propos de l’édition 2020 ?

Avant de postuler pour AFUP Day 2019, j’étais morte de peur à l’idée d’aller parler dans une conférence de développeurs. Les conférences auxquelles je participe sont très orientées bases de données et, comme à chaque fois qu’on sort de sa zone de confort, la peur est là.
Les retours ont été très positifs dans le sens où j’avais visé juste: ces trésors du SQL étaient bien méconnus de la plupart des participant·e·s, mais je me suis aussi rendue compte que cette conférence aurait gagné à aborder moins de points mais plus en détails. J’ai tenu compte de cet aspect lorsque j’ai redonné cette conférence.
Cette année, la conférence qui a été choisie va se concentrer sur un des fondamentaux des SGBD relationnels: l’Isolation, le fameux I des propriétés ACID.

Peux-tu nous citer les différents niveaux d’isolation possibles afin de nous mettre l’eau à la bouche ?

Il existe dans la norme SQL 4 niveaux d’isolation des transactions: le READ UNCOMMITTED, le READ COMMITTED, le REPEATABLE READ et le SERIALIZABLE. Pour la plupart des SGBDR, le niveau par défaut est READ COMMITTED, qui est un bon compromis entre la performance et l’interaction entre les transactions, mais cela implique des conséquences pas toujours connues qui peuvent poser problème. Le niveau d’isolation peut être changé pour une transaction seulement et peut vraiment éviter d’ajouter des sur-couches aux applications.

Tu vas nous parler d’un concept établi il y a près de 40 ans et qui est pourtant mal connu ou mal utilisé. Penses-tu qu’il s’agit d’un défaut de formation, d’outillage parmi les développeurs·euses ou tout simplement que c’est lié au décalage de métier entre un·e développeur·euse et un·e administrateur·trice de base de données ?

Je pense qu’effectivement les formations se concentrent un peu trop sur les langages de développement alors que l’informatique est beaucoup plus riche que ça ! Il n’y a pas (en France ou dans le monde) de formation initiale d’administrateur•trice de bases de données, c’est un métier qu’on apprend directement en production avec les risques que cela implique… Il y a aussi toute une génération de développeurs·euses qui se reposent sur l’ORM pour écrire leurs requêtes (voire pour modéliser les bases de données). Je pense que c’est une mauvaise pratique qui engendre des gros soucis de performance ou d’intégrité des données, mais d’un autre côté, je ne suis appelée par les clients que lorsque ça va mal !

Le speaker

Lætitia AVROT
Lætitia AVROT
Lætitia Avrot est experte PostgreSQL chez EnterpriseDB. Elle est co-fondatrice du mouvement Postgres Women, membre du Postgres Advocacy Group et membre du Postgres Funds Group. Elle a aussi été pendant un an membre du comité du Code de Conduite de la communauté PostgreSQL. Elle a écrit plusieurs patchs pour le projet PostgreSQL et donne régulièrement des conférences dans des événements communautaires.

Autres interviews

En poursuivant votre navigation sur ce site, vous acceptez l’utilisation des cookies pour améliorer votre navigation. plus d'infos

1. Qu’est-ce qu’un cookie?

Un Cookie est un petit fichier texte enregistré sur votre terminal (ordinateur, tablette, smartphone, etc.), à l’occasion de la consultation d’un service en ligne grâce à votre logiciel de navigation. Il permet à son émetteur d’identifier le terminal dans lequel il est enregistré, pendant la durée de validité ou d’enregistrement du Cookie. Lors de la consultation de notre site Internet, des informations relatives à la navigation de votre terminal sont susceptibles d'être enregistrées dans ces fichiers dits "Cookies". Ces derniers sont installés sur votre terminal, sous réserve des choix que vous auriez exprimés concernant les Cookies et que vous pouvez modifier à tout moment.

2. A quoi servent les cookies émis sur notre site ?

Seul l’émetteur d’un cookie est susceptible de lire ou de modifier les informations qui y sont contenues.
Les cookies utilisés sur notre site permettent :

3. Vos choix concernant les cookies

Vous disposez de différents moyens pour gérer les cookies. Tout paramétrage que vous pouvez entreprendre sera susceptible de modifier votre navigation sur notre site et sur Internet en général et vos conditions d'accès à certains services de notre site nécessitant l'utilisation de cookies. Vous pouvez à tout moment exprimer et modifier vos souhaits en matière de cookies, par les moyens décrits ci-dessous. L'accord sur les cookies L'enregistrement d'un cookie dans un terminal est essentiellement subordonné à la volonté de l'utilisateur du terminal, que celui-ci peut exprimer et modifier à tout moment et gratuitement à travers les choix qui lui sont offerts par son logiciel de navigation. Si vous avez accepté dans votre logiciel de navigation l'enregistrement de cookies dans votre terminal, les cookies intégrés dans les pages et contenus que vous avez consultés pourront être stockés temporairement dans un espace dédié de votre terminal. Ils y seront lisibles uniquement par leur émetteur.

Le refus des cookies Si vous refusez l'enregistrement de cookies dans votre terminal, ou si vous supprimez ceux qui y sont enregistrés, vous ne pourrez plus bénéficier d'un certain nombre de fonctionnalités qui sont néanmoins nécessaires pour naviguer dans certains espaces de notre site. Tel serait le cas si vous tentiez d'accéder à votre compte ou à votre abonnement qui nécessite de vous identifier. Tel serait également le cas lorsque nous, ou nos prestataires, ne pourrions pas reconnaître, à des fins de compatibilité technique, le type de navigateur utilisé par votre terminal, ses paramètres de langue et d'affichage ou le pays depuis lequel votre terminal semble connecté à Internet. Le cas échéant, nous déclinons toute responsabilité pour les conséquences liées au fonctionnement dégradé de nos services résultant de l'impossibilité pour nous d'enregistrer ou de consulter les cookies nécessaires à leur fonctionnement et que vous auriez refusés ou supprimés. Les choix offerts par votre logiciel de navigation Vous pouvez configurer votre logiciel de navigation de manière à ce que des cookies soient enregistrés dans votre terminal ou, au contraire, qu'ils soient rejetés, soit systématiquement, soit selon leur émetteur. Vous pouvez également configurer votre logiciel de navigation de manière à ce que l'acceptation ou le refus des cookies vous soient proposés ponctuellement, avant qu'un cookie soit susceptible d'être enregistré dans votre terminal. Pour la gestion des cookies et de vos choix, la configuration de chaque navigateur est différente. Elle est décrite dans le menu d'aide de votre navigateur, qui vous permettra de savoir de quelle manière modifier vos souhaits en matière de cookies. Selon votre navigateur, consultez le lien ci-dessous pour configurer votre navigateur et refuser les cookies :