我有很多重复的代码,可以从我的MySQL数据库中插入和选择数据。出于好奇,是否可以创建一个PHP函数,该函数可以将table
,columns
和rows
作为参数并生成SQL语句。一个完全动态的SQL语句生成器,如果你愿意的话。
例如:
function PushData($table, $columns, $values)
{
// insert data
}
此外,情况恰恰相反。一个可以选择和返回数据的函数。
function PullData($table, $columns, $rowID)
{
// grab data
return data;
}
这样的事情可能吗?如果是这样,这会值得吗?
答案 0 :(得分:2)
尝试类似的东西我不确定它会起作用。
function PushData($table, $columns, $values)
{
$question_mark = count($columns)-1;
$question_mark_array = array_fill(0, $question_mark, '?');
$valueEscapedTrimed = array();
foreach($values as $value)
{
$value=trim($value);
$valueEscapedTrimed[] = htmlentities($value, ENT_QUOTES | ENT_HTML5, $encoding = 'UTF-8' );
}
$query = 'INSERT INTO '.$table. '(' .implode(' ',$columns). ') VALUES ('.implode(',',$question_mark_array).') \' ' ;
foreach($valueEscapedTrimed as $value)
{
$stmt = $conn->prepare($query);
$stmt->bindValue('?', $value);
$stmt->execute();
$stmt->CloseCursor();
$stmt=null;
}
}
答案 1 :(得分:1)
万一有人像我一样好奇,我做了两个功能的实例。特别感谢迈克尔的回答让我朝着正确的方向前进。
插入数据功能
function PullData($conn, $table, $columns, $operand_column, $operand_value)
{
$columns = implode(',', $columns);
$sql = "SELECT {$columns} FROM {$table} WHERE {$operand_column} = {$operand_value}";
$result = mysqli_query($conn, $sql);
return $result;
}
选择数据功能
google.maps.event.trigger(map, 'resize');