python 批量造数据写入Oracle数据库

 # 导入必要的模块 
 import oracledb 
 import faker 
 import random 
  
 # 创建faker对象,指定中文语言 
 f = faker.Faker("zh_CN") 
  
 # 连接oracle数据库,替换用户名、密码和数据库 
 conn = oracledb.connect(user="用户名", password="密码", dsn="数据库") 
  
 # 创建游标对象 
 cur = conn.cursor()

 # 准备插入语句,使用绑定变量 
 sql = "insert into dev_test (name, age, income) values (:1, :2, :3)" 
  
 # 生成百万条记录的数据列表,每个元素是一个元组(name, age, income) 
 ##random.randint(a,b):用于生成一个指定范围的整数,包含b
 data = [(f.name(), random.randint(18, 60), random.randint(1000, 40000)) for _ in range(100)] 
  
 # 调整批量插入的大小,以适应内存和性能需求 
 batch_size = 10 
  
 # 批量插入数据,提高性能 
 for i in range(0, len(data), batch_size): 
     try :
         cur.executemany(sql, data[i:i+batch_size]) 
     except Exception as e:
         print(e)

 
 # 提交事务 
 conn.commit() 
 
 # 关闭游标和连接对象 
 cur.close() 
 conn.close()

查询表数据并执行

#定义查询语句
aid="select a from pepole"
#执行语句
cur.execute(aid)
#获取所有记录
result = cur.fetchall()


 

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Python可以轻松地从Oracle数据库中读取数据并生成报表。以下是一些常用的Python库和步骤: 1. 安装必要的Python库:cx_Oracle、pandas、openpyxl等。 2. 连接到Oracle数据库,可以使用cx_Oracle库连接到Oracle数据库。 3. 通过SQL查询从Oracle数据库中获取数据,使用pandas库可以将查询结果转换为DataFrame对象。 4. 使用openpyxl等库将数据写入Excel文件中。 以下是一个示例代码,用于从Oracle数据库中获取数据并将其写入Excel文件中: ```python import cx_Oracle import pandas as pd from openpyxl import Workbook # 连接Oracle数据库 conn = cx_Oracle.connect('username/password@host:port/service_name') # SQL查询语句 sql = 'SELECT * FROM table_name' # 获取查询结果并转换为DataFrame对象 df = pd.read_sql(sql, conn) # 创建Excel文件 wb = Workbook() # 选择第一个工作表 ws = wb.active # 将DataFrame对象写入Excel文件中 for r in dataframe_to_rows(df, index=False, header=True): ws.append(r) # 保存Excel文件 wb.save('report.xlsx') # 关闭数据库连接 conn.close() ``` 以上代码中,需要替换的部分包括: - `username`和`password`:Oracle数据库的用户名和密码 - `host`:Oracle数据库的主机名或IP地址 - `port`:Oracle数据库的端口号 - `service_name`:Oracle数据库的服务名称 - `table_name`:需要查询的表名 - `report.xlsx`:生成的Excel文件名 当然,如果你需要生成其他格式的报表,可以使用不同的Python库来实现。例如,使用matplotlib库可以生成图表,使用reportlab库可以生成PDF报表等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值