Oracle 10g → Oracle 19c 升级后问题解决方案(Pro*C 项目)

1️⃣ 升级背景

  • 旧环境:Oracle 10g + gcc 3.x → 支持隐式函数声明

  • 新环境:Oracle 19c + gcc ≥ 5.x → 遵循 C99/C11 标准,禁止隐式函数声明

  • 升级后主要问题:

    1. implicit declaration of function 'sqlcxt' 等错误

    2. 动态库找不到(运行时报错 libclntsh.so

    3. Pro*C 生成的 .c 文件缺少头文件


2️⃣ 升级流程建议

步骤 1:环境准备

  1. 安装 Oracle 19c Client / Database

  2. 安装新的 gcc 版本(≥5.x)

  3. 设置环境变量:

    export ORACLE_HOME=/opt/oracle/19c/client
    export PATH=ORACLE_HOME/bin:PATH
    export LD_LIBRARY_PATH=ORACLE_HOME/lib:LD_LIBRARY_PATH


步骤 2:验证动态库路径

复制代码
echo $LD_LIBRARY_PATH
ldd ./your_program  # 检查 .so 文件是否可找到

步骤 3:Pro*C 文件处理

  • 确认所有 .pc 文件在生成 .c 文件时包含必要的头文件:

    EXEC SQL INCLUDE sqlca;
    EXEC SQL INCLUDE sqlcpr;

  • 或在 Makefile proc 命令中加 include 参数:

    PROCFLAGS = userid=(USER_ID) mode=oracle sqlcheck=full dbms=native include=ORACLE_HOME/precomp/public


步骤 4:编译问题处理(implicit declaration)

方法 A:推荐(修复头文件)
  • 在生成的 .c 文件开头加:

    #include <sqlca.h>
    #include <sqlcpr.h>
    #include <oci.h> // 如果使用 OCI 函数

方法 B:临时编译参数(过渡)
  • 在 Makefile 中加入:

    CFLAGS += -Wno-implicit-function-declaration
    CFLAGS += -std=gnu89 # 可选

⚠️ 没有修复头文件可能导致运行时问题


步骤 5:gcc 版本控制

  • 在 Makefile 指定:

    CC = gcc-3 # 或者 gcc-9
    CFLAGS = -m32 -O2 -I.

  • 或临时修改 PATH:

    export PATH=/opt/gcc-3/bin:$PATH


小结

问题 解决方法
implicit declaration of function 修复 .c 头文件或 Makefile 增加 include,临时可加 -Wno-implicit-function-declaration
找不到动态库 设置 LD_LIBRARY_PATH=$ORACLE_HOME/lib:$LD_LIBRARY_PATH
Pro*C 生成 .c 文件缺少头文件 .pc 文件里加 EXEC SQL INCLUDE sqlca; sqlcpr; 或 Makefile proc include
gcc 版本差异 Makefile 指定 CC=gcc-x 或临时修改 PATH
相关推荐
粤M温同学几秒前
Android Room数据库的基本使用
android·数据库
cypking3 分钟前
三、NestJS 开发实战文档-->集成 MySQL(TypeORM)
前端·数据库·mysql·adb·node.js
码农水水7 分钟前
大疆Java面试被问:Spring事务的传播行为详解
java·数据库·spring
ha_lydms9 分钟前
2、Spark 函数_a/b/c
大数据·c语言·hive·spark·时序数据库·dataworks·数据开发
逍遥德14 分钟前
mysql-8.4.7-winx64.zip 安装/运行
数据库·mysql
lkbhua莱克瓦2418 分钟前
基础-约束
android·开发语言·数据库·笔记·sql·mysql·约束
Alex Cafu21 分钟前
Linux网络编程2(HTTP 协议、IO 多路复用)
linux·c语言·网络·http
falldeep21 分钟前
LeetCode高频SQL50题总结
数据结构·数据库·sql·算法·leetcode·职场和发展
万邦科技Lafite22 分钟前
淘宝开放API获取订单信息教程(2025年最新版)
java·开发语言·数据库·人工智能·python·开放api·电商开放平台
zore_c22 分钟前
【C语言】排序算法——希尔排序以及插入排序 ——详解!!!
c语言·数据结构·c++·笔记·算法·排序算法·推荐算法