diff options
author | marvin-j97 <marvin.janke.97@gmail.com> | 2024-09-04 18:45:17 +0200 |
---|---|---|
committer | marvin-j97 <marvin.janke.97@gmail.com> | 2024-09-04 18:45:17 +0200 |
commit | 74363c906065a559beef4c3c93e8f73a7ecff437 (patch) | |
tree | de3683f54e5cebb27f3b17b01dce9f87c86aca63 /src/db/sqlite_adapter.rs | |
parent | 615698df7d2d3867fd3d9cbdf8d8849a9de358bf (diff) | |
download | garage-74363c906065a559beef4c3c93e8f73a7ecff437.tar.gz garage-74363c906065a559beef4c3c93e8f73a7ecff437.zip |
perf(kv): dont retrieve values for write ops
see https://git.deuxfleurs.fr/Deuxfleurs/garage/issues/851
Diffstat (limited to 'src/db/sqlite_adapter.rs')
-rw-r--r-- | src/db/sqlite_adapter.rs | 16 |
1 files changed, 6 insertions, 10 deletions
diff --git a/src/db/sqlite_adapter.rs b/src/db/sqlite_adapter.rs index a91b9011..eb106a31 100644 --- a/src/db/sqlite_adapter.rs +++ b/src/db/sqlite_adapter.rs @@ -169,7 +169,7 @@ impl IDb for SqliteDb { } } - fn insert(&self, tree: usize, key: &[u8], value: &[u8]) -> Result<Option<Value>> { + fn insert(&self, tree: usize, key: &[u8], value: &[u8]) -> Result<()> { let tree = self.get_tree(tree)?; let db = self.db.get()?; let lock = self.write_lock.lock(); @@ -184,23 +184,19 @@ impl IDb for SqliteDb { assert_eq!(n, 1); drop(lock); - Ok(old_val) + Ok(()) } - fn remove(&self, tree: usize, key: &[u8]) -> Result<Option<Value>> { + fn remove(&self, tree: usize, key: &[u8]) -> Result<()> { let tree = self.get_tree(tree)?; let db = self.db.get()?; let lock = self.write_lock.lock(); - let old_val = self.internal_get(&db, &tree, key)?; - - if old_val.is_some() { - let n = db.execute(&format!("DELETE FROM {} WHERE k = ?1", tree), params![key])?; - assert_eq!(n, 1); - } + let n = db.execute(&format!("DELETE FROM {} WHERE k = ?1", tree), params![key])?; + assert_eq!(n, 1); drop(lock); - Ok(old_val) + Ok(()) } fn clear(&self, tree: usize) -> Result<()> { |