本文整理匯總了PHP中SqlQuery::validateColumn方法的典型用法代碼示例。如果您正苦於以下問題:PHP SqlQuery::validateColumn方法的具體用法?PHP SqlQuery::validateColumn怎麽用?PHP SqlQuery::validateColumn使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類SqlQuery
的用法示例。
在下文中一共展示了SqlQuery::validateColumn方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: execute
public function execute()
{
if (isset($this->orderby)) {
$this->orderbySQL = sprintf('ORDER BY %s', $this->orderby);
}
if (isset($this->paging)) {
$this->limitSQL = sprintf('LIMIT %d,%d', $this->paging->offset, $this->paging->limit);
}
if (isset($this->where)) {
$this->whereSQL = sprintf('WHERE %s', $this->where);
}
if (isset($this->data)) {
$columns = [];
$bindings = [];
foreach ($this->data as $key => $value) {
$columns[] = SqlQuery::validateColumn($key) . ' = ?';
$bindings[] =& $value;
}
// prepend bindings because SET comes before WHERE
$this->bindings = array_merge($bindings, $this->bindings);
$this->setSQL = sprintf('SET %s', implode(',', $columns));
}
switch ($this->query_type) {
case 'update':
$sql = sprintf('UPDATE %s %s %s', $this->table_name, $this->setSQL, $this->whereSQL);
break;
case 'select':
default:
$sql = sprintf('SELECT * FROM %s %s %s %s', $this->table_name, $this->whereSQL, $this->orderbySQL, $this->limitSQL);
}
if (isset($this->paging) && !isset($this->paging->total_records)) {
$this->paging->total_records = SqlQuery::getRecordCount($this->db, $this->table_name, $this->whereSQL, $this->bindings, $this->types);
}
//dbg($sql);
//var_dump($this->bindings);
return SqlQuery::executeSQL($this->db, $sql, $this->bindings, $this->types);
}
示例2: save
public function save()
{
$result = false;
$id = $this->ival($this->id_name);
if (isset($id) && $id > 0) {
$columns = [];
$bindings = [];
$types = '';
foreach ($this->data as $key => $value) {
if ($key != $this->id_name) {
$columns[] = SqlQuery::validateColumn($key) . ' = ?';
$bindings[] =& $this->data[$key];
$types .= SqlQuery::getTypeChar($value);
}
}
$bindings[] =& $this->data[$this->id_name];
$types .= 'i';
array_unshift($bindings, $types);
$sql = sprintf('UPDATE %s SET %s WHERE %s = ?', $this->table_name, implode(',', $columns), $this->id_name);
if ($st = $this->db->prepare($sql)) {
call_user_func_array(array($st, 'bind_param'), $bindings);
if ($st->execute()) {
$result = true;
} else {
dbErr($this->table_name, 'execute', $sql, $this->db->error);
}
$st->close();
} else {
dbErr($this->table_name, 'prepare', $sql, $this->db->error);
}
} else {
$columns = [];
$values = [];
$bindings = [];
$types = '';
foreach ($this->data as $key => $value) {
if ($key != $this->id_name) {
$columns[] = SqlQuery::validateColumn($key);
$values[] = '?';
$bindings[] =& $this->data[$key];
$types .= SqlQuery::getTypeChar($value);
}
}
array_unshift($bindings, $types);
$sql = sprintf('INSERT INTO %s (%s) VALUES (%s)', $this->table_name, implode(',', $columns), implode(',', $values));
if ($st = $this->db->prepare($sql)) {
//echo $sql;
call_user_func_array(array($st, 'bind_param'), $bindings);
if ($st->execute()) {
$this->is_loaded = true;
$result = true;
$this->data[$this->id_name] = $this->db->insert_id;
} else {
dbErr($this->table_name, 'execute', $sql, $this->db->error);
}
$st->close();
} else {
dbErr($this->table_name, 'prepare', $sql, $this->db->error);
}
}
return $result;
}