簡體   English   中英

Python mysql使用變量名稱創建並命名新表

[英]Python mysql create and name new table using variable name

因此,我有一個名為“ racenumber”的變量,希望用作創建的新表的名稱。

以下python代碼目前無法正常工作。 關於問題所在的任何想法?

racenumber = 10

cursor = db.cursor()
cursor.execute("""CREATE TABLE %s (ID INT PRIMARY KEY AUTO_INCREMENT, NAME VARCHAR(50) DEFAULT NULL,    
PRIZE_TOTAL VARCHAR(50) DEFAULT NULL, STRENGTH VARCHAR(50) DEFAULT NULL, URL VARCHAR(50) DEFAULT  
NULL ) ENGINE=MyISAM DEFAULT CHARSET=latin1""" % (racenumber))

db.commit()
db.close()

由於您在表名中使用數字,因此需要在表名周圍使用反引號。 我在這里使用SQL Fiddle測試了一個示例: http ://sqlfiddle.com/#!2 / c38e57

racenumber = 10

cursor = db.cursor()
cursor.execute("""CREATE TABLE `%s` (ID INT PRIMARY KEY AUTO_INCREMENT, NAME VARCHAR(50) DEFAULT NULL,    
PRIZE_TOTAL VARCHAR(50) DEFAULT NULL, STRENGTH VARCHAR(50) DEFAULT NULL, URL VARCHAR(50) DEFAULT  
NULL ) ENGINE=MyISAM DEFAULT CHARSET=latin1""" % (racenumber))

db.commit()
db.close()

這是文檔中的鏈接: http : //dev.mysql.com/doc/refman/5.0/en/identifiers.html

具體來說這行:

標識符可以以數字開頭,但除非加引號,否則不能僅由數字組成

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM