Access sql with python, please. I'm desperate

dd dijk at dijk.nldef
Thu Nov 13 16:00:23 EST 2003


Thank you very much. It really helped. By the way, can one do the
following?
 
select * from [a-query] where .......
 
So, select from a query instead of a table...
 
Thanks anyway you guys, for answering the previous question.


Arjen




> DD wrote:
> 
>> Hello,
>> But I cannot even connect to the access database (see below).
>> Could anyone explain it to me as simple as possible please. I'm using
>> Windows XP, ActivePython 2.3.2 build 230 and Microsoft access(XP?)
> OK, as several others have said, one solution (and the one I know)
> is via ODBC.  I use Win2K, not XP; there will be slight differences.
> 
> First, we create and ODBC (Open Data Base Connection) DSN (Data Source Name)
> I use (forgive the notation; I don't know a generally accepted one):
>      <Start>
>        <Settings>
>          <Control Panel>
>             <Administrative Tools>
>               <Data Sources (ODBC)>
> Gives a tabbed window labeled "ODBC Data Source Administrator".
> Choose tab "User DSN" (or "System DSN") and press the "Add..." button.
> It asks you to:
>     "Select a driver for which you want to set up a data source."
> 
> If you cannot find the menus I discuss above, explore using:
>      <Start>
>        <Help>
> Got to tab "Search" and type "ODBC" without the quotes.  Check out
> the various subjects that follow.
> Choose some version of "Microsoft Access Driver (*.mdb)" -- my
> machine offers the choice in a couple of human languages; I
> inevitably go for English (my native language), but your
> performance my vary.
> Having chose the correct driver, I click "Finish"
> This takes me to a dialog "ODBC Microsoft Access Setup"
> That wants a Data Source Name (name by which I will later refer
> to the DB) and a Description.  I always choose a simple DSN
> such as "Exploratory" and skip the Description, but I am on a home
> machine.  Remember the DSN namespace is "flat" -- no directories;
> all the names you use must be distinct.  So for my example we use
> "Exploratory" for the DSN and "None of your business" for the
> description.  In the "Database" box, I click "Select...", which
> will make a file chooser appear.  I then navigate to my access
> database's file (c:\imports\dbxx.mdb in this case) and click OK.
> Under the options section, I'm clicking "Read Only", but I'm paranoid.
> I now click OK here and again at the "ODBC Data Source Administrator"
> window, and this dialog session is at an end.
> 
>  From your attempts, I see you have loaded the win32 extensions, so
> the following should work work for you as well (changing names as
> appropriate -- I have a table named category):
> 
>      import odbc
>      conn = odbc.odbc("Exploratory")
>      cursor = conn.cursor()
>      cursor.execute("SELECT COUNT(*) FROM category")
>      print "lines in category = %s" % cursor.fetchone()
>      cursor.close()
>      conn.close()
> 
> If you get this far you are in business.  You can use idle (or your
> other favorite python interactive environment) to explore the results
> you get.  Know the difference between fetchone, fetchall and fetchmany,
> understand setautocommit, and have fun.
> 
> I personally used mxODBC
> 	http://www.lemburg.com/files/python/mxODBC.html
> 
> to do a lot of Database work at one job; Lemburg dots 'i's and
> crosses 't's to give you a great exploratory database environment.
> You get column names for all row returned and so on.  The odbc
> package that came with win32 does the bare bones.  The difference
> is well worth the price in time you save, in deployed systems
> (especially those given away) you may have to give up the features
> Marc-Andre provides.
> 
> -Scott David Daniels
> Scott.Daniels at Acm.Org





More information about the Python-list mailing list