fix: Use update instead of insert
If insert will add a new data when the item exists. Fix for this commit: https://review.opendev.org/c/openstack/skyline-apiserver/+/920163 Change-Id: I9c1cf197c1eb611ae81f072c9b35898414a2431b
This commit is contained in:
parent
ce7d977df4
commit
d3c48c17f8
@ -16,9 +16,9 @@ from __future__ import annotations
|
|||||||
|
|
||||||
import time
|
import time
|
||||||
from functools import wraps
|
from functools import wraps
|
||||||
from typing import Any
|
from typing import Any, Union
|
||||||
|
|
||||||
from sqlalchemy import delete, func, insert, select
|
from sqlalchemy import Insert, Update, delete, func, insert, select, update
|
||||||
|
|
||||||
from skyline_apiserver.types import Fn
|
from skyline_apiserver.types import Fn
|
||||||
|
|
||||||
@ -102,12 +102,12 @@ async def update_setting(key: str, value: Any) -> Any:
|
|||||||
db = DB.get()
|
db = DB.get()
|
||||||
async with db.transaction():
|
async with db.transaction():
|
||||||
is_exist = await db.fetch_one(get_query)
|
is_exist = await db.fetch_one(get_query)
|
||||||
|
stmt: Union[Insert, Update]
|
||||||
if is_exist is None:
|
if is_exist is None:
|
||||||
query = insert(Settings)
|
stmt = insert(Settings).values(key=key, value=value)
|
||||||
await db.execute(query, {"key": key, "value": value})
|
|
||||||
else:
|
else:
|
||||||
query = insert(Settings).values(key=key, value=value)
|
stmt = update(Settings).where(Settings.c.key == key).values(value=value)
|
||||||
await db.execute(query, {"value": value})
|
await db.execute(stmt)
|
||||||
result = await db.fetch_one(get_query)
|
result = await db.fetch_one(get_query)
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
Loading…
Reference in New Issue
Block a user