-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdelete.py
65 lines (47 loc) · 2.17 KB
/
delete.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import mysql.connector
from mysql.connector import Error
config = {
'user': 'root', # 替换为你的数据库用户名
'password': '1111', # 替换为你的数据库密码
'host': 'localhost', # 替换为你的数据库主机地址
'database': 'facereco' # 替换为你的数据库名称
}
def delete_employee_by_id(employee_id):
# 数据库连接配置
try:
connection = None
connection = mysql.connector.connect(**config)
# 建立数据库连接
if connection.is_connected():
cursor = connection.cursor()
# 检查员工ID是否存在于 staff 表中
check_staff_query = "SELECT COUNT(*) FROM staff WHERE id = %s"
cursor.execute(check_staff_query, (employee_id,))
(count,) = cursor.fetchone()
if count == 0:
print(f"员工ID {employee_id} 不存在,请重新输入.")
return
# 删除 FaceInfo 表中对应员工的数据
delete_faceinfo_query = "DELETE FROM FaceInfo WHERE id = %s"
cursor.execute(delete_faceinfo_query, (employee_id,))
# 删除 staff 表中对应员工的数据
delete_staff_query = "DELETE FROM staff WHERE id = %s"
cursor.execute(delete_staff_query, (employee_id,))
# 删除 record 表中对应员工的数据
delete_staff_record = "DELETE FROM record WHERE id = %s"
cursor.execute(delete_staff_record, (employee_id,))
# 提交事务
connection.commit()
print(f"ID为{employee_id}的员工数据已成功删除。")
except Error as e:
# 如果出现错误,则回滚事务
print(f"Error: {e}")
if connection and connection.is_connected():
connection.rollback()
finally:
if connection and connection.is_connected():
cursor.close()
connection.close()
print("MySQL connection is closed.")
# 使用函数删除某个员工的数据
#delete_employee_by_id(1) # 替换为实际的员工ID