- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在创建一个自定义类,以便更轻松地连接和使用 mysql。我创建了许多功能,除了一个部分外,其他功能都很好。我似乎无法弄清楚如何确定一个字符串是一个实际的字符串还是一个 mysql 函数以便在它周围加上引号。我将一个可以传递两个参数的函数放在一起,它将插入到数据库中。第一个参数是要插入的表,而第二个参数是列值对的数组。也许这个代码示例会帮助您了解更多。注意:我已经转义了所有字符串并删除了该代码以显示问题的简单性。
function insert($table,array $array){
$table = "`".$table."`";
$columns = "";
$values = "";
foreach($array as $key => $value){
$columns = ($columns=="") ? "`".$key."`" : $columns.", `".$key."`";
if($value===NULL || $value=="NULL"){
$value = "NULL";
} else {
$value = "'".$value."'";
}
$values = ($values=="") ? "".$value."" : $values.", ".$value."";
}
$query = "INSERT INTO $table ($columns) VALUES ($values)";
return $this->query($query);
}
这里是两个不同用途的例子以及各自的预期结果
$data = array(
"first_name"=>"John",
"last_name"=>"Doe",
"entry_date"=>"2013-08-26"
);
$MyClass->insert("people",$data);
会执行
INSERT INTO `people` (`first_name`,`last_name`,`entry_date`) VALUES ('John','Doe','2013-08-26')
这是预期的但是以下用途:
$data = array(
"first_name"=>"John",
"last_name"=>"Doe",
"entry_date"=>"NOW()"
);
$MyClass->insert("people",$data);
将执行为
INSERT INTO `people` (`first_name`,`last_name`,`entry_date`) VALUES ('John','Doe','NOW()')
这将不起作用,因为MySQL函数如果带引号将不会运行。我知道这可能是一个小的安全风险,因为如果不被捕获,它会允许用户使用功能。有没有更好的方法来做到这一点,或者应该不允许在这样的类插入函数中使用 MySQL 函数?如果有人将正则表达式放在一起以查找并允许 mysql 函数,那么这可能是一个解决方案。如果不存在这样的正则表达式,那么一种可能性是从头开始编写一个我不太擅长的......
编辑:
我将同时使用的另一个解决方案是在形成数组时使用 PHP 获取日期。如果可能的话,我还是想使用 MySQL 函数。这是我当前解决问题的代码,但不是我喜欢的方式:
$data = array(
"first_name"=>"John",
"last_name"=>"Doe",
"entry_date"=>date('Y-m-d H:i:s'),
);
$MyClass->insert("people",$data);
最佳答案
几年前,我实现了一项功能来完成您所描述的 Zend Framework 1.0。
我通过区分普通字符串标量和包含字符串的对象 解决了这个问题。
$data = array(
"first_name"=>"John",
"last_name"=>"Doe",
"entry_date"=>new Zend_Db_Expr("NOW()")
);
$MyClass->insert("people",$data);
这样我的框架就可以区分我打算处理的 PHP 字符串作为 SQL 字符串(即带引号),而不是在对象中汇总的字符串。
if($value===NULL || $value=="NULL"){
$value = "NULL";
} else if ($value instanceof Zend_Db_Expr) {
$value = $value->__toString(); // no quotes
} else {
$value = "'".$value."'";
}
PS:有些人可能会建议您使用查询参数,而不是像您这样做的那样连接转义变量。我同意这个建议,但它确实与你原来的问题没什么关系,所以我不会深入探讨。还有许多其他 StackOverflow 问题涉及使用查询参数。
回复你的评论:
您可以使用正则表达式来匹配 NOW()
和所有其他 MySQL 函数并特殊对待它们,但是您如何插入文字字符串“NOW()”(不是函数的结果那个名字)?
回答:你不能——就像你不能在你当前的代码中插入文字字符串“NULL”一样,因为你已经把这个词当作一个特例来对待。
您需要一些方法来区分 SQL 表达式 NOW()
和“NOW()”。仅仅因为您今天不需要将该字符串插入您的数据库并不意味着您将永远不需要该功能。请记住,您正在设计此 insert() 函数以针对当前或将来的任何 表进行一般使用。
你实际上是在设计一个框架。
关于php - 如果 MySQL 函数用于自定义类,则 MySQL 确定是否在字符串周围加上单引号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18452217/
我正在使用 Selenium Web 驱动程序 3.0,并且想要从打开的两个对话框(一个在后台,第二个在前台)的 Activity 对话框中单击“确定”按钮。如何从 html 下面的父 div 单击前
actions: [ FlatButton( onPressed: () {
我有一个问题有点超出我的范围(我真的很高兴我是 Beta)涉及重复项(所以 GROUP BY, HAVING, COUNT),通过将解决方案保留在 SQLite 附带的标准函数中而变得更加复杂。我正在
使用DBI是否可以确定SELECT语句的已执行语句句柄是否返回任何行而不从中获取行? IE。就像是: use DBI; ... my $sth = $dbh->prepare("SELECT ..."
是否可以为“确定”和“关闭”按钮指定回调函数? 如果是JQuery Modal,则可以在初始化时使用按钮字典指定回调函数。 Semantic-ui模态是否提供类似的功能?按下确定后,我该如何寻求其他逻
我想阅读警报中的消息。 示例:如果警报显示“错误的电子邮件地址”。怎么读呢?意味着我想将该消息存储在字符串中。 如何在“警报”中单击“确定”...?? 如何使用 Selenium 来做到这一点? 最佳
我有一个删除按钮: 我试图首先查明是否已选择一个网站,如果已选择一个网站,我需要确定是否已选择一个或多个列表项,如果是,则继续删除这些项目。 我的 if 语句不断返回“您必须首先选择您的列表”,即使它
部分出于好奇——我们想知道在我们的应用程序中发生了什么——部分是因为我们需要在我们的代码中找到一些潜在的问题,我喜欢在我们的网络应用程序运行时跟踪一些一般值。这尤其包括某些对象图的分配内存。 我们的应
我将 SweetAlert 与 Symfony 结合使用,我希望用户在完成删除操作之前进行确认。 发生的情况是,当用户单击删除按钮时,SweetAlert 会弹出,然后立即消失,并且该项目被删除。 在
我们有一个应用程序可以生成不包括字母 O 的随机基数 35 [0-9A-Z]。我正在寻找一种解决方案来查找包含任何淫秽英语单词的代码,而无需搜索包含 10,000 个条目的列表每个生成的代码。每秒生成
这是我做的: #include #include int betweenArray(int a, int b){ int *arr,i,range; range = b - a +
我知道如何创建 警报和确认框,但我不知道如何做的是实际单击“确定”。我有一个弹出确认框的页面。 我想使用 Java Script 插件单击“确定”。基本上,我希望我的代码单击页面上的链接,然后在出现提
代码: swal('Your ORDER has been placed Successfully!!!'); window.location="index.php"; 甜蜜警报工
>>> import re >>> s = "These are the words in a sentence" >>> regex = re.compile('are|words') >>> [m
使用确定的理想散列函数给出随机期望线性时间算法两个数组 A[1..n] 和 B[1..n] 是否不相交,即 A 的元素是否也是 B 的元素。 谁能告诉我如何做到这一点,甚至如何开始考虑它? 最佳答案
我在计算机科学课上有这段代码: int input=15; while (input < n ) { input = input *3;} 这段代码有 log3(n/15) 次循环的上限。我们怎样才能
我有一个允许 2 位玩家玩 TicTacToe 的程序。在每个玩家移动之后,它应该在那个点显示棋盘并返回一个名为 Status 的枚举,显示玩家是否应该继续,如果玩家赢了,还是平局。但是,该算法要么返
给定一个 y 值数组,例如 [-3400, -1000, 500, 1200, 3790],我如何确定“好的”Y 轴标签并将它们放置在网格上? ^ ---(6,000)-|---
假设我有一个检查用户登录的 SQL 语句: SELECT * FROM users WHERE username='test@example.com', password='abc123', expi
teradata中有返回表中哪一列被定义为主索引的命令吗?我没有制作一些我正在处理的表,也没有尝试优化我对这些表的连接。谢谢! 最佳答案 有dbc.IndicesV,其中IndexNumber=1表示
我是一名优秀的程序员,十分优秀!