我有一个视图,并希望将其数据提取到一个文件,该文件具有创建表语句和数据.
我知道mysqldump不适用于视图.
最佳答案
显然,没有一种自动方法来生成不存在的表的CREATE TABLE语句.所以你基本上有两个选择:
>创建一个实际的表,然后将其转储并删除.
>编写大量代码来分析视图和基础表并生成相应的SQL.
第一个选项根本不是最优选,但它很容易实现:
CREATE TABLE my_table AS
SELECT *
FROM my_view
您现在可以使用mysqldump转储表.当你完成了:
DROP TABLE my_table
第二个选项可以根据您的需要进行最佳选择,但它可能会变得非常复杂,并且很大程度上取决于您的实际需求和工具可用性.但是,如果性能是一个问题,您可以通过快速而肮脏的技巧将两种方法结合起来:
CREATE TABLE my_table AS
SELECT *
FROM my_view
LIMIT 1;
SHOW CREATE TABLE my_table;
现在,您使用自己喜欢的语言从my_view读取值并构建相应的INSERT INTO代码.最后:
DROP TABLE my_table;
无论如何,请随意解释为什么需要从视图中获取SQL代码,我们可能能够找到更好的解决方案.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。