Netezza Dialect for SQLAlchemy
Project description
A Netezza Dialect(nzalchemy) for SQLAlchemy
Scope
nzalchemy runs on top of pyodbc(over nzodbc) or nzpy as a dialect to bridge Netezza Performance Server and SQLAlchemy applications.
Prerequisites for using nzalchemy with pyodbc
Install pyodbc Python package
Details of pyodbc pre-requisites and installation instruction can be found here: https://github.com/mkleehammer/pyodbc/wiki/Install
Install Netezza OBDC(nzodbc) drivers
You will not be able to use pyodbc driver without installing Netezza OBDC drivers. This step is one of the pre-requisites to use pyodbc.
Install and configure Netezza ODBC on Linux
IBM has provided Netezza ODBC driver that you can install into any Linux box. Go to IBM support center and download required version of ODBC driver.
Get latest nzodbc 64bit driver linux64cli.package.tar from (https://www.ibm.com/support/fixcentral/swg/selectFixes?product=ibm/WebSphere/IBM+Cloud+Private+for+Data+System&release=IPS_11.1&platform=All&function=fixId&fixids=11.1.0.0-WS-ICPDS-IPS-fp125793)
untar and unpack using below command :
$ tar -xvf ips-linuxclient-v<version>.tar.gz
$ ./unpack npsclient.<version>.tar.gz
Unpacking would create a lib64 directory under which there would be libnzodbc.so. Add above directory to LD_LIBRARY_PATH.
For further details read here: https://www.ibm.com/support/knowledgecenter/SSULQD_7.2.1/com.ibm.nz.datacon.doc/c_datacon_configuring_odbc_unix_linux.html
Install and configure Netezza ODBC on Windows
You can download the Netezza odbc drivers from IBM website and install it on required system.
Get latest nzodbc driver nzodbcsetup.exe from (https://www.ibm.com/support/fixcentral/swg/selectFixes?product=ibm/WebSphere/IBM+Cloud+Private+for+Data+System&release=IPS_11.1&platform=All&function=fixId&fixids=11.1.0.0-WS-ICPDS-IPS-fp125793)
The installation program installs the Netezza ODBC libraries on your system, creates a Netezza SQL system data source entry (NZSQL) with appropriate default values, and adds the appropriate entries to the Windows registry.
- In the ODBC Data Source Administrator window, click either the System DSN tab or the User DSN tab.
- Select either of the following options:
- To configure an existing DSN, click Configure. Clicking Configure displays the ODBC Driver Setup window.
- To configure a new DSN, click Add. Clicking Add displays the Create New Data Source window. Select NetezzaSQL as the driver and click Finish.
- In the ODBC Driver Setup window, configure the DSN and driver options. See ODBC Driver Setup window.
- Attempt to establish a connection to the data source on your Netezza appliance server by clicking the DSN Options tab and then clicking Test Connection.
For further details read here: https://www.ibm.com/support/knowledgecenter/SSULQD_7.2.1/com.ibm.nz.datacon.doc/c_datacon_installing_configuring_odbc_win.html
Prerequisites for using nzalchemy with nzpy
Install nzpy package
To install nzpy using pip type:
pip install nzpy
To install nzpy using setup.py:
python setup.py install
Installing Netezza SQLAlchemy
The Netezza SQLAlchemy package can be installed from the public PyPI repository using pip:
pip install nzalchemy
Connection Parameters
To connect to Netezza with SQLAlchemy using pyodbc use the following connection string:
netezza+pyodbc:///?<ODBC connection parameters>
For example:
import urllib
params= urllib.parse.quote_plus("DRIVER=<path-to-libnzodbc.so>;SERVER=<nz-running-server>;PORT=5480;DATABASE=<dbname>;UID=<usr>;PWD=<password>")
engine = create_engine("netezza+pyodbc:///?odbc_connect=%s" % params, echo=True)
To connect to Netezza with SQLAlchemy using nzpy use the following connection string:
netezza+nzpy://username:password@hostname:port/databasename
For example:
engine = create_engine("netezza+nzpy://admin:password@localhost:5480/db1")
In order to pass any nzpy connection arguments to nzalchemy use below:
import nzpy
def creator():
return nzpy.connect(user="admin", password="password",host='localhost', port=5480, database="db1", securityLevel=0,logOptions=nzpy.LogOptions.Logfile, char_varchar_encoding='utf8')
engine = create_engine("netezza+nzpy://", creator=creator)
Feature Support
SQLAlchemy ORM - Python object based automatically constructed SQL
SQLAlchemy Core - schema-centric SQL Expression Language
Auto-increment Behavior
Auto-incrementing a value requires the Sequence object. Include the Sequence object in the primary key column to automatically increment the value as each new record is inserted. For example:
t = Table('mytable', metadata,
Column('id', Integer, Sequence('id_seq'), primary_key=True),
Column(...), ...
Known Limitations
- INTERVAL data type Reading interval data at sqlalchemy will fail as pyodbc doesn’t support interval data type directly.
There will not be any issue for writing data. - Unicode varchar will fail
- TIME data type with time zone TIME WITH TIME ZONE data type might not work. TIMETZ which is separate data type (internally it will be time with time zone) that works fine.
If you have any questions or issues you can create a new issue here.
Pull requests are very welcome! Make sure your patches are well tested. Ideally create a topic branch for every separate change you make. For example:
- Fork the repo
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Added some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request
License & Authors
If you would like to see the detailed LICENSE click here.
Copyright:: 2019-2020 IBM, Inc
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with 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.
Quick Example
#!/usr/bin/env python3
from sqlalchemy import create_engine, MetaData, Table, Column, select
import nzalchemy as nz
import urllib
params= urllib.parse.quote_plus("DRIVER=<path-to-libnzodbc.so>;SERVER=<nz-running-server>;PORT=5480;DATABASE=<dbname>;UID=<usr>;PWD=<password>")
engine = create_engine("netezza+pyodbc:///?odbc_connect=%s" % params, echo=True)
#create engine using nzpy
#engine = create_engine("netezza+nzpy://<username>:<password>@<nz-running-server>:5480/<dbname>")
meta = MetaData()
test = Table(
'TEST', meta,
Column('id', nz.INTEGER),
Column('name', nz.VARCHAR(20) ),
Column('gender', nz.CHAR),
)
meta.create_all(engine)
#conn for insert and select
conn = engine.connect()
#Insert
conn.execute(test.insert(),[
{'id':2,'name':'xyz','gender':'F'},
{'id':3,'name':'abc','gender':'M'},
]
)
#Select
print ("After Insert")
s = select([test])
result = conn.execute(s)
for row in result:
print (row)
#Update
updt = test.update().where(test.c.id == '2').values(name='updated_name')
conn.execute(updt)
s = select([test])
result = conn.execute(s)
for row in result:
print (row)
#Delete Row/s
delt = test.delete().where(test.c.name == 'abc')
conn.execute(delt)
s = select([test])
result = conn.execute(s)
for row in result:
print (row)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file nzalchemy-11.0.2.tar.gz
.
File metadata
- Download URL: nzalchemy-11.0.2.tar.gz
- Upload date:
- Size: 27.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.50.0 CPython/3.6.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4e05a5a8df984d43b8d301f7b19fb4f4408bac9eb0421205adb1ab29827de50e |
|
MD5 | dafde3441c3edc76b36a41361f2a5d40 |
|
BLAKE2b-256 | 3dbaea2c315151966704a30bbac0f5a122f5aa0742ae73315b8412c5f24e38e3 |
File details
Details for the file nzalchemy-11.0.2-py3-none-any.whl
.
File metadata
- Download URL: nzalchemy-11.0.2-py3-none-any.whl
- Upload date:
- Size: 21.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.50.0 CPython/3.6.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b7a7909bdab2a511f46d205598ec2b7d09cea1042f2a04e8351048c7a2811348 |
|
MD5 | ebe7bd66aac305084e24b069f1a6b3f3 |
|
BLAKE2b-256 | 1f4ca1dea614ea559de2268606a97e291f912fbb65e352f5a5357e5aaef4c41c |