


Insertion de plusieurs lignes avec les CTE de PostgreSQL
Supposons que vous disposiez d'une base de données relationnelle avec trois tables : table1, table2 et table3. La table table1 contient des informations générales sur l'utilisateur, tandis que les tables table2 et table3 contiennent des données supplémentaires telles que des mots de passe et des adresses. Lorsque vous ajoutez un nouvel utilisateur dans la table1, vous souhaitez insérer simultanément l'ID utilisateur et d'autres données uniques dans les tables enfants table2 et table3.
Les CTE de modification de données de Postgres 9.3 fournissent une solution à ce scénario. Les CTE vous permettent d'enchaîner plusieurs opérations INSERT de manière efficace.
Voici comment utiliser les CTE modifiant les données pour accomplir votre tâche :
WITH ins1 AS ( INSERT INTO table1 (username, name, surname) VALUES ('johnee', 'john', 'smith') RETURNING user_id ), ins2 AS ( INSERT INTO table2 (user_id, password) SELECT ins1.user_id, 'secret' FROM ins1 -- Nothing to return here ) INSERT INTO table3 (user_id, address, city, phone) SELECT ins1.user_id, ..., ... FROM ins1 RETURNING user_id;
Répartition du CTE :
- ins1 CTE : Insère une nouvelle ligne dans table1 et renvoie l'ID utilisateur nouvellement créé.
- ins2 CTE : Utilise l'ID utilisateur de ins1 pour insérer des données dans la table2. Puisqu'il n'est pas nécessaire de renvoyer une valeur, elle est omise.
- INSERT final : Insère des données dans la table3 en utilisant l'id_utilisateur de ins1 et des colonnes supplémentaires. Vous pouvez spécifier les colonnes et les valeurs souhaitées selon vos besoins. La clause RETURNING facultative vous permet de récupérer l'ID utilisateur nouvellement créé à partir de la table3.
Bonnes pratiques :
- Incluez toujours une liste de définitions de colonnes dans votre INSERT pour garantir la cohérence avec la structure de votre table.
- Si une colonne doit recevoir une valeur par défaut, omettez-la simplement dans INSERT déclaration; Postgres insérera automatiquement la valeur par défaut.
- Le dernier CTE peut éventuellement renvoyer une valeur, ce qui pourrait être utile pour un traitement ultérieur ou pour récupérer les identifiants nouvellement créés.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Comment surveiller efficacement les performances MySQL? Utilisez des outils tels que MySqladmin, ShowGlobalStatus, Perconamonitoring and Management (PMM) et MySQL EnterpriMeitor. 1. Utilisez MySqladmin pour afficher le nombre de connexions. 2. Utilisez ShowGlobalStatus pour afficher le numéro de requête. 3.PMM fournit des données de performances détaillées et une interface graphique. 4.MySQLenterPrisemonitor fournit des fonctions de surveillance et des mécanismes d'alarme riches.

La différence entre MySQL et SQLServer est: 1) MySQL est open source et adapté aux systèmes Web et intégrés, 2) SQLServer est un produit commercial de Microsoft et convient aux applications au niveau de l'entreprise. Il existe des différences significatives entre les deux dans le moteur de stockage, l'optimisation des performances et les scénarios d'application. Lors du choix, vous devez considérer la taille du projet et l'évolutivité future.

Dans les scénarios d'application au niveau de l'entreprise qui nécessitent une haute disponibilité, une sécurité avancée et une bonne intégration, SQLServer doit être choisi au lieu de MySQL. 1) SQLServer fournit des fonctionnalités de niveau d'entreprise telles que la haute disponibilité et la sécurité avancée. 2) Il est étroitement intégré aux écosystèmes Microsoft tels que VisualStudio et PowerBI. 3) SQLServer fonctionne excellent dans l'optimisation des performances et prend en charge les tables optimisées par la mémoire et les index de stockage de colonnes.

MySqlManagesCharAttetsEtsAndCollationsByusingUtf-8AstheDefault, permettant à la configuration dedata

Un déclencheur MySQL est une procédure stockée automatiquement exécutée associée à une table qui est utilisée pour effectuer une série d'opérations lorsqu'une opération de données spécifique est effectuée. 1) Définition et fonction de déclenchement: utilisé pour la vérification des données, la journalisation, etc. 2) Principe de travail: il est divisé en avant et après et prend en charge le déclenchement au niveau des lignes. 3) Exemple d'utilisation: peut être utilisé pour enregistrer les modifications de salaire ou mettre à jour l'inventaire. 4) Compétences de débogage: utilisez des commandes ShowTriggers et ShowCreateTrigger. 5) Optimisation des performances: Évitez les opérations complexes, utilisez des index et gérez les transactions.

Les étapes pour créer et gérer les comptes d'utilisateurs dans MySQL sont les suivants: 1. Créez un utilisateur: utilisez CreateUser'NewUser '@' localHost'IdentifiedBy'Password '; 2. Attribuez des autorisations: utilisez GRANSELECT, INSERT, UPDATEONMYDATABASE.TO'NEWUSER'@'LOCALHOST '; 3. Correction de l'erreur d'autorisation: Utilisez Revokeallprivilegesonmydatabase.from'newuser'@'localhost '; puis réaffectez les autorisations; 4. Autorisations d'optimisation: utilisez Showgra

MySQL convient au développement rapide et aux applications petites et moyennes, tandis qu'Oracle convient aux grandes entreprises et aux besoins à haute disponibilité. 1) MySQL est open source et facile à utiliser, adapté aux applications Web et aux petites et moyennes entreprises. 2) Oracle est puissant et adapté aux grandes entreprises et aux agences gouvernementales. 3) MySQL prend en charge une variété de moteurs de stockage, et Oracle offre des fonctions riches de niveau d'entreprise.

Les inconvénients de MySQL par rapport à d'autres bases de données relationnelles incluent: 1. Problèmes de performances: Vous pouvez rencontrer des goulots d'étranglement lors du traitement des données à grande échelle, et PostgreSQL fonctionne mieux dans les requêtes complexes et le traitement des mégadonnées. 2. Évolutivité: la capacité de mise à l'échelle horizontale n'est pas aussi bonne que Google Spanner et Amazon Aurora. 3. Limites fonctionnelles: pas aussi bonnes que PostgreSQL et Oracle dans les fonctions avancées, certaines fonctions nécessitent plus de code et de maintenance personnalisés.


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

VSCode Windows 64 bits Télécharger
Un éditeur IDE gratuit et puissant lancé par Microsoft

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

mPDF
mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

PhpStorm version Mac
Le dernier (2018.2.1) outil de développement intégré PHP professionnel

SublimeText3 version anglaise
Recommandé : version Win, prend en charge les invites de code !