


Génération de sous-séquences personnalisées PostgreSQL : méthode de création de sous-séquences basée sur les valeurs de clés étrangères
Cet article explique comment créer des sous-séquences personnalisées basées sur des valeurs de clé étrangère dans PostgreSQL. Les séquences de PostgreSQL sont généralement utilisées pour générer des identifiants uniques pour les lignes d'une table, mais dans certains cas, vous devrez peut-être générer une séquence pour qu'elle dépende de la valeur d'une autre colonne, créant ainsi une sous-séquence.
L'image suivante montre le cœur du problème :
Génération de séquence basée sur une corrélation personnalisée
Considérez la structure de tableau suivante :
列名 | 数据类型 | 说明 |
---|---|---|
id | integer | 外键,指向另一张表 |
seq | integer | 每个id的序列号 |
data | text | 无关信息 |
L'objectif est de construire un système d'identifiant où chaque combinaison unique d'id et de seq correspond à une ligne du tableau.
PostgreSQL y parvient grâce à une combinaison intelligente de conception de table et de déclencheurs. Nous pouvons créer deux tables : things
et stuff
, où things
représente les identifiants uniques et stuff
stocke les données réelles associées à chaque identifiant.
Créer des tables et des déclencheurs
things
La table peut créer un identifiant comme clé primaire :
CREATE TABLE things ( id serial primary key, name text );
Pour la table stuff
, nous définissons une combinaison de id et seq comme clé primaire :
CREATE TABLE stuff ( id integer references things, seq integer NOT NULL, notes text, primary key (id, seq) );
Ensuite, nous implémentons une fonction de déclenchement nommée things
sur la table make_thing_seq
. Ce déclencheur est appelé après chaque insertion de ligne et crée une nouvelle séquence avec l'identifiant inséré.
CREATE FUNCTION make_thing_seq() RETURNS trigger LANGUAGE plpgsql AS $$ begin execute format('create sequence thing_seq_%s', NEW.id); return NEW; end $$;
Ensuite, on crée un trigger nommé things
sur la table make_thing_seq
:
CREATE TRIGGER make_thing_seq AFTER INSERT ON things FOR EACH ROW EXECUTE PROCEDURE make_thing_seq();
Cela garantit que chaque fois qu'une nouvelle ligne est insérée dans la table things
, une séquence correspondante est créée.
Enfin, nous créons une fonction de déclenchement nommée fill_in_stuff_seq
qui est appelée avant chaque insertion de ligne et remplit la colonne seq
avec la valeur suivante appropriée de la séquence.
CREATE FUNCTION fill_in_stuff_seq() RETURNS trigger LANGUAGE plpgsql AS $$ begin NEW.seq := nextval('thing_seq_' || NEW.id); RETURN NEW; end $$;
Créez un déclencheur nommé stuff
sur la table fill_in_stuff_seq
:
CREATE TRIGGER fill_in_stuff_seq BEFORE INSERT ON stuff FOR EACH ROW EXECUTE PROCEDURE fill_in_stuff_seq();
Cela garantit que lorsqu'une ligne de la table stuff
est insérée, la valeur seq
est automatiquement définie en fonction de la valeur d'identification associée.
Résultats
Avec ces déclencheurs, la génération de séquence souhaitée peut être obtenue. L'insertion de données dans la table things
créera une nouvelle séquence, et l'insertion de données dans la table stuff
attribuera automatiquement le numéro de séquence correct en fonction de la référence d'identification.
En combinant ces techniques, nous pouvons créer des structures de données complexes et flexibles qui répondent à des exigences de tri spécifiques.
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!

MySQLDIFFERSFromothersqlDialictsinsyntaxforlimit, auto-imprémentation, stringcomparison, sous-questionnaires et performanceanalysis.1) MySqluseSlimit, WhilesQlServerUseStopandorAnUseSrownum.2)

Le partitionnement MySQL améliore les performances et simplifie la maintenance. 1) Diviser les grandes tables en petits morceaux par des critères spécifiques (tels que les gammes de dattes), 2) Divisez physiquement les données en fichiers indépendants, 3) MySQL peut se concentrer sur des partitions connexes lors de l'interrogation, 4) L'optimiseur de requête peut ignorer les partitions non liées, 5) le choix de la bonne stratégie de partition et le maintenir régulièrement est la clé.

Comment accorder et révoquer les autorisations dans MySQL? 1. Utilisez la déclaration de subvention pour accorder des autorisations, telles que GrantallPrivilegesondatabase_Name.to'Username'@'host '; 2. Utilisez la déclaration de révocation pour révoquer les autorisations, telles que Revokeallprivilegesondatabase_name.from'username'@'host 'pour garantir la communication opportune des modifications d'autorisation.

INNODB convient aux applications qui nécessitent un support de transaction et une concurrence élevée, tandis que Myisam convient aux applications qui nécessitent plus de lectures et moins d'écritures. 1.InNODB prend en charge les verrous de transaction et de bancs, adaptés aux systèmes de commerce électronique et bancaire. 2.Myisam fournit une lecture et une indexation rapides, adaptées aux systèmes de blogs et de gestion de contenu.

Il existe quatre types de jointures principales dans MySQL: innerjoin, gauche, droite et fullouterjoin. 1.Innerjoin Renvoie toutes les lignes dans les deux tableaux qui remplissent les conditions de jointure. 2.Leftjoin Renvoie toutes les lignes de la table de gauche, même s'il n'y a pas de lignes correspondantes dans la table droite. 3. Le droit est contraire à la gauche et renvoie toutes les lignes dans la table droite. 4.FulLouterJoin Renvoie toutes les lignes dans les deux tableaux qui se rencontrent ou ne remplissent pas les conditions de jointure.

MySQLoffersVariousStorageEngines, chacune, chacun desCasses: 1) InnodbisidealForApplications newedingacidcompenciance and highcurrency, soutenant les transactions et manqueurs

Les vulnérabilités de sécurité courantes dans MySQL incluent l'injection SQL, les mots de passe faibles, la configuration d'autorisation incorrecte et les logiciels unpudés. 1. L'injection SQL peut être évitée en utilisant des instructions de prétraitement. 2. Les mots de passe faibles peuvent être évités en utilisant de force des stratégies de mot de passe solides. 3. Une mauvaise configuration d'autorisation peut être résolue par examen régulier et ajustement des autorisations utilisateur. 4. Les logiciels unpus peuvent être corrigés en vérifiant et mise à jour régulièrement la version MySQL.

L'identification des requêtes lentes dans MySQL peut être réalisée en activant les journaux de requête lents et en définissant des seuils. 1. Activer les journaux de requête lents et définir les seuils. 2. Afficher et analyser les fichiers journaux de requête lente et utiliser des outils tels que MySqlDumpSlow ou Pt-Query-digest pour une analyse approfondie. 3. Optimisation des requêtes lentes peut être réalisée grâce à l'optimisation de l'index, à la réécriture de la requête et à l'évitement de l'utilisation de Select *.


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

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

Navigateur d'examen sécurisé
Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

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

Version Mac de WebStorm
Outils de développement JavaScript utiles

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