使用 codeigniter 将数据库中字段的值更新为 1

发布于 2024-09-11 01:34:59 字数 150 浏览 5 评论 0原文

我想使用 codeigniter 活动记录来实现 SQL 语句。

UPDATE tags SET usage = usage+1 WHERE tag="java";

如何使用 Codeigniter 活动记录来实现这一点?

I want to implement a SQL statement using codeigniter active record.

UPDATE tags SET usage = usage+1 WHERE tag="java";

How can I implement this using Codeigniter active records?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

忘你却要生生世世 2024-09-18 01:35:53

我发现有时只编写 SQL 比让 Active Record 为我构建它更简单。

$sql = 'update tags set usage=usage+1 where tag=?';
$this->db->query($sql, array($tag));

I find its sometimes simpler to just write the SQL rather than having Active Record build it for me.

$sql = 'update tags set usage=usage+1 where tag=?';
$this->db->query($sql, array($tag));
幼儿园老大 2024-09-18 01:35:47

您还可以使用类似

$data = array('usage' => 'usage+1', *other columns*);
$this->db->where('tag', 'java');
$this->db->update('tags', $data);

UPDATE: $data was not being pass on to update 的内容

You can also use something like this

$data = array('usage' => 'usage+1', *other columns*);
$this->db->where('tag', 'java');
$this->db->update('tags', $data);

UPDATE: $data was not being passed on to update

夏了南城 2024-09-18 01:35:41

来自文档

set() 还将接受可选的第三个参数 ($escape),如果设置为 FALSE,该参数将防止数据被转义.

因此,这应该可以将增量语句直接传递到数据库:

$this->db->set('usage', 'usage+1', FALSE);
$this->db->where('tag', 'java');
$this->db->update('tags');

因为它没有转义,所以如果您使用变量而不是固定数字,则应事先将其验证为数字。

From the documentation:

set() will also accept an optional third parameter ($escape), that will prevent data from being escaped if set to FALSE.

So this should work to pass the increment statement directly to the database:

$this->db->set('usage', 'usage+1', FALSE);
$this->db->where('tag', 'java');
$this->db->update('tags');

Because it's not escaped, if you're using a variable instead of a fixed number it should be verified as numeric beforehand.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文