diff options
author | marcus <marcus@36083f99-b078-4883-b0ff-0f9b5a30f544> | 2008-11-06 16:33:49 +0000 |
---|---|---|
committer | marcus <marcus@36083f99-b078-4883-b0ff-0f9b5a30f544> | 2008-11-06 16:33:49 +0000 |
commit | 40f717cad9b54511d6d4c0d549fd253409f8dd12 (patch) | |
tree | c8d23219a154aa1a6cb5ab28d01014285542d3aa /engine | |
parent | 3cb0559a580b2738c8aa7de601a495a169aa489e (diff) | |
download | elgg-40f717cad9b54511d6d4c0d549fd253409f8dd12.tar.gz elgg-40f717cad9b54511d6d4c0d549fd253409f8dd12.tar.bz2 |
datalists now has primary key, datalist set function optimised
git-svn-id: https://code.elgg.org/elgg/trunk@2417 36083f99-b078-4883-b0ff-0f9b5a30f544
Diffstat (limited to 'engine')
-rw-r--r-- | engine/lib/elgglib.php | 4 | ||||
-rw-r--r-- | engine/schema/mysql.sql | 2 | ||||
-rw-r--r-- | engine/schema/upgrades/2008110601.sql | 3 |
3 files changed, 6 insertions, 3 deletions
diff --git a/engine/lib/elgglib.php b/engine/lib/elgglib.php index 0ff9b2d26..836064060 100644 --- a/engine/lib/elgglib.php +++ b/engine/lib/elgglib.php @@ -1529,8 +1529,8 @@ $name = sanitise_string($name);
$value = sanitise_string($value); - delete_data("delete from {$CONFIG->dbprefix}datalists where name = '{$name}'");
- insert_data("insert into {$CONFIG->dbprefix}datalists set name = '{$name}', value = '{$value}'"); + //delete_data("delete from {$CONFIG->dbprefix}datalists where name = '{$name}'");
+ insert_data("INSERT into {$CONFIG->dbprefix}datalists set name = '{$name}', value = '{$value}' ON DUPLICATE KEY UPDATE value='{$value}'"); $DATALIST_CACHE[$name] = $value; diff --git a/engine/schema/mysql.sql b/engine/schema/mysql.sql index b906f9b5b..695a2e79f 100644 --- a/engine/schema/mysql.sql +++ b/engine/schema/mysql.sql @@ -288,7 +288,7 @@ CREATE TABLE `prefix_users_sessions` ( CREATE TABLE `prefix_datalists` (
`name` varchar(32) NOT NULL,
`value` text NOT NULL,
- KEY `name` (`name`)
+ PRIMARY KEY `name` (`name`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
-- System log
diff --git a/engine/schema/upgrades/2008110601.sql b/engine/schema/upgrades/2008110601.sql new file mode 100644 index 000000000..ddd80a91b --- /dev/null +++ b/engine/schema/upgrades/2008110601.sql @@ -0,0 +1,3 @@ +-- Alter datalists to have a primary key +ALTER TABLE `prefix_datalists` DROP KEY `name`; +ALTER TABLE `prefix_datalists` ADD PRIMARY KEY `name` (`name`); |