cursor
obiekt używa connection
obiekt.
Kiedy Twój get_user_by_username
funkcja kończy wykonywanie,
połączenie z mysql zostaje zamknięte, dlatego cursor
nie może również istnieć.
Jeśli funkcja zwraca zarówno połączenie, jak i kursor, zadziała.
import mysql.connector
def get_user_by_username(username):
mydb = mysql.connector.connect(
host="localhost",
user=username,
passwd="k3gc8pHPvEtGqND",
database="test"
)
mycursor = mydb.cursor()
mycursor.execute("SELECT * FROM users")
return mydb, mycursor
mydb, mycursor = get_user_by_username("testuser")
for x in mycursor:
print(x)