工具函数同步
This commit is contained in:
78
backend/util/currency.py
Normal file
78
backend/util/currency.py
Normal file
@@ -0,0 +1,78 @@
|
|||||||
|
from uuid import uuid4
|
||||||
|
from datetime import datetime
|
||||||
|
|
||||||
|
from django.db import connection
|
||||||
|
from django.db.models import Model
|
||||||
|
from django.core.cache import cache
|
||||||
|
|
||||||
|
|
||||||
|
def create_code(model,prefix):
|
||||||
|
current_date = datetime.now().strftime('%Y%m%d%H%M%S')
|
||||||
|
code = f"{prefix}{current_date}" + str(uuid4().int)[:6]
|
||||||
|
return code
|
||||||
|
|
||||||
|
def lock(key):
|
||||||
|
if callable(key): # @lock
|
||||||
|
def inner(*args, **kwargs):
|
||||||
|
with cache.lock(key='lock'):
|
||||||
|
return key(*args, **kwargs)
|
||||||
|
inner.__name__ = key.__name__
|
||||||
|
else: # @lock(key='aaa')
|
||||||
|
def inner(func):
|
||||||
|
def _inner(*args, **kwargs):
|
||||||
|
with cache.lock(key=key):
|
||||||
|
return func(*args, **kwargs)
|
||||||
|
_inner.__name__ = func.__name__
|
||||||
|
return _inner
|
||||||
|
return inner
|
||||||
|
|
||||||
|
def recursion_down_fast(instance:Model, parent='parent', key='id') -> list[int]:
|
||||||
|
"""向下递归instance的所有子级,且返回一维列表,使用sql优化,速度非常快"""
|
||||||
|
if not instance:
|
||||||
|
return []
|
||||||
|
sql = f"""
|
||||||
|
WITH RECURSIVE children AS (
|
||||||
|
SELECT id, {key} AS param_{key} FROM {instance.__class__._meta.db_table} WHERE {parent}_id = %s UNION ALL
|
||||||
|
SELECT a.id, a.{key} AS param_{key} FROM {instance.__class__._meta.db_table} a
|
||||||
|
INNER JOIN children b ON a.{parent}_id = b.id
|
||||||
|
) SELECT param_{key} FROM children;
|
||||||
|
"""
|
||||||
|
with connection.cursor() as cursor:
|
||||||
|
cursor.execute(sql, [getattr(instance, key)])
|
||||||
|
data = cursor.fetchall()
|
||||||
|
return [getattr(instance, key), *[i[0] for i in data]]
|
||||||
|
|
||||||
|
def recursion_up_fast(instance: Model, parent='parent', key='id') -> list[int]:
|
||||||
|
"""向上递归instance的所有父级,使用sql优化,速度非常快"""
|
||||||
|
if not instance:
|
||||||
|
return []
|
||||||
|
sql = f"""
|
||||||
|
WITH RECURSIVE parents AS (
|
||||||
|
SELECT id, {key} as param_{key}, {parent}_id FROM {instance.__class__._meta.db_table} WHERE id = %s UNION ALL
|
||||||
|
SELECT a.id, a.{key} as param_{key}, a.{parent}_id FROM {instance.__class__._meta.db_table} a
|
||||||
|
INNER JOIN parents b ON a.id = b.{parent}_id
|
||||||
|
) SELECT param_{key} FROM parents;
|
||||||
|
"""
|
||||||
|
with connection.cursor() as cursor:
|
||||||
|
cursor.execute(sql, [getattr(instance, key)])
|
||||||
|
data = cursor.fetchall()
|
||||||
|
return [getattr(instance, key), *[i[0] for i in data]]
|
||||||
|
|
||||||
|
def recursion_up_joint(instance: Model, parent='parent', key='name', joint='/') -> str:
|
||||||
|
"""向上递归instance所有父级并拼接需要的值,返回完整路径,使用sql优化,速度非常快"""
|
||||||
|
if instance is None:
|
||||||
|
return ''
|
||||||
|
sql = f"""
|
||||||
|
WITH RECURSIVE parents AS (
|
||||||
|
SELECT id, {parent}_id, {key}::TEXT AS path FROM {instance.__class__._meta.db_table} WHERE {key} = %s AND id = %s UNION ALL
|
||||||
|
SELECT a.id, a.{parent}_id, (a.{key} || '{joint}' || b.path)::TEXT FROM {instance.__class__._meta.db_table} a
|
||||||
|
INNER JOIN parents b ON a.id = b.{parent}_id
|
||||||
|
) SELECT path FROM parents where {parent}_id IS NULL;
|
||||||
|
"""
|
||||||
|
with connection.cursor() as cursor:
|
||||||
|
cursor.execute(sql, [getattr(instance, key), instance.pk])
|
||||||
|
data = cursor.fetchall()
|
||||||
|
try:
|
||||||
|
return data[0][0]
|
||||||
|
except IndexError:
|
||||||
|
raise Exception('找不到初始数据')
|
||||||
Reference in New Issue
Block a user