栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

我可以在准备好的语句中参数化表名吗?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

我可以在准备好的语句中参数化表名吗?

对您的问题的简短回答是“否”。

从最严格的意义上讲,在数据库级别,准备好的语句仅允许将参数绑定到SQL语句的“值”位。

一种思考的方式是“可以在语句的运行时执行而不替换其含义的事物”。表名不是这些运行时值之一,因为它确定SQL语句本身的有效性(即,哪些列名有效),并且在执行时对其进行更改将有可能更改SQL语句是否有效。

在更高的级别上,即使在模拟准备好的语句参数替换而不是实际将准备好的语句发送到数据库的数据库接口(例如PDO)中,也可以想象到,这可以允许您在任何地方使用占位符(因为占位符在发送到在这些系统上的数据库),该表占位符的值是一个字符串,并将其发送到数据库的SQL内封入作为这样,所以

SELECt* FROM ?
mytable
作为PARAM将实际上最终发送
SELECt * FROM 'mytable'
到数据库中,这是无效的SQL。

您最好的选择就是继续

SELECt * FROM {$mytable}

但是 绝对 应该有一个白名单的表,如果该表

$mytable
来自用户输入,则应首先对其进行检查。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/371672.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号