| # 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/02/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: |
| 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[1]) |
| 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 |
| |