文档章节

Python初学之连接Oracle数据库

rootliu
 rootliu
发布于 2017/09/07 18:00
字数 1010
阅读 10
收藏 0
点赞 0
评论 0

 

Python初学之连接Oracle数据库

2014-03-12 20:53 287人阅读 评论(0) 收藏 举报

 分类:

python(4) 

  最近喜欢上脚本语言,准备从phthon这本语言开始学习!因为我想从事手游这个行业。

  从学什么开始呢?那就从python链接oracle数据库开始吧!废话少说,现在开始!

Python 连Oracle 的基本操作

1.1  DB连接和关闭DB连接

1.1.1 方法一:用户名,密码和监听 分开写

 

[root@rac1 u01]# cat db.py

import cx_Oracle

db=cx_Oracle.connect('system','oracle','192.168.2.42:1521/dave')

print db.version

db.close()

 

[root@rac1 u01]# python db.py

10.2.0.1.0

 

1.1.2 方法二:用户名,密码和监听写在一起

[root@rac1 u01]# cat db.py

import cx_Oracle

db=cx_Oracle.connect('system/oracle@192.168.2.42:1521/dave')

print db.version

db.close()

 

[root@rac1 u01]# python db.py

10.2.0.1.0

 

1.1.3 方法三:配置监听并连接

 

[root@rac1 u01]# cat db.py

import cx_Oracle

tns=cx_Oracle.makedsn('rac1',1521,'dave1')

db=cx_Oracle.connect('system','oracle',tns)

print tns

print db.version

vs=db.version.split('.')

print vs

if vs[0]=='10':

   print "This is Oracle 10g!"

db.close()

 

[root@rac1 u01]# python db.py

(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=rac1)(PORT=1521)))(CONNECT_DATA=(SID=dave1)))

10.2.0.1.0

['10', '2', '0', '1', '0']

This is Oracle 10g!

 

 

1.2  建立cursor 并执行SQL语句

 

[root@rac1 u01]# cat db.py

import cx_Oracle

tns=cx_Oracle.makedsn('rac1',1521,'dave1')

db=cx_Oracle.connect('system','oracle',tns) --创建连接

cr=db.cursor()  --创建cursor

sql='select * from phone'

cr.execute(sql)  --执行sql 语句

 

print "\nThis is Fetchall!"

rs=cr.fetchall()  --一次返回所有结果集

 

print "print all:(%s)" %rs

print "\n print by row:"

for x in rs:

        print x

 

print "\nThis is Fetone!"

cr.execute(sql)

while(1):

        rs=cr.fetchone()  --一次返回一行

        if rs ==None:break

        print rs

 

--使用参数查询

print "\n select with parameter:"

pr={'id':3,'tel':13888888888}

cr.execute('select * from phone where id=:id or phone=:tel',pr)

--这里我们将参数作为一个字典来处理的

rs=cr.fetchall()

print rs

 

cr.execute('select * from phone where id=:myid or phone=:myphone',myid=2,myphone=13888888888)

--这里我们直接写参数

rs=cr.fetchall()

print rs

 

cr.close()

db.close()

 

[root@rac1 u01]# python db.py

 

This is Fetchall!

print all:([(1, 13865999999L), (2, 13888888888L)])

 

print by row:

(1, 13865999999L)

(2, 13888888888L)

 

This is Fetone!

(1, 13865999999L)

(2, 13888888888L)

 

select with parameter:

[(2, 13888888888L)]

[(2, 13888888888L)]

 

Python 类型和Oracle 类型的对应关系:

 

During the fetch stage, basic Oracle data types get mapped into their Python equivalents. cx_Oracle maintains a separate set of data types that helps in this transition. The Oracle - cx_Oracle - Python mappings are:

 

 

 

Oracle

cx_Oracle

Python

VARCHAR2
NVARCHAR2
LONG

cx_Oracle.STRING

str

CHAR

cx_Oracle.FIXED_CHAR

NUMBER

cx_Oracle.NUMBER

int

FLOAT

float

DATE

cx_Oracle.DATETIME

datetime.datetime

TIMESTAMP

cx_Oracle.TIMESTAMP

CLOB

cx_Oracle.CLOB

cx_Oracle.LOB

 

一个完成的示例

 

在这个例子里,我们将用Python 对DB 进行一些操作,包括,创建一张表,并插入一些数据,在修改其中的部分数据。

 

 

[root@rac1 u01]# cat dave.py

#!/usr/bin/python

#coding=utf-8

import cx_Oracle

import sys

import urllib

import os

 

def connectDB(dbname='dave'):

        if dbname=='dave':

                connstr='system/Oracle@192.168.2.42:1521/dave'

        db=cx_Oracle.connect(connstr)

        return db

 

def sqlSelect(sql,db):

        #include:select

        cr=db.cursor()

        cr.execute(sql)

        rs=cr.fetchall()

        cr.close()

        return rs

 

def sqlDML(sql,db):

        #include: insert,update,delete

        cr=db.cursor()

        cr.execute(sql)

        cr.close()

        db.commit()

 

def sqlDML2(sql,params,db):

        # execute dml with parameters

        cr=db.cursor()

        cr.execute(sql,params)

        cr.close()

        db.commit()

 

def sqlDDL(sql,db):

        #include: create

        cr=db.cursor()

        cr.execute(sql)

        cr.close()

 

 

if __name__=='__main__':

        print "This is a test python program,write by tianlesoftware!\n"

        os.environ['NLS_LANG']='SIMPLIFIED CHINESE_CHINA.UTF8'

 

        #connect to database:

        db=connectDB()

 

        #create a table:

        sql='create table dave(id number,name varchar2(20),phone number)'

        sqlDDL(sql,db)

 

        #insert data to table dave:

        sql='insert into dave values(1,\'tianlesoftware\',13888888888)'

        sqlDML(sql,db)

 

        dt=[{'id':2,'name':'dave','phone':138888888888},

            {'id':3,'name':'Oracle','phone':13888888888},

            {'id':4,'name':'anqing','phone':13888888888}]

 

        sql='insert into dave values(:id,:name,:phone)'

 

        for x in dt:

                sqlDML2(sql,x,db)

 

 

        #select the result:

        print "this is the first time select the data from dave"

        sql='select * from dave'

        rs=sqlSelect(sql,db)

        for x in rs:

                print x

 

        #update data where id=1,change the name to anhui

        sql='update dave set name=\'anhui\' where id=1'

        sqlDML(sql,db)

 

        #select again:

        print "\n change the nanme to anhui where id equal 1,and select the result"

        sql='select * from dave'

        rs=sqlSelect(sql,db)

        for x in rs:

                print x

 

        #delete data where id=3

        sql='delete from dave where id=3'

        sqlDML(sql,db)

 

        #select again:

        print "\n delete the data where id equal 3 and select the result"

        sql='select * from dave'

        rs=sqlSelect(sql,db)

        for x in rs:

                print x

 

        db.close()

 

 

[root@rac1 u01]# python dave.py

This is a test python program,write by tianlesoftware!

 

this is the first time select the data from dave

(1, 'tianlesoftware', 13888888888L)

(2, 'dave', 138888888888L)

(3, 'Oracle', 13888888888L)

(4, 'anqing', 13888888888L)

 

change the nanme to anhui where id equal 1,and select the result

(1, 'anhui', 13888888888L)

(2, 'dave', 138888888888L)

(3, 'Oracle', 13888888888L)

(4, 'anqing', 13888888888L)

 

delete the data where id equal 3 and select the result

(1, 'anhui', 13888888888L)

(2, 'dave', 138888888888L)

(4, 'anqing', 13888888888L)

 

 

关于Python 连接Oracle 数据库,及一些基本操作,就这么多。

 

© 著作权归作者所有

共有 人打赏支持
rootliu
粉丝 2
博文 221
码字总数 2796
作品 0
海淀
数据库管理员
Python远程连接服务器上的Oracle数据库

Python远程连接服务器上的Oracle数据库 1、正确的开启方式 在你的IPython或者是Anaconda的jupyter中输入一下代码,其中: ‘username’—— 用户名 ‘password’——密码 ‘192.168.1.1:1521/...

推荐码发放 ⋅ 05/04 ⋅ 0

Python学习日记六(Python连接MySql)

一.准备工作(下载MySQL-python和python安装包 ) Python需要连接mysql,需要下载Python MySQLdb模块,这里提供几个链接地址: MySQL-python官网下载地址 :https://pypi.python.org/pypi/My...

HaleyLiu ⋅ 04/12 ⋅ 0

她们不一样!python小白刚学会python竟然爬取了网上所有小姐姐的照片

如今想学python的人越来越多,无论是专业的程序员还是业余爱好者,都对python情有独钟。世界上值得学习的技能有很多,但是如果你要问我推荐哪一个,那么我会推荐一门编程语言,比如python。如...

Python学习 ⋅ 06/06 ⋅ 0

pycharm不能访问oracle(sybase)的问题

oracle环境: 服务器:docker中的oracle服务器,服务名为xe,参考unbuntu下Docker安装oracle和mysql 客户端:instantclient客户端,参考打造ubuntu下精简版的oracle客户端及pro*c编译环境 由...

wangxuwei ⋅ 05/28 ⋅ 0

python3 django配置数据库(mysql)

python3 django配置数据库(mysql) python3 下的mysql驱动 django 连接mysql默认驱动是MySQLdb,MySQLdb没有支持python3的版本,如果使用python3.x版本时,django连接mysql的方法 1、使用p...

代金券优惠 ⋅ 04/24 ⋅ 0

Pycharm开发工具里面python3连接MySQL问题

参考地址:http://www.runoob.com/python3/python3-mysql.html 以前的代码是python2.7开发的,Python2中则使用mysqldb,现在准备用python3,则用不了mysqldb组件;PyMySQL 是在 Python3.x 版...

mchdba ⋅ 04/18 ⋅ 0

什么样的人学Python比别人快?Python的学习大纲有哪些?

什么样的人学Python比别人快? 为什么会是这些人?前两类大家应该都没什么意见,为什么最后两类会学得快?这两类说白了就一个关键词:转行!既然决定转行,有太多需要学习的东西,太多不适应...

帅帅程序员 ⋅ 04/28 ⋅ 0

谁说小白不能做项目?Python大咖手把手教你采集拉勾网!

全文简介 本文是先采集拉勾网上面的数据,采集的是Python岗位的数据,然后用Python进行可视化。主要涉及的是爬虫&数据可视化的知识。 爬虫部分 先用Python来抓取拉勾网上面的数据,采用的是简...

Python学习 ⋅ 03/08 ⋅ 0

老司机工作总结!零基础python小白学习编程一定要知道的那些技巧

今天又是一年一度的关键时刻:高考了。高考可谓是牵动着无数普通家庭的心。但是高考就是千军万马过独木桥,是一场没有硝烟的战争,有输有赢。可是高考跟战争不一样的是,高考就算失败也会有其...

Python学习 ⋅ 06/07 ⋅ 0

Django-ORM数据库操作

背景 Django框架功能齐全自带数据库操作功能,由于工作中设计巨量的api接口,需要一个很好的web后端服务框架,Django给了莫大的帮助。本文主要介绍Django的ORM框架 我们一般对数据库的使用的...

武耀文 ⋅ 06/12 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Spring发展历程总结

转自与 https://www.cnblogs.com/RunForLove/p/4641672.html 目前很多公司的架构,从Struts2迁移到了SpringMVC。你有想过为什么不使用Servlet+JSP来构建Java web项目,而是采用SpringMVC呢?...

onedotdot ⋅ 41分钟前 ⋅ 0

Python模块/包/库安装(6种方法)

Python模块/包/库安装(6种方法) 冰颖机器人 2016-11-29 21:33:26 一、方法1: 单文件模块 直接把文件拷贝到 $python_dir/Lib 二、方法2: 多文件模块,带setup.py 下载模块包(压缩文件zip...

cswangyx ⋅ 今天 ⋅ 0

零基础学习大数据人工智能,学习路线篇!系统规划大数据之路?

大数据处理技术怎么学习呢?首先我们要学习Python语言和Linux操作系统,这两个是学习大数据的基础,学习的顺序不分前后。 Python:Python 的排名从去年开始就借助人工智能持续上升,现在它已经...

董黎明 ⋅ 今天 ⋅ 0

openJdk和sun jdk的区别

使用过LINUX的人都应该知道,在大多数LINUX发行版本里,内置或者通过软件源安装JDK的话,都是安装的OpenJDK, 那么到底什么是OpenJDK,它与SUN JDK有什么关系和区别呢? 历史上的原因是,Ope...

jason_kiss ⋅ 今天 ⋅ 0

梳理

Redux 是 JavaScript 状态容器,提供可预测化的状态管理。 它是JS的状态容器,是一种解决问题的方式,所以即可以用于 react 也可以用于 vue。 需要理解其思想及实现方式。 应用中所有的 stat...

分秒 ⋅ 今天 ⋅ 0

Java 后台判断是否为ajax请求

/** * 是否是Ajax请求 * @param request * @return */public static boolean isAjax(ServletRequest request){return "XMLHttpRequest".equalsIgnoreCase(((HttpServletReques......

JavaSon712 ⋅ 今天 ⋅ 0

Redis 单线程 为何却需要事务处理并发问题

Redis是单线程处理,也就是命令会顺序执行。那么为什么会存在并发问题呢? 个人理解是,虽然redis是单线程,但是可以同时有多个客户端访问,每个客户端会有 一个线程。客户端访问之间存在竞争...

码代码的小司机 ⋅ 今天 ⋅ 0

到底会改名吗?微软GVFS 改名之争

微软去年透露了 Git Virtual File System(GVFS)项目,GVFS 是 Git 版本控制系统的一个开源插件,允许 Git 处理 TB 规模的代码库,比如 270 GB 的 Windows 代码库。该项目公布之初就引发了争...

linux-tao ⋅ 今天 ⋅ 0

笔试题之Java基础部分【简】【二】

1.静态变量和实例变量的区别 在语法定义上的区别:静态变量前要加static关键字,而实例变量前则不加。在程序运行时的区别:实例变量属于某个对象的属性,必须创建了实例对象,其中的实例变...

anlve ⋅ 今天 ⋅ 0

Lombok简单介绍及使用

官网 通过简单注解来精简代码达到消除冗长代码的目的 优点 提高编程效率 使代码更简洁 消除冗长代码 避免修改字段名字时忘记修改方法名 4.idea中安装lombnok pom.xml引入 <dependency> <grou...

to_ln ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部