- 浏览: 5029315 次
- 性别:
- 来自: 南京
文章分类
- 全部博客 (2844)
- java (1094)
- hadoop (37)
- jvm (39)
- hbase (11)
- sql (25)
- 异常 (83)
- div css (6)
- 数据库 (95)
- 有趣的code (15)
- struts2 (6)
- spring (124)
- js (44)
- 算法 (65)
- linux (36)
- hibernate (7)
- 中间件 (78)
- 设计模式 (2)
- 架构 (275)
- 操作系统 (91)
- maven (35)
- tapestry (1)
- mybatis (9)
- MQ (101)
- zookeeper (18)
- 搜索引擎,爬虫 (208)
- 分布式计算 (45)
- c# (7)
- 抓包 (28)
- 开源框架 (45)
- 虚拟化 (12)
- mongodb (15)
- 计算机网络 (2)
- 缓存 (97)
- memcached (6)
- 分布式存储 (13)
- scala (5)
- 分词器 (24)
- spark (104)
- 工具 (23)
- netty (5)
- Mahout (6)
- neo4j (6)
- dubbo (36)
- canal (3)
- Hive (10)
- Vert.x (3)
- docker (115)
- 分布式追踪 (2)
- spring boot (5)
- 微服务 (56)
- 淘客 (5)
- mesos (67)
- php (3)
- etcd (2)
- jenkins (4)
- nginx (7)
- 区块链 (1)
- Kubernetes (92)
- 驾照 (1)
- 深度学习 (15)
- JGroups (1)
- 安全 (5)
- 测试 (16)
- 股票 (1)
- Android (2)
- 房产 (1)
- 运维 (6)
- 网关 (3)
最新评论
-
明兜3号:
部署落地+业务迁移 玩转k8s进阶与企业级实践技能(又名:Ku ...
Kubernetes系统常见运维技巧 -
q328965539:
牛掰啊 资料收集的很全面
HDFS小文件处理解决方案总结+facebook(HayStack) + 淘宝(TFS) -
guichou:
fluent挂载了/var/lib/kubelet/pods目 ...
kubernetes上部署Fluentd+Elasticsearch+kibana日志收集系统 -
xu982604405:
System.setProperty("java.r ...
jmx rmi 穿越防火墙问题及jmxmp的替代方案 -
大漠小帆:
麻烦问下,“获取每个Item相似性最高的前N个Item”,这个 ...
协同过滤推荐算法在MapReduce与Spark上实现对比
- 这种方法可以执行包括查询语句在内的动态SQL语句, 但它要求在预编译时刻动态SQL语句内选择列表项数,输入宿主变量占位符数据以及输入宿主变量的数据类型必须确定。 方法三以游标方式执行动态SQL语句, 它对SQL语句的处理过程为:
- ①. 准执行PREPARE命令准备SQL语句;
- #实际就是把要执行的动态语句调入内存, 以
- 便以后对它进行操作。
- ②. 执行DECLARE命令声明游标;
- ③. 执行OPEN打开游标;
- ④. 调用FETCH语句提取游标;
- ⑤. 调用CLOSE语句关闭游标。
- 动态SQL语句中的数据库对象名称和列名可以在运行时刻指定, 便此时不能以宿主变量形式指定对象名称或列名.
- 其实就是多了一个游标的使用。
- 如下面程序:
- <连接数据库>;
- strcpy(sql_stmt, "SELECT name, address, sex FROM test001");
- EXEC SQL PREPARE select_stmt FROM :sql_stmt;
- EXEC SQL DECLARE c1 CURSOR FOR select_stmt;
- EXEC SQL OPEN c1;
- EXEC SQL WHENEVER NOT FOUND DO BREAK;
- while(1)
- Oracle Pro*C 编程入门
- {
- EXEC SQL FETCH c1 INTO :Name, :address, :sex;
- printf("The name is: %s, The Address is: %s, The sex is :%s\n", Name, address,
- sex);
- }
- EXEC SQL CLOSE c1;
-
#include <stdio.h> #include <string.h> #include <stdlib.h> #include <sqlca.h> void connect(); void sql_err(); void dynamic_sqlthree(); void main() { EXEC SQL WHENEVER SQLERROR DO sql_err(); connect(); dynamic_sqlthree(); EXEC SQL COMMIT RELEASE; } void sql_err() { //printf("%.*s\n",sqlca.sqlerrm.sqlerrml,,sqlca.sqlerrm.sqlerrmc); } void connect()/*数据库连接-本地数据库,不添加server*/ { EXEC SQL BEGIN DECLARE SECTION; VARCHAR oraCN[30]; EXEC SQL END DECLARE SECTION; strcpy(oraCN.arr,"scott/Tiger@TEST_dist"); EXEC SQL CONNECT :oraCN; } void dynamic_sqlthree() { EXEC SQL BEGIN DECLARE SECTION; char name[10]; int salary; int dno; EXEC SQL END DECLARE SECTION; printf("input deptno u want to view: "); scanf("%d",&dno); getchar(); EXEC SQL PREPARE stat FROM 'SELECT sal,ename from emp WHERE deptno=:a'; EXEC SQL DECLARE emp_cursor CURSOR FOR stat; EXEC SQL OPEN emp_cursor USING :dno; EXEC SQL WHENEVER NOT FOUND DO break; for(;;) { EXEC SQL FETCH emp_cursor INTO :salary,:name; printf("name: %s,salary: %d\n",name,salary); } EXEC SQL CLOSE emp_cursor; }
发表评论
-
MyBatis 使用 MyCat 实现多租户的一种简单思路
2017-11-20 18:27 2836本文的多租户是基于多数据库进行实现的,数据是通过不同数据库进 ... -
Otter(一)初识----简介和基本架构图
2017-10-11 11:23 1273tter 初识----简介和基本架构图 ... -
Canal+Otter - 前日篇(1)
2017-10-11 11:21 1193数据库同步中间件Canal+Otter - 前日篇(1) ... -
Otter-入门篇1(阿里开源项目Otter介绍)
2017-10-11 11:16 944Otter-入门篇1(阿里开源项目Otter介绍) ... -
Mysql几种索引类型的区别及适用情况
2017-09-30 16:27 581如大家所知道的,Mysql目前主要有以下几种索引类型:FUL ... -
唯一索引与主键索引的比较
2017-09-29 10:21 1469唯一索引唯一索引不 ... -
主键索引和唯一索引的区别
2017-09-29 10:05 651-- 区别 主键是一种约束,唯一索引是一种索引,两者 ... -
Index column size too large. The maximum column size is 767 bytes
2017-09-28 18:01 1881Index column size too large. T ... -
数据库死锁分析与解决
2017-08-17 10:00 859一、死锁的表现 1、 ... -
mysql,oracle,sql server中的默认事务隔离级别查看,更改
2017-08-09 13:44 1372未提交读(隔离事务的最低级别,只能保证不读取物理上损坏的 ... -
Mycat跨分片Join
2017-08-02 11:26 8761 前言 Mycat目前版本支持跨分片的join,主要实现 ... -
Mycat 分布式事务的实现
2017-08-02 11:27 1368引言:Mycat已经成为了一个强大的开源分布式数据库 ... -
MyCat部署运行(Windows环境)与使用步骤详解
2017-08-02 10:20 8871、MyCat概念 1.1 总体架构 MyCAT的架 ... -
mycat 分片中快速数据迁移思考
2017-07-31 17:42 867操作实践背景: travelrecord表定义 ... -
Mycat水平拆分之十种分片规则
2017-07-31 16:43 872水平切分分片实现 配置schema.xml ... -
博客分类: DB-oracle sqlOracle 1、方式一:使用序列和触发器 Sql代码 收藏代码 SQL> CREATE SEQUENCE te
2017-07-22 09:01 506sqlOracle 1、方式一:使用 ... -
PL/SQL Developer连接本地Oracle 11g 64位数据库
2017-05-16 22:29 7071.登录PL/SQL Developer 这里省略Ora ... -
分库分表的几种常见形式以及可能遇到的难
2017-04-11 23:33 806在谈论数据库架构和数据库优化的时候,我们经常会听到“分库分表 ... -
MySQL 日志
2017-01-11 20:58 582概述 MySQL日志记录了MySQL服务器的各种行为,My ... -
undo log与redo log原理分析
2016-12-17 21:57 815数据库通常借助日志来 ...
相关推荐
三、Pro*C的动态SQL方法在仿真系统中的应用 在仿真系统中,Pro*C的动态SQL方法可以解决数据处理和存储问题。通过使用Pro*C的动态SQL方法,可以实现对不同数据库的操作,例如数据采集、数据处理、数据分析、数据存储...
1. **高级Pro*C特性**:深入讲解Pro*C的高级特性,如动态SQL、批处理、并发控制等。 2. **性能优化**:介绍如何通过Pro*C优化数据库访问,包括索引策略、查询优化和内存管理。 3. **分布式处理**:探讨如何在Pro*C中...
Oracle Pro*C 是一种集成的开发工具,用于在C语言中嵌入SQL语句,以便高效地与Oracle数据库进行交互。这种技术将C语言的强大功能与SQL的数据库操作能力结合在一起,提供了一种灵活且高性能的方式来构建数据库应用...
1. Pro*C简介:Pro*C是一种将SQL语句嵌入C程序中的开发工具,它允许开发者在C语言中直接使用SQL语句访问Oracle数据库。它是一种第三代语言嵌入式SQL工具,可以在Oracle数据库管理系统中使用。Pro*C程序可以执行...
PRO*C为开发者提供了一种将SQL语句嵌入C语言程序的有效方式,使得开发者可以在保持C语言强大逻辑处理能力的同时,充分利用SQL语言进行高效的数据管理。通过了解PRO*C的基本概念、程序结构以及如何使用SQL语句,...
Pro*C是Oracle公司开发的一种预编译器,它允许程序员在C语言中嵌入PL/SQL代码,使得C程序可以直接与Oracle数据库交互。通过Pro*C,开发者可以利用C语言的强大功能和效率,同时享受Oracle数据库提供的高级数据库操作...
8. **动态SQL**:在Pro*C中,可以使用字符串拼接或者EXEC SQL EXECUTE IMMEDIATE语句执行动态SQL,这在处理灵活的查询需求时非常有用。 9. **存储过程和函数**:学习如何在C/C++中调用Oracle的存储过程和函数,以及...
《Pro*C程序设计ORACLE调用接口》是关于在C语言中使用Oracle数据库的一种高效方法。Pro*C,全称为Pre-Compiler for C,是Oracle公司提供的一个预编译器,它允许开发者直接在C程序中嵌入SQL语句,极大地提高了数据库...
7. **游标和动态SQL**:Pro*C/C++支持游标,可以用来遍历查询结果,也可以用于执行动态SQL。动态SQL允许在运行时构建SQL语句,增加了程序的灵活性。 8. **事务管理**:使用`EXEC SQL BEGIN WORK`、`EXEC SQL COMMIT...
3. **Pro*C编译器**: Pro*C编译器通常位于`$ORACLE_HOME/bin`目录下,名为`proc`。使用`proc`命令可以预编译包含PL/SQL的源代码文件,生成C/C++源代码。 4. **Pro*C语法**: 在Pro*C程序中,使用`EXEC SQL`语句...
PRO*C是Oracle Corporation为C程序员设计的一种工具,它允许在C程序中嵌入SQL语句,使得C语言能够与Oracle数据库无缝集成。 一、PRO*C简介 PRO*C是Oracle数据库的C语言接口,它扩展了C语言,增加了对SQL和PL/SQL的...
在IT领域,PRO*C是Oracle公司提供的一种预编译器,它允许开发人员使用C语言来编写PL/SQL代码,从而更高效地与Oracle数据库进行交互。这个“PRO*C入门实例”可能是针对初学者的一个教程,通过一个实际的代码示例来...
Pro*C/C++ 是一种集成在C或C++编程语言中的预处理器,它允许程序员直接在源代码中嵌入PL/SQL语句,用于与Oracle数据库进行交互。这种编程方式提供了高效且灵活的数据库访问手段,特别适合于开发与Oracle数据库紧密...
Pro*C将C源代码和SQL语句结合在一起,通过预处理器将SQL语句转换为C语言中的函数调用。然后,开发者可以编译这些源代码为动态链接库或静态库,供其他程序(如Java应用)调用。 在Java中调用Pro*C程序通常涉及到以下...
9. **带参动态SQL**:Pro*C允许使用动态SQL来构建和执行在运行时决定的SQL语句,这对于处理参数化查询非常有用。 10. **oci接口**:除了Pro*C,Oracle还提供了Oracle Call Interface (OCI),这是一种更底层的C接口...
Pro*C是Oracle公司提供的一种预编译器,它允许程序员在C语言中直接嵌入SQL语句,从而实现高效的数据库操作。以下是对Pro*C程序设计主要知识点的详细阐述: 1. **Pro*C概述**:Pro*C是C语言的一个扩展,它引入了特殊...
**Pro*C**是一种由Oracle提供的C语言扩展,它允许开发者在C程序中直接嵌入SQL语句,并通过Oracle预编译器将其转换成标准C代码,从而实现数据库操作与业务逻辑的无缝集成。 #### 二、新特性介绍 - **ORACLE 9i ...
Pro*C增删改查Oracle数据库中数据表的代码
Pro*C是Oracle公司提供的一种预编译器,它允许C/C++程序员直接在C或C++代码中嵌入SQL语句,从而实现与Oracle数据库的紧密交互。下面将详细阐述这一配置过程。 **1. 安装必要的组件** 首先,确保已经安装了以下组件...
3. **Pro*C 程序的组成部分** - **应用程序首部**:包含 C 变量描述、SQL 变量描述(DECLARE 部分)和 SQL 通信区。 - **DECLARE 部分**:定义程序中的 SQL 变量,如 VARCHAR、INT、SHORT、LONG、FLOAT、DOUBLE 等...