繁体   English   中英

在mysql中轻松'从视图创建表'语法?

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM