GBase 8s数据库连接 – Python

简介: GBase 8s数据库连接 – Python

gbase 数据,操作系统:RHEL 6 64bit 软件需求: GBase 8s CSDK Python 2.6 及Python-devel 2.6 unixODBC pyodbc-4.0.25

系统环境确认 1.1 python、python-devel及unixODBC版本 Linux下root用户通过rpm确认python、python-devel,unixODBC、unixODBC-devel均已经安装,如

[root@localhost ~]# rpm -qa python python-devel unixODBC unixODBC-devel
unixODBC-devel-2.2.14-14.el6.x86_64
python-2.6.6-66.el6_8.x86_64
unixODBC-2.2.14-14.el6.x86_64
python-devel-2.6.6-66.el6_8.x86_64
GBase 8s CSDK已经安装 Linux下gbasedbt用户通过esql -V命令确认GBase 8s CSDK已经安装,如下:

[gbasedbt@localhost ~]$ esql -V
GBase CSDK Version 4.10, GBASE-ESQL Version 4.10.FC4G1_2.0.1A2_2
Software Serial Number AAA#B000000
ODBC配置 2.1 ODBC配置文件 修改/etc/odbc.ini配置文件,增加GBase 8s数据库连接信息

;---------------------------------------------------------------------------
; GBase ODBC Sample File
;
; File: odbc.ini
;
;---------------------------------------------------------------------------
[ODBC Data Sources]
utf8=GBase ODBC DRIVER
;
; Define ODBC Database Driver's Below - Driver Configuration Section
;
[utf8]
Driver=/opt/gbase8s/lib/cli/iclis09b.so
Description=GBase ODBC DRIVER
Database=utf8
LogonID=gbasedbt
pwd=GBase123
Servername=gbasedbt
CursorBehavior=0
CLIENT_LOCALE=zh_CN.utf8
DB_LOCALE=zh_CN.utf8
TRANSLATIONDLL=/opt/gbase8s/lib/esql/igo4a304.so
;
; UNICODE connection Section
;
[ODBC]
;uncomment the below line for UNICODE connection
;UNICODE=UCS-4
;
; Trace file Section
;
Trace=0
TraceFile=/tmp/odbctrace.out
InstallDir=/opt/gbase8s
TRACEDLL=idmrs09a.so
验证ODBC配置 加载GBase 8s CSDK环境变量,包含连接到GBase 8s数据库所需的GBASEDBTDIR、LD_LIBRARY_PATH,以及选用的字符集DB_LOCALE、CLIENT_LOCALE、LANG等。加载ODBCINI环境变量。环境变量内容可保存为配置文件,如:gbase8s_odbc_env,以供调用。

export GBASEDBTDIR=/opt/gbase8s # GBase 8s CSDK安装目录# 数据库使用的字符集export DB_LOCALE=zh_CN.utf8
export CLIENT_LOCALE=zh_CN.utf8

export LD_LIBRARY_PATH=$GBASEDBTDIR/lib:$GBASEDBTDIR/lib/esql:$LD_LIBRARY_PATH# ODBCINIexport ODBCINI=/etc/odbc.ini
通过isql命令检查ODBC配置
{spa.sleepinfestival.com]
{spa.longre-hz.com]
{spa.hqjinrong.com]
{spa.goingshop.net]
{spa.wzfresh.com]

[root@localhost ~]# . gbase8s_odbc_env
[root@localhost ~]# isql -v utf8
+---------------------------------------+
| Connected! |
| |
| sql-statement |
| help [tablename] |
| quit |
| |
+---------------------------------------+SQL> select dbservername::varchar(40) from systables where tabid = 1;+-----------------------------------------+
| |
+-----------------------------------------+
| gbasedbt |
+-----------------------------------------+
SQLRowCount returns -1
1 rows fetched
编译安装pyodbc 将pyodbc-4.0.25.tar.gz上传至GBase 8s CSDK所在的服务器上,使用root用户解压。

[root@localhost pyodbc]# tar -zxvf pyodbc-4.0.25.tar.gz
在生成的pyodbc-4.0.25目录里执行python setup.py install

[root@localhost pyodbc-4.0.25]# python setup.py install
内容如下:

running install
running bdist_egg
running egg_info
writing pyodbc.egg-info/PKG-INFO
writing top-level names to pyodbc.egg-info/top_level.txt
writing dependency_links to pyodbc.egg-info/dependency_links.txt
reading manifest file 'pyodbc.egg-info/SOURCES.txt'
reading manifest template 'MANIFEST.in'
writing manifest file 'pyodbc.egg-info/SOURCES.txt'
installing library code to build/bdist.linux-x86_64/egg
running install_lib
running build_ext
creating build/bdist.linux-x86_64/egg
copying build/lib.linux-x86_64-2.6/pyodbc.so -> build/bdist.linux-x86_64/egg
creating stub loader for pyodbc.so
byte-compiling build/bdist.linux-x86_64/egg/pyodbc.py to pyodbc.pyc
creating build/bdist.linux-x86_64/egg/EGG-INFO
copying pyodbc.egg-info/PKG-INFO -> build/bdist.linux-x86_64/egg/EGG-INFO
copying pyodbc.egg-info/SOURCES.txt -> build/bdist.linux-x86_64/egg/EGG-INFO
copying pyodbc.egg-info/dependency_links.txt -> build/bdist.linux-x86_64/egg/EGG-INFO
copying pyodbc.egg-info/top_level.txt -> build/bdist.linux-x86_64/egg/EGG-INFO
writing build/bdist.linux-x86_64/egg/EGG-INFO/native_libs.txt
zip_safe flag not set; analyzing archive contents...
creating 'dist/pyodbc-4.0.25-py2.6-linux-x86_64.egg' and adding 'build/bdist.linux-x86_64/egg' to it
removing 'build/bdist.linux-x86_64/egg' (and everything under it)
Processing pyodbc-4.0.25-py2.6-linux-x86_64.egg
creating /usr/lib64/python2.6/site-packages/pyodbc-4.0.25-py2.6-linux-x86_64.egg
Extracting pyodbc-4.0.25-py2.6-linux-x86_64.egg to /usr/lib64/python2.6/site-packages
Adding pyodbc 4.0.25 to easy-install.pth file

Installed /usr/lib64/python2.6/site-packages/pyodbc-4.0.25-py2.6-linux-x86_64.egg
Processing dependencies for pyodbc==4.0.25
Finished processing dependencies for pyodbc==4.0.25
完成后在/usr/lib64/python2.6/site-packages/目录下,将生成以下4个文件:

[root@localhost site-packages]# ls odbc
EGG-INFO pyodbc.py pyodbc.pyc pyodbc.so
Python通过ODBC连接GBase 8s数据库测试 编写测试脚本程序test_odbc.py,内容如下:

!/usr/bin/python# coding:utf-8import sys

import pyodbc

reload(sys)
sys.setdefaultencoding('utf-8')
conn = pyodbc.connect("DSN=utf8")

mycursor = conn.cursor()
mycursor.execute('drop table if exists tpyodbc;')

mycursor.execute('create table tpyodbc(id serial, name varchar(60), sex char(3));')

mycursor.execute("insert into tpyodbc(name,sex) values('张三','男')")
mycursor.execute('insert into tpyodbc(name,sex) values("韩美美","女")')
conn.commit()

cursor1 = conn.cursor()
cursor1.execute('select id,name,sex from tpyodbc')
rows = cursor1.fetchall();
{spa.tywanglawgroup.com]
{spa.7per.com]
{spa.82668365.com]
{spa.an-tantei.com]
{spa.maiip8.com]

for i,(id,name,sex) in enumerate(rows):
print "ID: %d \t姓名:%s\t性别: %s" % (id, str(name), str(sex))

conn.close()
sys.exit(0);
python test_odbc.py执行并输出结果:

[root@localhost pyodbc-4.0.25]# python test_odbc.py
ID: 1 姓名: 张三 性别: 男
ID: 2 姓名: 韩美美 性别: 女

相关文章
|
4月前
|
关系型数据库 数据库连接 数据库
Python执行PG数据库查询语句:以Markdown格式打印查询结果
使用Python的`psycopg2`和`pandas`库与PostgreSQL交互,执行查询并以Markdown格式打印结果。首先确保安装所需库:`pip install psycopg2 pandas`。接着建立数据库连接,执行查询,将查询结果转换为DataFrame,再用`tabulate`库将DataFrame格式化为Markdown。代码示例包括连接函数、查询函数、转换和打印函数。最后限制列宽以适应输出。
|
5天前
|
存储 关系型数据库 数据库
轻量级数据库的利器:Python 及其内置 SQLite 简介
轻量级数据库的利器:Python 及其内置 SQLite 简介
13 3
|
5月前
|
SQL 关系型数据库 数据库连接
使用 Python 访问数据库的基本方法
【5月更文挑战第12天】在Python中操作数据库涉及安装数据库驱动(如mysql-connector-python, psycopg2, pymongo)、连接数据库、执行查询/更新、处理结果集及关闭连接。使用ORM(如SQLAlchemy)可简化操作。通过上下文管理器(with语句)能更好地管理资源和错误。注意根据实际需求处理事务、错误和安全性,例如使用SSL连接。
60 2
|
23天前
|
JSON NoSQL 数据库
和SQLite数据库对应的NoSQL数据库:TinyDB的详细使用(python3经典编程案例)
该文章详细介绍了TinyDB这一轻量级NoSQL数据库的使用方法,包括如何在Python3环境中安装、创建数据库、插入数据、查询、更新以及删除记录等操作,并提供了多个编程案例。
47 0
|
5月前
|
存储 NoSQL MongoDB
MongoDB数据库转换为表格文件的Python实现
MongoDB数据库转换为表格文件的Python实现
203 0
|
2月前
|
Oracle 关系型数据库 数据库
Oracle数据库备份脚本分享-Python
Oracle数据库备份脚本分享-Python
31 0
|
4月前
|
SQL 关系型数据库 数据库
Python执行PostgreSQL数据库查询语句,并打印查询结果
本文介绍了如何使用Python连接和查询PostgreSQL数据库。首先,确保安装了`psycopg2`库,然后创建数据库连接函数。接着,展示如何编写SQL查询并执行,例如从`employees`表中选取所有记录。此外,还讨论了处理查询结果、格式化输出和异常处理的方法。最后,提到了参数化查询和事务处理以增强安全性及确保数据一致性。
Python执行PostgreSQL数据库查询语句,并打印查询结果
|
4月前
|
SQL 关系型数据库 数据库连接
Python连接线上数据库的实战指南
Python连接线上数据库的实战指南
206 1
|
4月前
|
SQL 关系型数据库 MySQL
Python 操作 MySQL 数据库
Python 操作 MySQL 数据库
|
4月前
|
SQL 安全 API
Python基础教程(第3版)中文版 第13章 数据库支持(笔记)
Python基础教程(第3版)中文版 第13章 数据库支持(笔记)