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

Administration PostgreSQL Discussion :

Changer de schéma


Sujet :

Administration PostgreSQL

  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Janvier 2006
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Corse (Corse)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 476
    Points : 831
    Points
    831
    Par défaut Changer de schéma
    bonjour ,
    j'ai toutes mes tables dans le schéma public ,est-il possible de créer un nouveau schéma et d'y importer toutes les tables?

  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 761
    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 761
    Points : 52 547
    Points
    52 547
    Billets dans le blog
    5
    Par défaut
    PostGreSQL ayant commis la même erreur qu'Oracle (en fait les développeurs du moteur PG ont décider de singer Oracle) il n'est pas possible de transférer certains objets d'un schma dans un autre comme c'est le cas de la commande :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ALTER SCHEMA mon_schema TRANSFER mon_objet;
    Néanmoins, vous pouvez changer le nom d'un schéma en faisant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ALTER SCHEMA mon_schema RENAME mon_nouveau_nom
    Cela dit, si vous avez mis en place une sécurité via des privilèges cela risque d'être dangereux !

    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/ * * * * *

  3. #3
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Janvier 2006
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Corse (Corse)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 476
    Points : 831
    Points
    831
    Par défaut
    merci, je crois que je vais être prudent

  4. #4
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut
    Salut
    C'est bien possible de changer de schema...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ALTER TABLE ancien_schema.latable
      SET SCHEMA nouveau_cshema
    Vous pouvez utiliser ce code pour boucler sur les tables
    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
    DO $$DECLARE r record;
    BEGIN
        FOR r IN select n.nspname , c.relname  FROM pg_class c inner JOIN pg_namespace n ON n.oid = c.relnamespace
    inner join pg_authid a on c.relowner=a.oid
            WHERE c.relkind = 'r'::"char" and n.nspname='ancine_schema' 
        LOOP
    	begin
     
            EXECUTE 'ALTER TABLE ' || r.nspname || '.' || r.relname || 'SET SCHEMA nouveau_schema' ;
    	exception
    	when others then
    	continue;
            end;
        END LOOP;
    END$$;
    Mais si c'est l'ensemble des objets, la solution de SQLpro est mieux!
    @+
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

Discussions similaires

  1. Changer le schéma d'une requête d'un gridview
    Par quake3 dans le forum Général Dotnet
    Réponses: 2
    Dernier message: 12/04/2011, 13h35
  2. Changer d'utilisateur sous un même schéma oracle 9i
    Par saigon dans le forum Sql Developer
    Réponses: 2
    Dernier message: 18/09/2008, 10h19
  3. [9i] changer un table des schéma
    Par sygale dans le forum Oracle
    Réponses: 1
    Dernier message: 05/05/2006, 14h38
  4. [Crystal Report 9] Changer de schéma avec Oracle
    Par sur_uix dans le forum SAP Crystal Reports
    Réponses: 2
    Dernier message: 14/11/2002, 12h19
  5. changer l'adresse d'un fichier...
    Par cava dans le forum C
    Réponses: 6
    Dernier message: 05/06/2002, 12h22

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