Can I copy a full schema (for testing needs ) on the same node?
I need to copy a full schema "public" and call it another name for test purposes .I need all the tables +data +objects+ constraints and everything that is in my "public" schema .It is for test purposes.I want to start a new DBD layout for this new schema and I don't want to create a mess with the working schema.any suggestions?
I have only one node on the cluster with one machine.(ubuntu)
0
Answers
Do you have any other objects other than tables?
If you have just tables to move (and their constraints), you can simply use the ALTER TABLE ... SET SCHEMA to bulk move them from PUBLIC to your new schema...
Example:
See:
https://www.vertica.com/docs/latest/HTML/Content/Authoring/SQLReferenceManual/Statements/ALTERTABLE.htm
wow thanks so much for your answer , the thing is that I don´t want to move the tables I want to copy them exactly to a new schema on the same db.
COPY_TABLE copies one table to another.
This lightweight, in-memory copy increases performance by initially sharing the same storage between two tables.
The copied table includes copies of any explicitly created projections from the source table.
Once copied, the source and copy tables are independent of each other.
Users can perform operations on one table without impacting the other.
Here is an example:
Thanks! so if I query my new copied table I will have all the data in it?(because data in vertica is stored in projections and not in tables it makes me a bit confused. )
I want to create this new schema for testing purposes so I don't "destroy" the original schema.
Q - If I query my new copied table I will have all the data in it?
A - Yes, the copied table includes copies of any explicitly created projections from the source table.
Thanks again.
Is there a way to bulk copy all objects from the schema or do I need to do it manually table by table?
There are other options but the big advantage of the COPY_TABLE method is that the source and target tables initially share the same storage. You can duplicate huge tables very fast, with almost no I/O, and initially with no need for extra storage.
It is advised to do the copy tables with COPY_TABLE sequentially, as shown above.
For more info see: https://www.vertica.com/docs/10.1.x/HTML/Content/Authoring/SQLReferenceManual/Functions/VerticaFunctions/COPY_TABLE.htm
Thanks so much for your help! I did it and it works.:-)
Happy to assist