Python学习之 cx_Oracle学习记录 一

        今天开始正式学习Python,正好在学Oracle,刚好结合在一起把cx_Oracle学习了。

对了这哥们有一个教python的网站,我在上面也学了学

地址: http://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493182103fac9270762a000/001374738165063fb542617cc6f4ccd943363211148ba9a000

这个网址也记一下,

地址:http://www.cnblogs.com/hzhida/archive/2012/08/09/2630173.html

Python是靠cx_Oracle来和Oracle来交互的。

  1. 首先就是安装这些东西了,我用的环境是Centos6.4 64位版本,在网上找到的cx_Oracle是最高支持Python到3.3,

所以我下的是Python3.3,使用的数据库是11g的,所以cx_Oracle下载相应的版本。

cx_Oracle下载地址:http://sourceforge.net/projects/cx-oracle/files/5.1.2/

上面的地址这里没有最新版本的,我用的是5.1.3在这个地址下的

cx_Oracle下载地址: https://pypi.python.org/pypi/cx_Oracle/5.1.3

先说一下,我电脑本身装着那个Python2.6呢,但是我要用python3.3,所以下载了个python3.3的源码包进行安装

然后我下载了cx_Oracle的rpm安装包,但是安装后,使用import cx_Oracle没有这个模块。

然后我就又下载了cx_Oracle的源码包,自己这样安装,安装后,就可以用了。

cx_Oracle源码包中,有一个文件是setup.py,这里面有具体的安装方法,

python setup.py build install

这里python我因为安装的是3.3的,所以我用的是

python3.3 setup.py build install

这样就是安装过程了,并且我的机器是本身安装了Oracle 11g的。


2. 然后就是使用了,我在网上看了一下,使用的帖子都差不多,内容也没有多大区别,然后我就在官网上找到了说明

地址:http://cx-oracle.readthedocs.org/en/latest/module.html

根据这里的介绍来使用就可以了。


3. 先放一个我刚写的测试的,遇到了问题。

1.py

#!/usr/local/bin/python3.3
import cx_Oracle as orcl
print(orcl.clientversion())
username = "scott"
passwd = "xx"
host = "192.168.32.200"
port = "1521"
sid = "oracleSid"
dsn = orcl.makedsn(host, port, sid)
con = orcl.connect(username, passwd, dsn)
cursor = con.cursor()
sql = "SELECT ENAME, EMPNO FROM EMP"
cursor.execute(sql);
result = cursor.fetchall()
print("Total: " + str(cursor.rowcount))
for row in result:
    print(row)
cursor.close()
con.close()
print(orcl.Date(2015,3,13))

可以看到

orcl.Date(2015,3,13) 这里D是大写的,我在写的时候以为不区分大小写,就写成小写的,报错。

con.cursor()这里cursor第一个字母是小写的,我改成大写但是报错,我看文档中cx_Oracle.Cursor(connection

这里是Cursor,这第一个字母是大写的,我当时就出现疑问了,怎么格式不统一呢???

但是后来我发现原来是我看错了,使用cx_Oracle调用的,第一个字母是大写的,也就是文档中的那种,

但是con.cursor()这个是用连接调用的,不是一回事。

在这里con.cursor()还可以改成,orcl.Cursor(con)

这样也是取得游标了。

还有那个dsn是data source name的简写。



又练习了一会,程序有所扩充,有了一个产生随机数的模块random,

需要import random

#!/usr/local/bin/python3.3
import cx_Oracle as orcl
print(orcl.clientversion())
username = "scott"
passwd = "xx"
host = "192.168.32.200"
port = "1521"
sid = "oracleSid"
dsn = orcl.makedsn(host, port, sid)
con = orcl.connect(username, passwd, dsn)
cursor1 = orcl.Cursor(con)
cursor = con.cursor()
sql = "SELECT ENAME, EMPNO FROM EMP"
cursor1.execute(sql);
result = cursor1.fetchall()
print("Total: " + str(cursor1.rowcount))
for row in result:
    print(row)
print(con.autocommit)
print(con.dsn)
print(con.password)
print(con.ping())
print(con.tnsentry)
print(con.username);
print(con.version)
where_params = {'deptno':30}
sql = "SELECT ENAME, EMPNO FROM EMP \
        WHERE deptno = :deptno"
cursor.execute(sql, where_params);
result = cursor.fetchall();
print("Total row: " + str(cursor.rowcount))
for row in result:
    print(row)
sql = "SELECT ENAME, trunc(SAL,0) FROM EMP \
       WHERE deptno = :deptno and sal > :value"
cursor.execute(sql, deptno = 30, value = 1000);
result = cursor.fetchall();
print("Total row: " + str(cursor.rowcount))
for row in result:
    print(row)
import random
empno = random.randint(1000, 6000);
params = {'empno':empno}
sql = "INSERT INTO EMP (EMPNO, SAL, DEPTNO) VALUES(:empno, 8888, 30)"
cursor.execute(sql, params);
con.commit()
sql = "DELETE FROM EMP WHERE EMPNO = 8888"
cursor.execute(sql);
con.commit();
cursor1.close()
con.close()
print(orcl.Date(2015,3,13))
print(orcl.DateFromTicks(555555555))
print(orcl.apilevel)
print(orcl.buildtime)
print(orcl.paramstyle)
print(orcl.version)


我贴上代码发现这样太乱了,还是分功能的学习,先是插入数据

insert.py

  #!/usr/local/bin/python3.3
import cx_Oracle as db
username = "scott"
passwd = "xx"
host = "192.168.32.200"
port = "1521"
sid = "oracleSid"
dsn = db.makedsn(host, port, sid)
con = db.connect(username, passwd, dsn);
cur = db.Cursor(con);
import random
params = {'empno':random.randint(1000, 6000),\
            'sal':random.randint(1000, 3000)}
print("Insert empno: ", params['empno'], "sal: ", params['sal']);
sql = "INSERT INTO EMP (EMPNO, SAL, DEPTNO) \
       VALUES(:empno, :sal, 30)"
cur.execute(sql, params);
con.commit();
cur.close();
con.close();

我又重新写的时候发现还真是有问题他们的命名,一会大写一会小写的。Cursor是大写,但是connect用的是小写,而在文档中,大小写都是有的,但我改成大写,报错了。

还有这里使用字典params的时候,我打印的时候是这么用的,我感觉,应该还有更简便的方法。以后发现再补充上。

这是select,里面用字典来当那个where里的参量,
并且这里还使用了环境变量,这个需要使用os扩展,import os,代码如下:
  


#!/usr/local/bin/python3.3
import cx_Oracle as db
import os
username = "scott"
passwd = "xx"
host = "192.168.32.200"
port = "1521"
sid = "oracleSid"
dsn = db.makedsn(host, port, sid);
con = db.connect(username, passwd, dsn);
cur = db.Cursor(con);
sql = "SELECT ENAME, SAL FROM EMP \
       WHERE deptno = :deptno and sal < :sal"
cur.execute(sql, deptno = 30, sal = 2200)
result = cur.fetchall();
for row in result:
    print(row);
print("################################################")
params = {'deptno':30, 'sal':3000}
cur.execute(sql, params)
result = cur.fetchall();
for row in result:
    print(row);
print("################################################")
cur.execute(sql, params)
result = cur.fetchone()
print(result)
result = cur.fetchone()
print(result)
print(os.environ["ORACLE_HOME"])
print("################################################")
cur.close();
con.close();

这里使用了fetchall和fetchone,

我尝试了一次,如果之前使用了fetchall,接着就执行fetchone,这时候是得不到东西了已经。

必须再次执行,execute才可以再次调用fetchone,不过,fetchone可以多次调用,应该是调用到没有数据为止、

我又去尝试着写了一下,用fetchone来得到所有数据的循环,总算是出来了,用的是while

#!/usr/local/bin/python3.3
import cx_Oracle as db
import os
username = "scott"
passwd = "xx"
host = "192.168.32.200"
port = "1521"
sid = "oracleSid"
dsn = db.makedsn(host, port, sid);
con = db.connect(username, passwd, dsn);
cur = db.Cursor(con);
sql = "SELECT ENAME, SAL FROM EMP \
       WHERE deptno = :deptno and sal < :sal"
cur.execute(sql, deptno = 30, sal = 2200)
result = cur.fetchall();
for row in result:
    print(row);
print("################################################")
params = {'deptno':30, 'sal':3000}
cur.execute(sql, params)
result = cur.fetchall();
for row in result:
    print(row);
print("################################################")
cur.execute(sql, params)
result = cur.fetchone()
while result:
    print(result, " Haha...")
    result = cur.fetchone()
print("################################################")
result = cur.fetchone()
print(result)
print(os.environ["ORACLE_HOME"])
print("################################################")
cur.close();
con.close();

我看了,他这个循环结构就是不论for还是while就是先用冒号来开始,然后tab缩进的都属于循环块中。










你可能感兴趣的:(Python学习之 cx_Oracle学习记录 一)