mirror of
https://github.com/almet/notmyidea.git
synced 2025-04-29 12:02:39 +02:00
76 lines
No EOL
3.5 KiB
HTML
76 lines
No EOL
3.5 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<title>PyconFR 2015 — <span class="caps">SQL</span> Alchemy - Alexis Métaireau</title>
|
|
<meta charset="utf-8" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
<link rel="stylesheet" href="https://blog.notmyidea.org/theme/css/main.css" type="text/css" />
|
|
<link href="https://blog.notmyidea.org/feeds/all.atom.xml" type="application/atom+xml" rel="alternate" title="Alexis Métaireau ATOM Feed" />
|
|
</head>
|
|
<body>
|
|
<section id="links">
|
|
<li>
|
|
<a class="" href="https://blog.notmyidea.org/" id="site-title">Blog</a>
|
|
</li>
|
|
<li><a class="" href="https://blog.notmyidea.org/pages/projets.html">Projets</a></li>
|
|
</section>
|
|
|
|
|
|
|
|
|
|
|
|
<header>
|
|
<h1 class="post-title">PyconFR 2015 — <span class="caps">SQL</span> Alchemy</h1>
|
|
<time datetime="2015-10-17T00:00:00+02:00">17 octobre 2015</time>
|
|
|
|
|
|
</header>
|
|
<article>
|
|
<div class="admonition note">
|
|
<p class="first admonition-title">Note</p>
|
|
<p class="last">Voici quelques notes prises durant la PyconFR 2015, à Pau. N’hésitez pas
|
|
à les completer si besoin.</p>
|
|
</div>
|
|
<p>Speaker: David Allouche</p>
|
|
<p><span class="caps">SQL</span> Alchemy vous permet de produire le <span class="caps">SQL</span> que vous voulez. Il faut que vous
|
|
souhaitiez comprendre ce que va etre produit.</p>
|
|
<p>Déclaratif:</p>
|
|
<ul class="simple">
|
|
<li>On créé des classes qui representent nos tables, et les liaisons entre les
|
|
tables, en utilisant <cite>relationship</cite> (qui à énormement d’attributs).</li>
|
|
<li>On définit quelles osnt les clés étrangères entre les tables.</li>
|
|
<li>Puis on va définir les attributs qui sont liés entre les tables (relationship).</li>
|
|
<li>Pour définir des relations entre les Tables, il est possible d’utiliser des
|
|
chaines de caractère <cite>relationship(‘OtherTable’)</cite>.</li>
|
|
<li>La session es tun concept important.</li>
|
|
<li>Lire efficacement. Attention à ne pas faire énormement de requetes avec
|
|
L’<span class="caps">ORM</span>.</li>
|
|
</ul>
|
|
<p><strong>Performance <span class="caps">SQL</span></strong></p>
|
|
<ul class="simple">
|
|
<li>Générer le <span class="caps">SQL</span> (python)</li>
|
|
<li>Ne pas faire énormement de petites requetes.</li>
|
|
</ul>
|
|
<p>Il est possible de demander à la session de charger les données qui sont
|
|
associées. (avec un joinedload). Par defaut, cela risque de charger
|
|
l’ensemble des colonnes.</p>
|
|
<p>Pour la générer avec SQLAlchemy, il est possible de faire un
|
|
<cite>.query(Table).join(Table).join(Table2).filter_by(field=value)</cite></p>
|
|
<p>En pratique, le mieux est de lister clairemnet le nom des tables</p>
|
|
<p>2ème partie:</p>
|
|
<p>Pour de l’import de données,</p>
|
|
<ul class="simple">
|
|
<li>first() fait une requete <span class="caps">SQL</span>. A éviter dans les boucles</li>
|
|
<li>session.flush() c’est quand la session écrit en base tout ce qui est en cours
|
|
dans la transaction. Par default, la session fait un flush avant chaque requete.</li>
|
|
<li>une option backçpopulates mets à jour la liste des documents associés à une
|
|
table qui à une foreign key.
|
|
backref modifie implicitement la classe associée. Il est recommandé
|
|
d’utiliser <cite>back_populates</cite> et non pas <cite>backref</cite>.</li>
|
|
<li><cite>subqueryload</cite> permet de générer une requete séparée plutôt qu’une jointure.</li>
|
|
</ul>
|
|
|
|
</article>
|
|
|
|
</body>
|
|
</html> |