Python FastApi连接oracle进行查询

这边技术选型是cx_oracle进行连接查询,cx_oracle的使用首先要有官方的客户端才能连接到数据库,python并不自带客户端。我用是Python3.9

安装客户端

可以到官网在选择最新版进行下载。

Instant Client for Microsoft Windows (x64) 64-bit

或者直接从我这里下也行

我用夸克网盘分享了「instantclient-basic-windows.x64-21.12.0.0.0dbru.zip」,点击链接即可保存。打开「夸克APP」,无需下载在线播放视频,畅享原画5倍速,支持电视投屏。
链接:https://pan.quark.cn/s/c0fa18a92342
提取码:VwUC

解压找到   instantclient_版本号 这个文件 ,把它复制到项目路径下

加载客户端

我的客户端路径在这里

F:\pyVersion\pyResource\instantclient-basic-windows.x64-21.12.0.0.0dbru\instantclient_21_12

项目配置下全局参数

key:ORACLE_CLIENT_LIB

value:F:\pyVersion\pyResource\instantclient-basic-windows.x64-21.12.0.0.0dbru\instantclient_21_12

安装其他包

安装cx_Oracle

pip  install cx_Oracle

示例代码

import os

from fastapi import FastAPI
import cx_Oracle

app = FastAPI()

oracle_client_lib_dir = os.getenv("ORACLE_CLIENT_LIB", "instantclient_21_12")
cx_Oracle.init_oracle_client(lib_dir=oracle_client_lib_dir)


@app.on_event("startup")
async def startup():
    global pool
    pool = cx_Oracle.SessionPool("账号", "密码", "ip4:1521/服务名", min=2, max=5, increment=1, encoding="UTF-8")


@app.on_event("shutdown")
async def shutdown():
    pool.close()


@app.get("/")
async def root():
    # 从连接池中获取一个连接
    connection = pool.acquire()

    try:
        # 使用连接进行查询
        cursor = connection.cursor()
        # select * from wx.USER_VIDEO_CUTIMG where id in(1571373,1571423,1571439,1571459)
        cursor.execute(
            "select * from wx.USER_VIDEO_CUTIMG where NAME LIKE '%C%'")
        # 获取返回值结果,只针对于查询
        result_list = cursor.fetchall()
      
        for result in result_list:
            oldPhotoName = result[3]
            newPhotoName = oldPhotoName.replace('C', 'D')
            print(newPhotoName)

        # 调用相片旋转等其他操作
        ...
    finally:
        # 将连接放回连接池
        pool.release(connection)

    return {"message": "Hello World"}

当然你可以不必像我这么高级,非要全局获取,直接写成下面也是会连接的

cx_Oracle.init_oracle_client(lib_dir=“F:\pyVersion\pyResource\instantclient-basic-windows.x64-21.12.0.0.0dbru\instantclient_21_12”)

执行成功

------------------------------------------与正文内容无关------------------------------------
如果觉的文章写对各位读者老爷们有帮助的话,麻烦点赞加关注呗!小弟在这拜谢了!
如果您觉得我的文章在某些地方写的不尽人意或者写的不对,从而让你对你人生观产生颠覆(概不负责),需要斧正,麻烦在评论区不吝赐教,作者看到后会根据您的提示查阅文章进行修改,还这世间一个公理一片蓝天

  • 20
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Python FastAPI 是一个快速(高性能)且易于学习的 Web 框架,它可以与多种消息队列(MQ)进行集成,其中包括 RabbitMQ。 在使用 FastAPI 和 RabbitMQ 进行集成时,你可以使用 Pika 库来连接 RabbitMQ,然后在 FastAPI 中使用 FastAPI-BackgroundTasks 库来异步处理消息队列中的消息。以下是一个简单的示例: 1. 安装 FastAPI 和 Pika 库: ```python pip install fastapi pip install pika pip install fastapi-background-tasks ``` 2. 在 FastAPI 应用程序中导入相关库: ```python from fastapi import FastAPI, BackgroundTasks import pika ``` 3. 连接 RabbitMQ: ```python connection = pika.BlockingConnection(pika.ConnectionParameters(host='localhost')) channel = connection.channel() channel.queue_declare(queue='my_queue') ``` 4. 编写处理函数,并在函数中使用 `channel.basic_publish()` 方法将消息发布到消息队列中: ```python def process_message(message): # 处理消息的代码 print("Received message:", message) def send_message_to_queue(message): channel.basic_publish(exchange='', routing_key='my_queue', body=message) ``` 5. 在 FastAPI 中定义异步任务: ```python app = FastAPI() @app.post("/send_message") async def send_message(message: str, background_tasks: BackgroundTasks): background_tasks.add_task(send_message_to_queue, message) return {"message": "Message sent successfully!"} @app.on_event("startup") async def startup_event(): connection = pika.BlockingConnection(pika.ConnectionParameters(host='localhost')) channel = connection.channel() channel.queue_declare(queue='my_queue') channel.basic_consume(queue='my_queue', on_message_callback=process_message, auto_ack=True) channel.start_consuming() ``` 6. 启动应用程序: ```python uvicorn main:app --reload ``` 这是一个简单的示例,你可以根据你的需求进行调整和扩展。下面是一些相关问题:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

A乐神

恭喜发财啊,老板,嘻嘻!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值