# Copyright 2012 Citrix Systems, Inc. Licensed under the # Apache License, Version 2.0 (the "License"); you may not use this # file except in compliance with the License. Citrix Systems, Inc. # reserves all rights not expressly granted by the License. # You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # # Automatically generated by addcopyright.py at 04/03/2012 import pymysql import cloudstackException import sys import os import traceback class dbConnection(object): def __init__(self, host="localhost", port=3306, user='cloud', passwd='cloud', db='cloud'): self.host = host self.port = port self.user = user self.passwd = passwd self.database = db try: self.db = pymysql.Connect(host=host, port=port, user=user, passwd=passwd, db=db) except: traceback.print_exc() raise cloudstackException.InvalidParameterException(sys.exc_info()) def __copy__(self): return dbConnection(self.host, self.port, self.user, self.passwd, self.database) def close(self): try: self.db.close() except: pass def execute(self, sql=None): if sql is None: return None resultRow = [] cursor = None try: # commit to restart the transaction, else we don't get fresh data self.db.commit() cursor = self.db.cursor() cursor.execute(sql) result = cursor.fetchall() if result is not None: for r in result: resultRow.append(r) return resultRow except pymysql.MySQLError, e: raise cloudstackException.dbException("db Exception:%s"%e) except: raise cloudstackException.internalError(sys.exc_info()) finally: if cursor is not None: cursor.close() def executeSqlFromFile(self, fileName=None): if fileName is None: raise cloudstackException.InvalidParameterException("file can't not none") if not os.path.exists(fileName): raise cloudstackException.InvalidParameterException("%s not exists"%fileName) sqls = open(fileName, "r").read() return self.execute(sqls) if __name__ == "__main__": db = dbConnection() ''' try: result = db.executeSqlFromFile("/tmp/server-setup.sql") if result is not None: for r in result: print r[0], r[1] except cloudstackException.dbException, e: print e ''' print db.execute("update vm_template set name='fjkd' where id=200") for i in range(10): result = db.execute("select job_status, created, last_updated from async_job where id=%d"%i) print result