环境:

Python版本:3.6.6

win系统:64位

Linux系统:64位

首先安装配置时,版本必须一致!包括:系统版本,python版本,oracle客户端的版本,cx_Oracle的版本!

需要的安装包:

Oracle Instant Client 客户端下载

https://www.oracle.com/cn/database/technologies/instant-client/downloads.html

instantclient-basic-windows.x64-11.2.0.4.0.zip

cx_Oracle 下载

https://pypi.python.org/pypi/cx_Oracle/6.0rc1

https://sourceforge.net/projects/cx-oracle/files/

cx_Oracle-6.0rc1-cp36-cp36m-manylinux1_x86_64.whl # linux

cx_Oracle-6.0rc1-cp36-cp36m-win_amd64.whl # PIP 安装

Windows 安装步骤:

  1. 解压 [instantclient ]客户端到指定目录,并新建环境变量:例如: ORACLE_HOME == D:\app\oracle\product\instantclient_11_2

    (设置好后cx_oracle会通过此路径找到它要的oci.dll等动态链接库)

或者手动将文件复制过去:

将解压文件夹下的oci.dll, oraocci12.dll,oraociei12.dll 拷贝到python安装目录下的lib/site-packages中

  1. 安装 cx_Oracle ;
  2. 验证安装是否成功: import cx_Oracle 或 python -c "import cx_Oracle"

Linux 安装步骤:

  1. 解压 [instantclient-basic-windows.x64-11.2.0.4.0.zip] 到指定目录;
  2. 解压后的 [instantclient_11_2]目录。添加到 PATH环境变量中(如下);
$ vim /etc/profile #文件尾部添加
export ORACLE_HOME=/opt/instantclient_11_2/
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME
$ source /etc/profile 使文件修改生效

$ vim ~/.bash_profile
export ORACLE_HOME=/usr/lib/oracle/12.2/client64
export LD_LIBRARY_PATH=/usr/lib/oracle/12.2/client64/lib
$ source .bash_profile 使文件修改生效
  1. 创建软连接

    cd /安装目录/instantclient_11_2/ ln -s libclntsh.so.11.1 libclntsh.so

  2. 安装cx_Oracle:

    pip install cx_Oracle-6.0rc1-cp36-cp36m-win_amd64.whl

  3. 验证安装是否成功:

    import cx_Oracle 或 python -c "import cx_Oracle"

注意:

1、Oracle数据库服务器端和Python编码方式不一致时会导致读取的中文文本乱码,可以通过设置NLS_LANG环境变量解决这一问题。

2、cx_Oracle模块会读取系统的path环境变量,寻找所需Oracle客户端文件,将path指向新下载的64位即时客户端,这样就可以解决系统中已有的Oracle11g - 32位版客户端与64位Python不兼容的冲突问题。

环境变量设置: 解决查询汉字出现乱码的问题

import os
os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8'
os.environ['path'] = 'C:/instantclient_11_2/' # 解压的目录路径

连接Oracle数据库

  • 连接数据库:
import cx_Oracle
# 方式一:
tns = cx_Oracle.makedsn(locahost, port, database)
db = cx_Oracle.connect(user, pwd, tns)
# 方式二:
db = cx_Oracle.connect('username','password','locahost/database')
# 方式三:
db = cx_Oracle.connect('用户名/密码@IP:端口号/database')
  • 创建操作游标:
cursor = db.cursor()   # 用于进行 SQL 操作
  • 关闭数据库:
cursor.close()  # 关闭游标
db.close() # 关闭数据库
  • SQL 查询:
方式一:
cursor.execute("Select member_id from member") 方式二:
sqlstr = "Select member_id from member where dt =:1 and id =:2"
datatuplp = ('2021-02-08', '123456789')
cursor.execute(sqlstr, datatuplp) 方式三:
cursor.prepare("""select * from tb_user where id <= :id""")
cursor.execute(None,{'id':5})
for row in cursor: #相当于fetchall()
print(row)
  • 创建表格:
sql = 'create table tb_user(id number, name varchar2(50),password varchar(50),primary key(id))'
cursor.execute(sql)
  • 插入数据:
#插入一条记录
cursor.execute("""insert into tb_user values(1,'admin','password')""") #再插入一条数据
param={'id':2,'n':'admin','p':'password'}
cursor.execute('insert into tb_user values(:id,:n,:p)',param) #一次插入多条数据,参数为字典列表形式
param=[{'id':3,'n':'admin','p':'password'},{'id':4,'n':'admin','p':'password'},{'id':5,'n':'admin','p':'password'}]
cursor.executemany('insert into tb_user values(:id,:n,:p)',param) #再一次插入多条数据
param=[];
#生成5条插入数据,参数为元组列表形式
for i in range(6,11): # [6,7,8,9,10]
param.append((i,'user'+str(i),'password'+str(i)))
#插入数据
cursor.executemany('insert into tb_user values(:1,:2,:3)',param)

python访问Oracle数据库相关操作的更多相关文章

  1. python对oracle数据库的操作

    1          Oracle数据库 1.1       Oracle环境配置&客户端连接 1.1.1          下载安装Oracle绿色版客户端instantclient: 到o ...

  2. 【转】Python访问oracle数据库,DPI-1047: Cannot locate a 64-bit Oracle Client library: "The specified module could not be found"

    使用python连接Oracle,出现如下错误: DPI-1047: Cannot locate a 64-bit Oracle Client library: "The specified ...

  3. 在代码生成工具Database2Sharp中使用ODP.NET(Oracle.ManagedDataAccess.dll)访问Oracle数据库,实现免安装Oracle客户端,兼容32位64位Oracle驱动

    由于我们开发的辅助工具Database2Sharp需要支持多种数据库,虽然我们一般使用SQLServer来开发应用较多,但是Oracle等其他数据库也是常用的数据库之一,因此也是支持使用Oracle等 ...

  4. python链接oracle数据库以及数据库的增删改查实例

    初次使用python链接oracle,所以想记录下我遇到的问题,便于向我这样初次尝试的朋友能够快速的配置好环境进入开发环节. 1.首先,python链接oracle数据库需要配置好环境. 我的相关环境 ...

  5. Oracle数据库一些操作信息

    Oracle数据库如何查看当前用户角色权限及默认表空间查看当前用户的一些信息,包括用户拥有的角色权限信息.用户表空间以及用户和默认表空间的关系等--查看用户的角色权限1.查看当前用户拥有的角色权限信息 ...

  6. python——连接Oracle数据库

    前言 Python自带的模块中有很多操纵文件的.我们可以把文件的数据读出来,经过处理还可以将数据写入文件中.但是对于数据的管理和分析来说,数据库还是专业一些.如果Python能和数据库结合在一起,那么 ...

  7. .net(C#)访问Oracle数据库的几种免安装组件的对比

    Oracle 数据存取组件(ODAC) 库为Borland Delphi,C++ Builder 以及 Kylix提供了一些非可视化的组件.它们用来存取Oracle关系数据库系统.与BDE类似, OD ...

  8. 用JDBC访问ORACLE数据库 关于commit 增快效率 大数据 等的整理

    1.问:用JDBC访问ORACLE数据库,做DELETE操作,能用JAVA多线程实现吗? ORACLE服务器要怎么配?(以下答案来自网络,仅供参考) 答: Oracle有自己的锁机制.就算你开100条 ...

  9. .net(C#)访问Oracle数据库的几种免安装组件的对比(转)

    原文地址 [内容为转载,个人推荐还是用官方的组件,推荐使用 Oracle.DataAccess.dll ] .net(C#)编程过程中,使用到了以下三种免安装的Oracle访问组件,能够不安装Orac ...

随机推荐

  1. 小试牛刀ElasticSearch大数据聚合统计

    ElasticSearch相信有不少朋友都了解,即使没有了解过它那相信对ELK也有所认识E即是ElasticSearch.ElasticSearch最开始更多用于检索,作为一搜索的集群产品简单易用绝对 ...

  2. SpringBoot @Value 解析集合配置

    引自:https://jitwxs.cn/d6d760c4.html 一.前言 在日常开发中,经常会遇到需要在配置文件中,存储 List 或是 Map 这种类型的数据.Spring 原生是支持这种数据 ...

  3. CTO也糊涂的常用术语:功能模块、业务架构、用户需求、文档……

    功能模块.业务架构.需求分析.用户需求.系统分析.功能设计.详细设计.文档.业务.技术--很多被随口使用的名词,其实是含糊甚至错误的. 到底含糊在哪里,错误在哪里,不仅仅是新手软件开发人员糊涂,许多入 ...

  4. 转 5 jmeter性能测试小小的实战

    5 jmeter性能测试小小的实战   项目描述 被测网址:www.sogou.com指标:相应时间以及错误率场景:线程数 20.Ramp-Up Period(in seconds) 10.循环次数 ...

  5. mybatis源码分析之走进缓存

    之前写了一篇关于mybatis缓存的读后感,想了想还是把缓存模块简单分析一下,附赠下载地址:https://github.com/MyBatis/MyBatis-3,github直接搜排名很靠前的. ...

  6. python生成器 递归

    生成器 生成器:只要函数体内出现yield关键字,那么再执行函数就不会执行函数代码,会得到一个结果,该结果就是生成器   生成器就是迭代器   yield的功能 1.yield为我们提供了一种自定义迭 ...

  7. CACTI优化-流量接口统计total输入和输出流量数据

    看图,没有优化前(没有显示流入和流出的总流量是多少): 优化后(有显示流入和流出总流量统计): 如何实现呢?本节就是处理的过程小结.第一步:登陆cacti管理平台进入控制台->模板->图形 ...

  8. JAVA SSM整合流程以及注意点

    1.搭建整合环境 整合说明:SSM整合可以使用多种方式,咱们会选择XML + 注解的方式 先搭建整合的环境 先把Spring的配置搭建完成 再使用Spring整合SpringMVC框架 最后使用Spr ...

  9. ubuntu 14.04下安装 mysql-workbench

    直接在命令行下运行下面命令: sudo apt-get install mysql-workbench 安装完,都可以在Dash中找到 "mysql" 就点击应用打开. 在data ...

  10. httpd反向代理实践(一)

    div.example { background-color: rgba(229, 236, 243, 1); color: rgba(0, 0, 0, 1); padding: 0.5em; mar ...