1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
|
# Copyright 2002-2004 CherryPy Team (team@cherrypy.org)
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2, or (at your option)
# any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
# 02111-1307, USA.
#
# As a special exception, the CherryPy team gives unlimited permission to
# copy, distribute and modify the CherryPy scripts that are the
# output of CherryPy. You need not follow the terms of the GNU
# General Public License when using or distributing such scripts, even
# though portions of the text of CherryPy appear in them. The GNU
# General Public License (GPL) does govern all other use of the
# material that constitutes the CherryPy program.
#
# Certain portions of the CherryPy source text are designed to be
# copied (in certain cases, depending on the input) into the output of
# CherryPy. We call these the "data" portions. The rest of the
# CherryPY source text consists of comments plus executable code that
# decides which of the data portions to output in any given case. We
# call these comments and executable code the "non-data" portions.
# CherryPy never copies any of the non-data portions into its output.
#
# This special exception to the GPL applies to versions of CherryPy
# released by the CherryPy team. When you make and distribute a modified
# version of CherryPy, you may extend this special exception to the
# GPL to apply to your modified version as well, *unless* your
# modified version has the potential to copy into its output some of
# the text that was the non-data portion of the version that you
# started with. (In other words, unless your change moves or copies
# text from the non-data portions to the data portions.) If your
# modification has such potential, you must delete any notice of this
# special exception to the GPL from your modified version.
import DCOracle2
################
CherryClass DCOracleFull abstract:
################
variable:
auto_commit=0 # 0 = manually need to commit: 1 = commit executed on InsertSQL, UpdateSQL and DeleteSQL
function:
def DBConnect(self, DSN, ID, PSWD):
connect_string = '%s/%s@%s' % (ID, PSWD, DSN)
self.db = DCOracle2.connect(connect_string)
def ExecSQL(self, sql):
c = self.db.cursor()
c.execute(sql)
rs = c.fetchall()
c.close()
del c
return rs
def SVExecSQL(self, sql):
c = self.db.cursor()
c.execute(sql)
rs = c.fetchall()
c.close()
del c
return (rs[0][0])
def DeleteSQL(self, sql):
c = self.db.cursor()
c.execute(sql)
if self.auto_commit:
c.execute('commit')
c.close()
del c
def InsertSQL(self, sql):
c = self.db.cursor()
c.execute(sql)
if self.auto_commit:
c.execute('commit')
c.close()
del c
def UpdateSQL(self, sql):
c = self.db.cursor()
c.execute(sql)
if self.auto_commit:
c.execute('commit')
c.close()
del c
|