IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PostgreSQL Discussion :

Création d'indexes GIN avec to_tsvector = Error


Sujet :

PostgreSQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre extrêmement actif
    Avatar de kedare
    Homme Profil pro
    SRE
    Inscrit en
    Juillet 2005
    Messages
    1 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Espagne

    Informations professionnelles :
    Activité : SRE

    Informations forums :
    Inscription : Juillet 2005
    Messages : 1 549
    Par défaut Création d'indexes GIN avec to_tsvector = Error
    Hello,
    j'ai un probleme, je crée des tables avec ce script la :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    CREATE TABLE channels (
        id serial NOT NULL,
        name character(255) NOT NULL,
        reg_date timestamp with time zone,
        last_activity timestamp with time zone,
        flags character(24),
     
        CONSTRAINT channel_pk PRIMARY KEY (id),
        CONSTRAINT channel_unik UNIQUE (id,name)
    );
     
    CREATE TABLE users (
        id serial NOT NULL,
        name text NOT NULL,
        admin_level integer,
        last_activity timestamp with time zone,
        reg_date timestamp with time zone,
     
        CONSTRAINT users_pk PRIMARY KEY (id),
        CONSTRAINT users_unik UNIQUE (id,name)
    );
     
    CREATE TABLE messages (
        id serial NOT NULL,
        content text,
        user_id integer,
        channel_id integer,
        post_date timestamp with time zone,
     
        CONSTRAINT messages_pk PRIMARY KEY (id),
        CONSTRAINT messages_unik UNIQUE (id),
        CONSTRAINT messages_fk_channels FOREIGN KEY (channel_id) REFERENCES channels(id),
        CONSTRAINT messages_fk_users FOREIGN KEY (user_id) REFERENCES users(id)
    );
     
    CREATE TABLE user_on_channel (
        id serial NOT NULL,
        user_id integer NOT NULL,
        channel_id integer NOT NULL,
        level integer,
        flags character(24),
     
        CONSTRAINT user_on_channel_pk PRIMARY KEY (id),
        CONSTRAINT user_on_channel_unik UNIQUE (id),
        CONSTRAINT user_on_channel_fk_users FOREIGN KEY (user_id) REFERENCES users(id),
        CONSTRAINT user_on_channel_fk_channels FOREIGN KEY (channel_id) REFERENCES channels(id)
    );
     
     
    CREATE INDEX channels_idx_btree_id_name on channels using btree(id, name);
    CREATE INDEX users_idx_btree_id_name on users using btree(id, name);
    CREATE INDEX messages_idx_btree_id_content on messages using btree(id, content);
    CREATE INDEX messages_idx_gin_content on messages using gin(to_tsvector(content));
    deja, je voudrais savoir si il y a certaines conventions de nommage pour nommer les indexes et contraintes ?

    autre chose, impossible de créer l'index GIN pour la recherche fulltext sur les messages, j'ai cette erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ERROR: functions in index expression must be marked IMMUTABLE
    État SQL :42P17
    savez vous comment regler ce problème ?
    merci

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 998
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 998
    Billets dans le blog
    6
    Par défaut
    Pour ma part, tous mes objets sont préfixés. pour les contraintes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    DK_ => default
    NK_ => not null
    PK_ => primary key
    UK_ => unique
    FK_ => foreign key
    CK_ => CHECK
    Donc retrouver toutes les contraintes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE nom_contrainte LIKE '_K?_%' ESCAPE '?'
    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

Discussions similaires

  1. Réponses: 2
    Dernier message: 24/08/2012, 14h20
  2. Réponses: 4
    Dernier message: 04/07/2008, 16h29
  3. Création d'index sur tables avec 400000 rows
    Par Poisson59 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 25/07/2007, 13h53
  4. Création d'Index
    Par viny dans le forum Requêtes
    Réponses: 2
    Dernier message: 08/12/2003, 13h20
  5. Pb de configuration postgre -> plantage avec DB error
    Par liv dans le forum Installation
    Réponses: 6
    Dernier message: 05/11/2003, 18h07

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo