[egenix-users] Basic tsql example using MxODBC Zope DA adaptor?
Charlie Clark
charlie at egenix.com
Mon Jan 8 12:09:38 CET 2007
Am 04.01.2007, 17:52 Uhr, schrieb gilcneth at earthlink.net
<gilcneth at earthlink.net>:
> Hello Everyone,
> I am relatively new to Zope/Plone, as well as the MxODBC Zope DA
> adaptor. I am wondering if someone could point me to a basic example
> that would illustrate how to use the MxODBC Zope DA adaptor outside of a
> ZSQL method, using the Python API. I am using a script to build
> transact-sql statements, and it doesn't appear to be possible to pass
> t-sql into a ZSQL method.
> Any advice would be greatly appreciated.
You can use the mxODBC ZopeDA to pass in all kinds of SQL, ie. if you wish
to generate your SQL dynamically or to make use of bound parameters. This
is done using an ExternalMethod as detailed below. However, this will
still be within Zope's transacational management and is, thus, not
suitable if you wish to manage transactions yourself. If you wish to do
this then you should first of all read up on Zope's transactional
management to see how to use this. If you wish to use this for something
like a batch function then you are probably better of without using Zope
at all.
"""
ZSQL and ZopeDAs are severely limited and contain antiquated code.
This makes it particularly difficult to generate dynamic SQL as often
required. It also means that parameters get quoted by the DA which can
be messy. An alternative is to use ExternalMethods to call the
.execute() method of an mxODBCZopeDA and pass it statements
and parameters.
Create a file in ~/Extensions, say ODBC_SQL.py
This is essentially needs only one function:
from Shared.DC.ZRDB import Results
def callSQL(connObj, SQL="SELECT value FROM content"):
results = connObj.execute(SQL)
return Results.Results(results)
Create a Zope External Method say SQL which points to callSQL in
ODBC_SQL.
You can then call this method from any PythonScript and simply pass it
the connection and statement you want to execute.
In your case the PythonScript needs only to be modified slightly,
depending on what you want to.
statement = "select [Building ID] from [Buildings] "\
"where [Building Name] = ?"
results = context.SQL(mymxODBCZopeDA(), statement)
return results
The results returned are the same as would be returned by a ZSQL-method."""
Charlie
More information about the egenix-users
mailing list