5

データベースの特定のフィールドで1ずつインクリメントしようとすると、問題が発生しました。アクティブなレコードがある場合とない場合で試しました。

私の関数は次のようになります(私のモデルでは)

function _set_reads($id){
$this->db->set('reads', 'reads+1', FALSE)
$this->db->where('id', $id);
$this->db->update('article');
}

function _set_reads($id){
$sql = 'update article set reads=reads+1 where id=?';
$this->db->query($sql, array($id));
}

どちらの場合も同じエラーが発生し、次のエラーメッセージが表示されます。

Error Number: 1064

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'reads+1 WHERE `id` = '15'' at line 1

UPDATE `article` SET `reads` = reads+1 WHERE `id` = '15'

最新バージョンのMAMPを使用しています

4

3 に答える 3

13

-- 小さな修正が必要

$this->db->where('id', $id);
$this->db->set('set_row', '`set_row`+ 1', FALSE);

ありがとうございました

于 2013-11-25T00:40:19.860 に答える
7

解決しました:変更する必要がありました

$this->db->set('reads', 'reads+1', FALSE)

$this->db->set('reads', '`reads+1`', FALSE)

投稿失礼します…

于 2012-10-15T23:06:54.833 に答える
3

set()はオプションの 3 番目のパラメーターも受け入れます($escape)これは、に設定されている場合にデータがエスケープされるのを防ぎますFALSE

于 2012-10-15T23:09:49.780 に答える