feat/db-init #3
@@ -0,0 +1,3 @@
|
||||
from .connection import get_connection, get_db_config
|
||||
|
||||
|
|
||||
__all__ = ['get_connection', 'get_db_config']
|
||||
@@ -0,0 +1,54 @@
|
||||
# database/connection.py
|
||||
import psycopg2
|
||||
import os
|
||||
from contextlib import contextmanager
|
||||
from typing import Generator
|
||||
|
||||
from utils.loadDotEnv import initializeENV
|
||||
|
||||
initializeENV()
|
||||
|
||||
|
||||
def get_db_config() -> dict:
|
||||
|
BlackCorbeau
commented
Добавь подключение по ссылке вместо этого Добавь подключение по ссылке вместо этого
Nitro
commented
Зачем Зачем
Sweetbread
commented
@Nitro, как раз наоборот: зачем отдельно вводить кучу переменных? Ссылка стандартизирована и удобнее @Nitro, как раз наоборот: зачем отдельно вводить кучу переменных? Ссылка стандартизирована и удобнее
|
||||
return {
|
||||
'host': os.getenv('DB_HOST', 'localhost'),
|
||||
'port': int(os.getenv('DB_PORT', 5432)),
|
||||
'database': os.getenv('DB_NAME', 'warehouse_db'),
|
||||
'user': os.getenv('DB_USER', 'postgres'),
|
||||
'password': os.getenv('DB_PASSWORD', '')
|
||||
}
|
||||
|
||||
|
||||
@contextmanager
|
||||
def get_connection() -> Generator[psycopg2.extensions.connection, None, None]:
|
||||
conn = None
|
||||
try:
|
||||
config = get_db_config()
|
||||
conn = psycopg2.connect(**config)
|
||||
print("Подключение к БД установлено")
|
||||
|
BlackCorbeau
commented
Поменяй на логи Поменяй на логи
|
||||
yield conn
|
||||
except psycopg2.OperationalError as e:
|
||||
print(f"Ошибка подключения к БД: {e}")
|
||||
|
BlackCorbeau
commented
Поменяй на логи Поменяй на логи
|
||||
raise
|
||||
except Exception as e:
|
||||
print(f"Неожиданная ошибка: {e}")
|
||||
|
BlackCorbeau
commented
Поменяй на логи Поменяй на логи
Sweetbread
commented
А в чём смысл обрабатывать ошибку, которая всё равно уронит процесс? Если она неожиданная, то и обрабатывать не надо А в чём смысл обрабатывать ошибку, которая всё равно уронит процесс? Если она неожиданная, то и обрабатывать не надо
|
||||
if conn:
|
||||
conn.rollback()
|
||||
raise
|
||||
|
Sweetbread
commented
Зачем? Зачем?
|
||||
finally:
|
||||
if conn:
|
||||
conn.close()
|
||||
print("БД закрыта")
|
||||
|
BlackCorbeau
commented
Поменяй на логи Поменяй на логи
|
||||
|
||||
|
||||
def test_connection() -> bool:
|
||||
try:
|
||||
with get_connection() as conn:
|
||||
with conn.cursor() as cur:
|
||||
cur.execute("SELECT version();")
|
||||
version = cur.fetchone()
|
||||
print(f" Версия PostgreSQL: {version[0]}")
|
||||
|
BlackCorbeau
commented
Поменяй на логи Поменяй на логи
|
||||
return True
|
||||
except Exception as e:
|
||||
print(f"Тест подключения бд провален: {e}")
|
||||
|
BlackCorbeau
commented
Поменяй на логи Поменяй на логи
|
||||
return False
|
||||
Reference in New Issue
Block a user
Файл не нужен