Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Ausführen verschiedener Abfragen mit mysql-python

Ich denke, das ist es, wonach Sie suchen.

def connect_and_get_data(query, data):
    ...
    cursor.execute(query, data)
    ...

def get_data_about_first_amazing_topic(useful_string):
    query = "SELECT ... FROM ... WHERE ... AND some_field=%s"
    connect_and_get_data(query, ("one","two","three"))
    ...

Wenn Sie jedoch schnell mehrere Abfragen durchführen, ist es besser, Ihre Verbindung wiederzuverwenden, da zu viele Verbindungen Zeit verschwenden können.

...
CONNECTION = MySQLdb.connect(host=..., port=...,
                             user=..., passwd=..., db=...,
                             cursorclass=MySQLdb.cursors.DictCursor,
                             charset = "utf8")
cursor = CONNECTION.cursor()
cursor.execute("SELECT ... FROM ... WHERE ... AND some_field=%s", ("first", "amazing", "topic"))
first_result = cursor.fetchall()

cursor.execute("SELECT ... FROM ... WHERE ... AND some_field=%s", (("first", "amazing", "topic")))
second_result = cursor.fetchall()

cursor.close()
...

Dadurch wird Ihr Code viel leistungsfähiger.