I’m using this function :
x
def checker(name,s)
MY_T = "SELECT count(*) FROM `"+session.SessionInfo.Name where EventName='"+name+"'"
I want to check if the table exists, how can I do it ?
I saw some examples using : XXXX.execute()
what does it mean?
Here is what I saw :
query = cursor.execute("""SELECT count(*) FROM scan WHERE prefix = %s and code_id = %s and answer = %s and station_id = %s""",
(prefix, code_id, answer, station,))
if query != 1:
I tried printing MY_T to see if it returns -1 for example but it just prints "select count (*)...... "
How can I check it? Any help would be very appreciated.
Advertisement
Answer
Use the “TABLES” information schema view. http://dev.mysql.com/doc/refman/5.0/en/information-schema.html
SELECT * FROM information_schema.tables
WHERE table_name = 'YOUR TABLE'
You can apply this view to your code by doing something like the following:
def checkTableExists(dbcon, tablename):
dbcur = dbcon.cursor()
dbcur.execute("""
SELECT COUNT(*)
FROM information_schema.tables
WHERE table_name = '{0}'
""".format(tablename.replace(''', '''')))
if dbcur.fetchone()[0] == 1:
dbcur.close()
return True
dbcur.close()
return False