如何在 MySQL 中动态选择列?
首先,你需要准备一个查询,然后你需要执行准备好的语句来动态选择 MySQL 中的列。
让我们先创建一个表 −
mysql> create table DemoTable ( EmployeeName varchar(100) ); Query OK, 0 rows affected (0.77 sec)
使用插入命令在表中插入一些记录 −
mysql> insert into DemoTable values('John Doe'); Query OK, 1 row affected (0.18 sec)
使用 select 语句从表中显示所有记录 −
mysql> select *from DemoTable;
这将产生以下输出 −
+--------------+ | EmployeeName | +--------------+ | John Doe | +--------------+ 1 row in set (0.00 sec)
现在让我们动态选择 MySQL 中的列 −
mysql> set @dynamicQuery=CONCAT("SELECT ", (SELECT "EmployeeName from DemoTable")); Query OK, 0 rows affected (0.00 sec) mysql> select @dynamicQuery; +---------------------------------------+ | @dynamicQuery | +---------------------------------------+ | SELECT EmployeeName from DemoTable | +---------------------------------------+ 1 row in set (0.00 sec) mysql> prepare myStatement from @dynamicQuery; Query OK, 0 rows affected (0.00 sec) Statement prepared mysql> execute myStatement;
这将产生以下输出 −
+--------------+ | EmployeeName | +--------------+ | John Doe | +--------------+ 1 row in set (0.00 sec)
广告