数据库入门教程:如何在 MySQL 中选择除了某一列以外的所有列?

SQL通过SELECT *(SELECT ALL)子句使选择表中的所有字段变得非常简单。 不幸的是,一旦您从列表中省略一列,SELECT ALL语句就会消失。 写出每个列的名称很快就会变得乏味,尤其是当您碰巧要处理包含数十个列的表时。 如果我们可以选择除一列之外的每一列怎么办-通过排除而不是包含进行选择? 可以办到。 实际上,有两种方法可以做到这一点-一种简单,另一种则少一些。 这些将是今天博客的重点。

SQL通过SELECT *(SELECT ALL)子句使选择表中的所有字段变得非常简单。 不幸的是,一旦您从列表中省略一列,SELECT ALL语句就会消失。 写出每个列的名称很快就会变得乏味,尤其是当您碰巧要处理包含数十个列的表时。 如果我们可以选择除一列之外的每一列怎么办-通过排除而不是包含进行选择可以办到。 实际上,有两种方法可以做到这一点-一种简单,另一种则少一些。 这些将是今天博客的重点。

方法1:使用INFORMATION_SCHEMA.COLUMNS表

INFORMATION_SCHEMA提供对数据库元数据的访问,有关MySQL服务器的信息,例如数据库或表的名称,列的数据类型或访问权限。 更具体地说,COLUMNS表提供有关表中列的信息,包括列名。

The Sakila示例数据库的电影表中包含了最多的列13列。

film_columns (50K)

这是我们使用INFORMATION_SCHEMA.COLUMNS表来获取除original_language_id列以外的所有列的方式:

数据库入门教程:如何在 MySQL 中选择除了某一列以外的所有列?

GROUP_CONCAT函数将所有列名称连接为一个逗 分隔的字符串。 然后,我们可以将字段替换为空字符串!

执行查询

要克服的一个小障碍是MySQL查询不能接受动态列名。 解决方案是采用准备好的语句。 这是设置@sql变量,准备语句并执行的代码:

SET @sql = CONCAT('SELECT ',            (SELECT REPLACE(GROUP_CONCAT(COLUMN_NAME), '<columns_to_omit>,', '')             FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = '<table>'             AND TABLE_SCHEMA = '<database>'),                     ' FROM <table>');  PREPARE stmt1 FROM @sql;  EXECUTE stmt1;  

在查询中插入列,表和模式信息会产生我们想要的结果:

数据库入门教程:如何在 MySQL 中选择除了某一列以外的所有列?

方法2:使用Navicat

在查询创建工具中,表名称旁边有一个复选框,用于选择其所有列。 如果单击它,则只需取消选中original_language_id字段即可将其从列列表中删除:

数据库入门教程:如何在 MySQL 中选择除了某一列以外的所有列?

数据库入门教程:如何在 MySQL 中选择除了某一列以外的所有列?

与手动编写代码相比,使用查询创建工具创建查询具有一些优势:

  • 减少错别字
  • 生成易于阅读的格式化SQL

总结

在今天的博客中,我们学习了两种技术来选择表中的每一列,你学会了吗即下载Navicat for MySQL体验吧!

标签:

声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2021年1月1日
下一篇 2021年1月1日

相关推荐

发表回复

登录后才能评论