mysql _ 通配符_选择MySQL通配符

有没有办法用通配符选择列.

喜欢

选择名称类型可能是’SELECT%type%from table_name’的列?

解决方法:

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

SELECT a.id, a.title, b.*

FROM articles AS a

JOIN blurbs AS b ON a.id = b.article

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

或者,您可以通过获取表元数据来获取列名,从而在SQL或其他语言中构建语句.使用MySQL,您可以查询INFORMATION_SCHEMA数据库中的COLUMNS表以获取列名称,并使用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”和“…”.您甚至可以将其转换为预准备语句,以便将其用于任何表.从那里,PREPARE和EXECUTE构建的声明.

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

我非常有兴趣看到实际需要的情况.

标签:mysql,wildcard

来源: https://codeday.me/bug/20191002/1841258.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值