从Python脚本将数据插入MySQL表

从Python脚本将数据插入MySQL表,python,mysql,Python,Mysql,我有一个名为TBLTEST的MySQL表,有两列ID和qSQL。每个qSQL中都有SQL查询 我还有一张桌子 表TBLTEST中有10行 例如,在TBLTEST上,让我们使用id=4和qSQL=“从ABC中选择id、city、state” 如何使用python从TBLTEST插入FACTRESTTBL,可能是使用dictionary 谢谢 您可以使用 示例代码(您需要调试它,因为我无法在此处运行它): 您想执行列qSQL中的查询,并将结果插入FACTRESTTBL?FACTRESTTBL的列是什

我有一个名为TBLTEST的MySQL表,有两列ID和qSQL。每个qSQL中都有SQL查询

我还有一张桌子

表TBLTEST中有10行

例如,在TBLTEST上,让我们使用id=4和qSQL=“从ABC中选择id、city、state”

如何使用python从TBLTEST插入FACTRESTTBL,可能是使用dictionary

谢谢

您可以使用

示例代码(您需要调试它,因为我无法在此处运行它):


您想执行列
qSQL
中的查询,并将结果插入
FACTRESTTBL
FACTRESTTBL
的列是什么?FACTRESTTBL中的列是id,cityThere也有,如果这对分发很重要的话,它是纯python的。给定的查询可以工作。由于TBLTEST及以上查询中有10行,所以如果我试图一次执行一个查询,则会运行该查询。我想执行多个查询,比如:cursor.execute(“从TBLTEST中选择qSQL,其中id位于(4,5,6)”),对于id=5,qSQL=“从DEF中选择id,城市,邮政编码”对于id=6,qSQL=“从ABC中选择id,城市,县”您会怎么做?谢谢
#!/usr/bin/python

import MySQLdb

# Open database connection
db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# prepare a cursor object using cursor() method
cursor = db.cursor()

# Select qSQL with id=4.
cursor.execute("SELECT qSQL FROM TBLTEST WHERE id = 4")

# Fetch a single row using fetchone() method.
results = cursor.fetchone()

qSQL = results[0]

cursor.execute(qSQL)

# Fetch all the rows in a list of lists.
qSQLresults = cursor.fetchall()
for row in qSQLresults:
    id = row[0]
    city = row[1]

    #SQL query to INSERT a record into the table FACTRESTTBL.
    cursor.execute('''INSERT into FACTRESTTBL (id, city)
                  values (%s, %s)''',
                  (id, city))

    # Commit your changes in the database
    db.commit()

# disconnect from server
db.close()