[英]Easy 'create table from view' syntax in mysql?
我想创建一个表,它是视图结果的缓存。 有没有一种从视图定义中自动定义表的简单方法,还是我必须从show create table view
中将它拼凑在一起?
您可以从视图中执行CREATE TABLE SELECT
来构建它。 这应该将视图的结构复制为包含所有视图行的新表。 这是此语句的MySQL语法参考 。
CREATE TABLE tbl_from_view AS
SELECT
col1,
col2,
col3,
col4,
col5
FROM your_view;
请注意,您希望在列选择中非常明确。 不建议从源视图执行SELECT *
。 还要确保您有任何计算或聚合列的别名,如COUNT(*), MAX(*), (col1 + col2)
等。
我还发现在mysqldump输出中,有一些语句在视图定义之前将视图创建为表。 我可以解析那些并将它们作为查询运行。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.