Update primary keys in multiple tables using PostgreSQL












0














I have 11 tables in a single schema in PostgreSQL. Each table has a column named 'id' that should be a unique primary key. Unfortunately, some of the tables have ids that are in other tables.



How can I create a new sequence and update all the tables' id values with fully unique values? Do I have to do it one sequence and one table at a time?



I'm new at SQL, so I don't know where to start beyond creating a sequence and updating a single table.










share|improve this question



























    0














    I have 11 tables in a single schema in PostgreSQL. Each table has a column named 'id' that should be a unique primary key. Unfortunately, some of the tables have ids that are in other tables.



    How can I create a new sequence and update all the tables' id values with fully unique values? Do I have to do it one sequence and one table at a time?



    I'm new at SQL, so I don't know where to start beyond creating a sequence and updating a single table.










    share|improve this question

























      0












      0








      0







      I have 11 tables in a single schema in PostgreSQL. Each table has a column named 'id' that should be a unique primary key. Unfortunately, some of the tables have ids that are in other tables.



      How can I create a new sequence and update all the tables' id values with fully unique values? Do I have to do it one sequence and one table at a time?



      I'm new at SQL, so I don't know where to start beyond creating a sequence and updating a single table.










      share|improve this question













      I have 11 tables in a single schema in PostgreSQL. Each table has a column named 'id' that should be a unique primary key. Unfortunately, some of the tables have ids that are in other tables.



      How can I create a new sequence and update all the tables' id values with fully unique values? Do I have to do it one sequence and one table at a time?



      I'm new at SQL, so I don't know where to start beyond creating a sequence and updating a single table.







      postgresql






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 15 '18 at 0:36









      BirdBird

      6483730




      6483730
























          1 Answer
          1






          active

          oldest

          votes


















          1














          Your question is a bit vague but I assume your ids are of type int/bigint. And you want these 'id's to be globally unique not just inside one table.



          There might be many options. This one is one of the most simple but maybe not the most elegant way. First create a sequence to provied ids, like:



          CREATE SEQUENCE globally_unique_id;


          Then just go through all your 11 tables with update, like:



          UPDATE table1 SET id = nextval('globally_unique_id');


          Using this one sequence will not give you the same id for any rows in all tables.



          If you have foreign key constraints in other tables to the 'id' column that are not declared to cascade on update you are in bigger trouble. But that is an another story.



          Of course you do not need to do it table by table. You could for example query Postgres system tables for all tables - like asked here - (or make an array of table names by hand) and loop tables with id in some specially constructed query or procedure.



          But in my opinion: 'only' 11 tables might not be worth of coding it. On the other hand it might be useful later if you need to do the same again.






          share|improve this answer





















            Your Answer






            StackExchange.ifUsing("editor", function () {
            StackExchange.using("externalEditor", function () {
            StackExchange.using("snippets", function () {
            StackExchange.snippets.init();
            });
            });
            }, "code-snippets");

            StackExchange.ready(function() {
            var channelOptions = {
            tags: "".split(" "),
            id: "1"
            };
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function() {
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled) {
            StackExchange.using("snippets", function() {
            createEditor();
            });
            }
            else {
            createEditor();
            }
            });

            function createEditor() {
            StackExchange.prepareEditor({
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            imageUploader: {
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            },
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            });


            }
            });














            draft saved

            draft discarded


















            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53310836%2fupdate-primary-keys-in-multiple-tables-using-postgresql%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            1














            Your question is a bit vague but I assume your ids are of type int/bigint. And you want these 'id's to be globally unique not just inside one table.



            There might be many options. This one is one of the most simple but maybe not the most elegant way. First create a sequence to provied ids, like:



            CREATE SEQUENCE globally_unique_id;


            Then just go through all your 11 tables with update, like:



            UPDATE table1 SET id = nextval('globally_unique_id');


            Using this one sequence will not give you the same id for any rows in all tables.



            If you have foreign key constraints in other tables to the 'id' column that are not declared to cascade on update you are in bigger trouble. But that is an another story.



            Of course you do not need to do it table by table. You could for example query Postgres system tables for all tables - like asked here - (or make an array of table names by hand) and loop tables with id in some specially constructed query or procedure.



            But in my opinion: 'only' 11 tables might not be worth of coding it. On the other hand it might be useful later if you need to do the same again.






            share|improve this answer


























              1














              Your question is a bit vague but I assume your ids are of type int/bigint. And you want these 'id's to be globally unique not just inside one table.



              There might be many options. This one is one of the most simple but maybe not the most elegant way. First create a sequence to provied ids, like:



              CREATE SEQUENCE globally_unique_id;


              Then just go through all your 11 tables with update, like:



              UPDATE table1 SET id = nextval('globally_unique_id');


              Using this one sequence will not give you the same id for any rows in all tables.



              If you have foreign key constraints in other tables to the 'id' column that are not declared to cascade on update you are in bigger trouble. But that is an another story.



              Of course you do not need to do it table by table. You could for example query Postgres system tables for all tables - like asked here - (or make an array of table names by hand) and loop tables with id in some specially constructed query or procedure.



              But in my opinion: 'only' 11 tables might not be worth of coding it. On the other hand it might be useful later if you need to do the same again.






              share|improve this answer
























                1












                1








                1






                Your question is a bit vague but I assume your ids are of type int/bigint. And you want these 'id's to be globally unique not just inside one table.



                There might be many options. This one is one of the most simple but maybe not the most elegant way. First create a sequence to provied ids, like:



                CREATE SEQUENCE globally_unique_id;


                Then just go through all your 11 tables with update, like:



                UPDATE table1 SET id = nextval('globally_unique_id');


                Using this one sequence will not give you the same id for any rows in all tables.



                If you have foreign key constraints in other tables to the 'id' column that are not declared to cascade on update you are in bigger trouble. But that is an another story.



                Of course you do not need to do it table by table. You could for example query Postgres system tables for all tables - like asked here - (or make an array of table names by hand) and loop tables with id in some specially constructed query or procedure.



                But in my opinion: 'only' 11 tables might not be worth of coding it. On the other hand it might be useful later if you need to do the same again.






                share|improve this answer












                Your question is a bit vague but I assume your ids are of type int/bigint. And you want these 'id's to be globally unique not just inside one table.



                There might be many options. This one is one of the most simple but maybe not the most elegant way. First create a sequence to provied ids, like:



                CREATE SEQUENCE globally_unique_id;


                Then just go through all your 11 tables with update, like:



                UPDATE table1 SET id = nextval('globally_unique_id');


                Using this one sequence will not give you the same id for any rows in all tables.



                If you have foreign key constraints in other tables to the 'id' column that are not declared to cascade on update you are in bigger trouble. But that is an another story.



                Of course you do not need to do it table by table. You could for example query Postgres system tables for all tables - like asked here - (or make an array of table names by hand) and loop tables with id in some specially constructed query or procedure.



                But in my opinion: 'only' 11 tables might not be worth of coding it. On the other hand it might be useful later if you need to do the same again.







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Nov 15 '18 at 17:57









                pirhopirho

                3,849101830




                3,849101830






























                    draft saved

                    draft discarded




















































                    Thanks for contributing an answer to Stack Overflow!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid



                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.


                    To learn more, see our tips on writing great answers.





                    Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                    Please pay close attention to the following guidance:


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid



                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.


                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function () {
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53310836%2fupdate-primary-keys-in-multiple-tables-using-postgresql%23new-answer', 'question_page');
                    }
                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Guess what letter conforming each word

                    Run scheduled task as local user group (not BUILTIN)

                    Port of Spain