当前位置:  数据库>oracle

Linux下C语言访问Oracle数据库Demo

    来源: 互联网  发布时间:2017-03-28

    本文导语: 前提条件  1. Linux环境已经存在,安装好了Oracle  本demo 运行环境 本地环境     RedHat LINUX AS 4 ,ORACLE 10G本地数据库sid orcl,ip:127.0.0.1,用户名:kingbi,密码:kingbi,表dsd_test. 显示表dsd_test 的所有记录. 步骤: (1) 创建表 create table dsd_tes...

前提条件

 1. Linux环境已经存在,安装好了Oracle

 本demo 运行环境

本地环境     RedHat LINUX AS 4 ,ORACLE 10G
本地数据库sid orcl,ip:127.0.0.1,用户名:kingbi,密码:kingbi,表dsd_test. 显示表dsd_test 的所有记录.

步骤:

(1) 创建表 create table dsd_test(aa char(3)); insert into dsd_test  values('123');insert into dsd_test  values('456');

      被配置本地命名服务($ORACLE_HOME/network/admin/tnsnames.ora

     ORCL =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = localhost.localdomain)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = orcl)
    )
  )







(2) 修改配置文件 /etc/profile (用root用户修改,增加 2句代码

      ...

      export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE INPUTRC
      export ORACLE_HOME=........                                                          #以下2行为新加

      export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/usr/lib          #这句很关键
       .....

(3) 更改$ORACLE_HOME/precomp/admin/pcscfg.cfg (include= 开头的语句为新加的,,/usr/lib/gcc/i386-redhat-linux/3.4.3/include 也是新加的) www.linuxidc.com

sys_include=(/ade/aime_rdbms_9819/oracle/precomp/public,/usr/include,/usr/lib/gcc-lib/i486-SUSE-linux/2.95.3/include,/usr/lib/gcc-lib/i386-redhat-linux/3.2.3/include,/usr/lib/gcc-lib/i386-redhat-linux7/2.96/include,/usr/lib/gcc/i386-redhat-linux/3.4.3/include)
include=$ORACLE_HOME/lib
include=$ORACLE_HOME/precomp/precomp/include
include=$ORACLE_HOME/precomp/oracore/include
include=$ORACLE_HOME/precomp/oracore/public
include=$ORACLE_HOME/precomp/rdbms/include
include=$ORACLE_HOME/precomp/rdbms/public
include=$ORACLE_HOME/precomp/rdbms/demo
include=$ORACLE_HOME/precomp/nlsrtl/include
include=$ORACLE_HOME/precomp/nlsrtl/public
include=$ORACLE_HOME/precomp/network_src/include
include=$ORACLE_HOME/precomp/network_src/public
include=$ORACLE_HOME/precomp/network/include
include=$ORACLE_HOME/precomp/network/public
include=$ORACLE_HOME/precomp/plsql/public
ltype=short
(4) 编写c 程序 test.pc文件 www.linuxidc.com















#include

EXEC SQL INCLUDE SQLCA;

int main()
{
     //声明SQL变量
     EXEC SQL BEGIN DECLARE SECTION;
     VARCHAR user[20],pass[20],tnsname[20];



     //VARCHAR预编译后为struct { unsigned short len; unsigned char arr[20];}
     char ename[20];
     EXEC SQL END DECLARE SECTION;

     //声明结束
     int i=0;
     strcpy(user.arr,"kingbi");
     user.len=(unsigned short)strlen((char *)user.arr);
     strcpy(pass.arr,"kingbi");
     pass.len=(unsigned short)strlen((char *)pass.arr);
     strcpy(tnsname.arr,"orcl");
     tnsname.len=(unsigned short)strlen((char *)tnsname.arr);
     //连接数据库
     EXEC SQL CONNECT :user IDENTIFIED BY :pass USING :tnsname;








    //执行查询

    EXEC SQL declare emp_cursor cursor for
     select aa from kingbi.test;          
     EXEC SQL open emp_cursor;
     EXEC SQL WHENEVER NOT FOUND DO break;


     while(1)
     {
           EXEC SQL fetch emp_cursor into :empno,:ename;
           printf("the name is %sn",ename);
           i=i+1;
     }
    
     printf("Yeah!We get %d recordsn",i);






     EXEC SQL close emp_cursor;
     EXEC SQL commit work release;
}

(5) 预编译 ,编译后会生成 .c文件

proc test.pc

(6)编译

gcc -o test test.c $ORACLE_HOME/lib/libclntsh.so

(6) 运行生成的可执行文件

./test

输出:

the name is 123               
the name is 456               
Yeah!We get 2 records


    
 
 

您可能感兴趣的文章:

  • Linux下C语言strstr()查找子字符串位置函数详细介绍(strstr原型、实现及用法)
  • 求助,在linux下,c语言和汇编语言的接口是什么?
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • 我安装的linux时默认语言选择的是中文,又乱码,怎么可以解决?怎么更改默认语言成英文?
  • LINUX 或者Windows 如何保证一个进程只有一个实例在运行?如果是C语言,JAVA语言开发,又怎么样保证?
  • LINUX下面C语言和C++语言所开发的软件有什么区别
  • 有了c语言基础,如何入手学习用c语言linux网络编程
  • Linux 区分语言版本吗?
  • 一个小问题。Linux下编程语言的问题。
  • 我是一个linux新手,不知道如何在linux进行C语言的编写和使用?
  • LINUX下语言的困惑(超菜)
  • 初学Linux要看什么书?, 请问Linux下C语言编程怎么设置环境?
  • LINUX新手提问,如何在LINUX下添加语言项?
  • linux新手想请问大家你们在linux下通常用什么开发语言和工具(C多点还是C++多点还是pascal ?还有工具方面?)
  • LINUX下 C语言编程中 DIR 是做什么用的~?
  • 谁能简单介绍一下LINUX上的各种语言脚本的功能.
  • 什样在linux中学习c语言?
  • linux下的汇编语言的软件是什么?
  • redhat linux中如何卸载语言?
  • 安装Linux,界面一直停留在选择语言的界面
  • Linux启动过程到哪个阶段之后的源代码全是C语言而不是汇编写的?
  • Linux和windows下用mysql c++ library操作Mysql数据库
  • 请问在红旗Linux多功能服务器版上(不是数据库服务器版)能否正常安装使用Oracle?红旗Linux数据库服务器版要比红旗Linux多功能服务器版贵
  • 请问Linux数据库编程是否也可以支持通用的SQL语言进行数据库编写.
  • Linux下Oracle数据库,dbstart持续不动,数据库无法启动解决
  • 请教在linux系统开发环境下,有没有db和dbf数据库引擎,如何使用这个数据库?
  • linux小白提问linux备份oracle数据库的问题
  • 装linux enterprise3 ,没有选择数据库,自行安装了mysql-max-5.0.22-linux-i686,请问
  • Linux不是免费的嘛,怎么在红旗的网站只有桌面版下载?没有server版下载?哪有红旗Linux数据库服务器3.0版下载?
  • 【急……】求助linux数据库相关问题
  • linux下不知有什么小型的数据库?要求速度比较快,开销最小。并且支持单文件数据库及多表的
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Linux c++库boost unordered_set数据插入及查找代码举例
  • linux串口程序可以发送数据,但是不能接受数据?谁知道原因?
  • Linux c++库boost unordered_map数据插入及查找代码举例
  • 急,请问数据流是经过zip压缩的,Linux下如何编程,解开压缩的数据流?
  • 强人,linux下驱动相关数据结构和usb设备数据结构之间的功能分析
  • 在安装Linux时,如果未给/usr挂载磁盘分区,那往/usr里写数据时,数据保存在哪儿啊?
  • linux下已经从摄像头采集到的数据,如何将这些数据播放成视频呢?????
  • linux下用libpcap库函数抓包,如何判断捕获的数据包是IP数据包还是非IP数据包,顺便说一下、捕获的数据包除了IP数据包之外,还有那些种类,非常感谢!!!
  • linux中的串口通信判断一帧数据是否传输完整时,用定时器检查前后两帧数据的间隔时间,该用什么定时函数,有详细代码最好,谢谢!
  • linux转发数据,局域网A(eth1)的数据是如何发送到另一个网卡eth0所在的网络上的,只需要设置FORWARD的ACCEPT吗?
  • {高分200分}jsp访问linux上的mysql数据库,取到和插入的数据全是乱码,我是这样设置的???
  • Linux下访问MYSQL数据库中数据时出现乱码问题
  • 如何在Linux的shell中先删除数据库再创建数据库
  • linux下还有数据没有recv完,能send数据吗?
  • 如何做linux下的数据存储文件如何做?
  • 求教,Linux下键盘输入的所有数据都会经过Linux内核吗???
  • linux下的数据可视化工具 OpenDX
  • linux串口读取数据的问题,select
  • 如何恢复被linux覆盖的原Windows下数据?
  • 如何在UNIX/LINUX下实现数据包拦截?
  • linux 中数据怎样图像显示?
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3