免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 1942 | 回复: 11
打印 上一主题 下一主题

求pro*c的一个方法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-01-15 11:30 |只看该作者 |倒序浏览
输入一条sql查询语句select ……
然后这个方法执行这条语句并输出结果,
pro*c能做到吗?

论坛徽章:
0
2 [报告]
发表于 2007-01-15 12:51 |只看该作者
定义一堆host variable,然后把select出来的东西存进去,然后printf,就可以了

论坛徽章:
0
3 [报告]
发表于 2007-01-15 13:03 |只看该作者
当然可以做到了,你最好是争对那些常用的,固定的表去这样做,传出来的是一个表结构的内存集合,用来再free掉

论坛徽章:
0
4 [报告]
发表于 2007-01-15 13:06 |只看该作者
dynamic SQL

论坛徽章:
0
5 [报告]
发表于 2007-01-15 13:14 |只看该作者
当然能了

论坛徽章:
0
6 [报告]
发表于 2007-01-15 14:31 |只看该作者
数据库提供的嵌入式开发

论坛徽章:
0
7 [报告]
发表于 2007-01-15 18:35 |只看该作者
谢谢各位, 我这里有个小例子,用 c 可以编译通过,用c++就不行了。
proc 3testproc.pc  CODE=CPP 用C++编译不通过。
proc 3testproc.pc 可以通过

问题是我这里的程序是C++的,郁闷。

各位有什么好办法么?

程序如下:
#include <sqlca.h>

int main()
{

     EXEC SQL BEGIN DECLARE SECTION;
             VARCHAR user[20],pass[20],tnsname[20];
             char C_COMPANYNAME[100];
             char C_TELEPHONE[50];
             char C_FAX[50];
             char C_CONTACT[20];
             EXEC SQL VAR C_COMPANYNAME IS STRING(100);
             EXEC SQL VAR C_TELEPHONE IS STRING(50);
             EXEC SQL VAR C_FAX IS STRING(50);
             EXEC SQL VAR C_CONTACT IS STRING(20);
     EXEC SQL END DECLARE SECTION;
     
     char c_sql[200];
     int id = 20;
     strcpy(user.arr,"user");
     user.len=(unsigned short)strlen((char *)user.arr);
     strcpy(pass.arr,"pass");
     pass.len=(unsigned short)strlen((char *)pass.arr);
     strcpy(tnsname.arr,"host");
     tnsname.len=(unsigned short)strlen((char *)tnsname.arr);
     
     EXEC SQL CONNECT :user IDENTIFIED BY :pass USING :tnsname;
     
                 EXEC SQL DECLARE csr CURSOR FOR
                 SELECT COMPANYNAME, TELEPHONE, FAX, CONTACT FROM USER WHERE ID < :id;
                 EXEC SQL open csr;
                 EXEC SQL WHENEVER NOT FOUND DO break;
                 
                 while(1) {
                                EXEC SQL FETCH csr INTO :C_COMPANYNAME, :C_TELEPHONE, :C_FAX, :C_CONTACT;

                                if( sqlca.sqlcode == 1403) {
                                        break;
                                }
                                printf("the COMPANYNAME is %s \n",C_COMPANYNAME);
                          printf("the TELEPHONE is %s \n",C_TELEPHONE);
                          printf("the FAX is %s \n",C_FAX);
                          printf("the CONTACT is %s \n",C_CONTACT);
                          printf("==================================================\n");
                 }
                 
                 EXEC SQL CLOSE csr;
     EXEC SQL commit work release;
}

论坛徽章:
0
8 [报告]
发表于 2007-01-15 18:50 |只看该作者
先预编译一下就可以啦

论坛徽章:
0
9 [报告]
发表于 2007-01-15 19:01 |只看该作者
动态方法4可以实现

论坛徽章:
0
10 [报告]
发表于 2007-01-16 09:14 |只看该作者
wyaccent 如何预编译呀?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP