summaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
authorBharat Mediratta <bharat@menalto.com>2009-12-17 21:16:51 -0800
committerBharat Mediratta <bharat@menalto.com>2009-12-17 21:16:51 -0800
commit9d19e272d672ffc224dfed2799f8e480ecb583e4 (patch)
tree198ee5c3434b71341fb419f3399ad441a363b3ee /modules
parent8883d1605a12b94fb8f8b5a39ce5b4675b358302 (diff)
Convert some database queries.
Diffstat (limited to 'modules')
-rw-r--r--modules/gallery/helpers/gallery_event.php25
-rw-r--r--modules/gallery/helpers/module.php23
2 files changed, 30 insertions, 18 deletions
diff --git a/modules/gallery/helpers/gallery_event.php b/modules/gallery/helpers/gallery_event.php
index 37f39d15..301432d4 100644
--- a/modules/gallery/helpers/gallery_event.php
+++ b/modules/gallery/helpers/gallery_event.php
@@ -49,19 +49,18 @@ class gallery_event_Core {
static function identity_provider_changed($old_provider, $new_provider) {
$admin = identity::admin_user();
- $db = Database::instance();
- $db->from("tasks")
- ->set(array("owner_id" => $admin->id))
- ->where("1", "=", "1") // @todo why do we need this?
- ->update();
- $db->from("items")
- ->set(array("owner_id" => $admin->id))
- ->where("1", "=", "1") // @todo why do we need this?
- ->update();
- $db->from("logs")
- ->set(array("user_id" => $admin->id))
- ->where("1", "=", "1") // @todo why do we need this?
- ->update();
+ db::build()
+ ->update("tasks")
+ ->set("owner_id", $admin->id)
+ ->execute();
+ db::build()
+ ->update("items")
+ ->set("owner_id", $admin->id)
+ ->execute();
+ db::build()
+ ->update("logs")
+ ->set("user_id", $admin->id)
+ ->execute();
}
static function group_created($group) {
diff --git a/modules/gallery/helpers/module.php b/modules/gallery/helpers/module.php
index b8928f7b..71c4efa0 100644
--- a/modules/gallery/helpers/module.php
+++ b/modules/gallery/helpers/module.php
@@ -432,17 +432,30 @@ class module_Core {
/**
* Increment the value of a variable for this module
+ *
+ * Note: Frequently updating counters is very inefficient because it invalidates the cache value
+ * which has to be rebuilt every time we make a change.
+ *
+ * @todo Get rid of this and find an alternate approach for all callers (currently only Akismet)
+ *
+ * @deprecated
* @param string $module_name
* @param string $name
* @param string $increment (optional, default is 1)
*/
static function incr_var($module_name, $name, $increment=1) {
- Database::instance()->query(
- "UPDATE {vars} SET `value` = `value` + $increment " .
- "WHERE `module_name` = '$module_name' " .
- "AND `name` = '$name'");
+ db::build()
+ ->update("vars")
+ ->set("value", new Database_Expression("`value` + $increment"))
+ ->where("module_name", "=", $module_name)
+ ->where("name", "=", $name)
+ ->execute();
- Database::instance()->delete("vars", array("module_name" => "gallery", "name" => "_cache"));
+ db::build()
+ ->delete("vars")
+ ->where("module_name", "=", "gallery")
+ ->where("name", "=", "_cache")
+ ->execute();
self::$var_cache = null;
}