Proc *C/C++入门之常用嵌入式SQL语句

事务控制语句

Commit, rollback and savepoint.
EXEC SQL commit;
EXEC SQL commit work release;
EXEC SQL rollback work release;

数据定义语句(DDL)

create, alter, drop
EXEC SQL CREAT TABLE t1(cola int);
EXEC SQL DROP TABLE t1;
EXEC SQL ALTER TABLE t1 add(faxno number);

注意:对象名, 列名不能用宿主变量.`

自动提交事务

Alter: alter table emp add( faxno number );
Analyze: analyze table 

数据操作语句(DML)

EXEC SQL Select …….;
EXEC SQL Insert …….;
EXEC SQL update …….;
EXEC SQL Delete …….;

用单个变量操作单行单列

char ename[35];
int empno=20;
EXEC SQL select emp_name INTO :ename from emp 
where emp_no=:empno;
cout<<“the name is “<< ename;

注意:

字符串长度定义
指示变量的运用

用多个变量操作单行多列

变量顺序与字段名一至

char v_name[31], char v_job[21];
float v_salary;
int empno=20;
EXEC SQL select emp_name,job,salary
INTO :v_name,:v_job,:v_salary
FROM emp 
WHERE emp_no=:empno;
cout<<v_name<< v_job<<v_salary;

用结构(struct )操作单行多列

宿主结构是指包含多个宿主变量的C语言结构,以此可简化单行多列操作。

Struct{
    int no;
    char    name[10];
    int salary;
}emp_record;

输入:
EXEC SQL INSERT INTO emp(empno,ename,sal) VALUES (:emp_record);
输出:
EXEC SQL SELECT empno,ename,sal INTO :emp_record WHERE rownum=1;

注意:

1.可用结构pointer,但要分配空间。
2.结构成员的数据类型,顺序必须与SQL语句一至。
3.不能用嵌套的结构。
4.不能用C联合(UNION)

Struct{
    int no;
    char    name[10];
    int salary;
}*emp_record;
emp_record = (struct emp_record *)malloc(sizeof(struct emp_record ));
EXEC SQL SELECT empno,ename,sal INTO :emp_record
            WHERE rownum=1;

用数组(array)操作多行多列

为了降低网络开销,提高程序性能。

  • 数组和 INSERT 语句
int num[100]; float salary[100]; char name[100][25];
/** 在此为ARRAY赋值 **/
EXEC SQL INSERT INTO emp(empno,ename,sal) VALUES (:num, :name, :salary);
  • 数组和 UPDATE / DELETE 语句
Char name[100]; float salary[100];
…….. /** 在此为ARRAY赋值 **/
EXEC SQL UPDATE EMP SET sal=:salary WHERE ename=:name;
Char name[100];
…….. /** 在此为ARRAY赋值 **/
EXEC SQL DELETE FROM emp WHERE ename=:name;
  • 数组和 SELECT 语句
Char name[100][25];
EXEC SQL SELECT ename INTO :name FROM emp
        WHERE dept_num=2;
For(int j=0;j<sqlca.sqlerrd[2];j++) 
    cout<<“Emp_name”<<name[j]<<endl;

注意事项:

1.只有CHAR 和 ARCHAR 可为二维数组。
2.如数组INDEX不同,按最小操作。
3.在SELECT语句的WHERE子句中,不能用数组。
4.数组元素最大值:32767

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值