选择MySQL通配符

时间:2011-04-07 13:47:10

标签: mysql wildcard

有没有办法选择带外卡的列。

选择名称类型的列可以是“SELECT %type% from table_name”?

3 个答案:

答案 0 :(得分:3)

不是真的。您可以使用* column wildcard选择所有列。如果要连接多个表,则可以通过在*前加上表名或别名来选择特定表中的所有列:

SELECT a.id, a.title, b.*
  FROM articles AS a
    JOIN blurbs AS b ON a.id = b.article

但是,除非您正在编写数据库管理程序,否则不应使用*

或者,您可以通过获取表元数据来获取列名,从而在SQL或其他语言中构建语句。只使用MySQL,您可以查询COLUMNS数据库中的INFORMATION_SCHEMA表来获取列名,并使用GROUP_CONCAT来构建语句的列列表。

SELECT CONCAT(
      'SELECT ',
      GROUP_CONCAT(COLUMN_NAME SEPARATOR ', '),
      ' FROM ', :db, '.', :table,
      ' WHERE ...'
      )
  FROM INFORMATION_SCHEMA.COLUMNS
  WHERE TABLE_SCHEMA=:db AND TABLE_NAME=:table

用适当的值替换“:db”,“:table”和“...”。您甚至可以将其转换为预准备语句,以便将其用于任何表。从那里,PREPAREEXECUTE构造语句。

如果您不仅限于SQL编程,那么它应该不那么混乱。您选择的语言的DB驱动程序可能提供获取元数据的方法。实际的实现类似于纯SQL方法(获取列名,汇编语句,准备,执行),但不应该如此丑陋,因为您将使用算法而不是声明性语言。

我非常有兴趣了解实际需要的情况。

答案 1 :(得分:1)

您可以使用information_schema找到名称中包含类型的所有字段,然后使用预准备语句。

set @str = (concat('select ',(select concat(group_concat(column_name),' from ',table_name)
from information_schema.columns
where table_schema = 'your_db_name' and table_name = 'your_table_name' and column_name like '%type%')));
prepare stmt from @str;
execute stmt;
deallocate prepare stmt;

答案 2 :(得分:0)

如果您使用的是前端语言,当然可以。如果php只是使用

 $fieldlist= "cola, colb ";
 $tablename="tabl";
"select $fieldlist from $table"

我的直觉告诉你使用php-mysql做一些简单的事情,但我可能错了。