c语言selectinto
我曾经写过C语言的数据库系统..
给你部分代码(一个销售函数)以作参考...
void
book_out()
//销售函数
{
char
temp;
EXEC
sql
BEGIN
DECLARE
SECTION;
/*主变量定义开始.*/
int
Hout_shuliang;
int
Hshuliang;///////////
char
Hbook_id[11];
EXEC
SQL
END
DECLARE
SECTION;
/*主变量定义结束*/
lab3:
printf("请输入图书编号:");
scanf("%s",&Hbook_id);
printf("请输入卖出本数:");
scanf("%d",&Hout_shuliang);
//先将库存量取出到主变量
EXEC
SQL
select
book_shuliang
into
:Hshuliang
from
book_kucun
where
book_id=:Hbook_id;
if(Hshuliang<Hout_shuliang)
//假如库存不足,销售不成功.
{
printf("输入有误.没那么多库存,请重新输入.\n");
goto
lab3;
}
//将销售记录插入到book_out(销售表)数据表.
EXEC
SQL
insert
into
book_out
values(:Hbook_id,:Hout_shuliang,GETDATE());
EXEC
SQL
COMMIT
TRANSACTION;
/*事务提交*/
printf("售出成功,输入Y继续输入其他要售出的书.其他键返回主菜单:");
getchar();//////////////////////////
scanf("%c",&temp);
if(temp=='y'||temp=='Y')
goto
lab3;
}
② c程序该怎么样调用oracle存储过程并获取存储过程中的输出参数的值
我以前这样用pro*c 这样玩的,仅供参考
EXEC SQL EXECUTE
DECLARE
lsid varchar2(60);
lss_this_error_code number;
BEGIN
proctest(:ls_name,lsid); --ls_name 输入参数 lss_id 输出
:chId := lsid;-- lsid 输出返回给C变量chId
END;
END-EXEC;
③ C语言如何调用SQLite3中的接口
下载 sqlite3 库,放在项目文件夹中,包含 sqlite3.h 头文件,包含 sqlite3.lib 导入库,将 sqlite3.dll 复制到 .exe 所在目录。
代码如下:
#include<stdio.h>
#include<stdlib.h>
//包含sqlite3头文件
#include"../sqlite-3.24.0/include/sqlite3.h"
//添加sqlite3lib库
#pragmacomment(lib,"../sqlite-3.24.0/x86/sqlite3.lib")
inttable_exist_callback(void*data,intargc,char**argv,char**azColName)
{
intval=atoi(argv[0]);
if(val==0){
return-1;
}
return0;
}
intprint_callback(void*data,intargc,char**argv,char**azColName)
{
for(inti=0;i<argc;i++){
printf("%s=%s ",azColName[i],argv[i]);
}
printf(" ");
return0;
}
intmain()
{
sqlite3*db=NULL;
char*sql=NULL;
char*errMsg=NULL;
//打开数据库
intret=sqlite3_open("data.db",&db);
if(ret!=SQLITE_OK){
printf("打开数据失败,%s ",sqlite3_errmsg(db));
exit(-1);
}
//判断students是否存在,如果不存在,则创建表students
sql="selectcount(*)fromsqlite_masterwheretype='table'andname='students';";
ret=sqlite3_exec(db,sql,table_exist_callback,NULL,NULL);
if(ret!=SQLITE_OK){
//创建students表
sql="createtablestudents(numbervarchar(10),namevarchar(20),ageinteger);";
ret=sqlite3_exec(db,sql,NULL,NULL,&errMsg);
if(ret!=SQLITE_OK){
printf("创建表失败,%s. ",errMsg);
sqlite3_close(db);
sqlite3_free(errMsg);
exit(-1);
}
}
//插入数据到students表
sql="insertintostudents(number,name,age)values('100001','Barry',23);"
"insertintostudents(number,name,age)values('100002','Oliver',33);";
ret=sqlite3_exec(db,sql,NULL,NULL,&errMsg);
if(ret!=SQLITE_OK){
printf("插入表数据失败,%s. ",errMsg);
sqlite3_close(db);
sqlite3_free(errMsg);
exit(-1);
}
//查询students表数据
sql="select*fromstudents";
ret=sqlite3_exec(db,sql,print_callback,NULL,&errMsg);
if(ret!=SQLITE_OK){
printf("查询数据失败,%s. ",errMsg);
sqlite3_close(db);
sqlite3_free(errMsg);
exit(-1);
}
//关闭数据库
sqlite3_close(db);
system("pause");
return0;
}
项目源码:网页链接
④ c连接oracle数据库的连接语句
连接代码如下:
int main()
{
EXEC SQL BEGIN DECLARE SECTION;
char oc_passwd[101]; /*数据库密码*/
char oc_userid[101]; /*数据库用户名*/
char oc_dbname[101]; /*数据库名*/
char oc_coad[101];
EXEC SQL END DECLARE SECTION;
memset(oc_passwd, 0x00, sizeof(oc_passwd));
memset(oc_userid, 0x00, sizeof(oc_userid));
memset(oc_dbname, 0x00, sizeof(oc_dbname));
/*取数据库用户名*/
strcpy(oc_userid, "userid");
/*取数据库用户密码*/
strcpy(oc_passwd, "passwd") ;
/*取数据库名*/
strcpy(oc_dbname, "dbname");
EXEC SQL CONNECT :oc_userid
IDENTIFIED BY :oc_passwd
USING :oc_dbname;
if (sqlca.sqlcode != 0)
{
printf("用户名[%s]密码[%s]数据库[%s]\n", oc_userid, oc_passwd, oc_dbname);
printf("连接数据库失败,sqlcode=%d\n", sqlca.sqlcode);
return -1;
}
/*读table取coad字段*/
memset(oc_coad, 0x00, sizeof(oc_coad));
EXEC SQL SELECT coad
INTO :oc_coad
FROM table
WHERE 1=1;
if (sqlca.sqlcode == NORECORD)
{
printf("查询无记录\n");
return -1;
}
else if (sqlca.sqlcode != 0)
{
printf("查询失败,sqlcode=%d\n", sqlca.sqlcode);
return -1;
}
return 0;
}
⑤ C语言中嵌套sql语句 $select user_name into :user_name from test where student_id = 1; test如何设置
一般情况应该不是支持这种写法的。
可以采用动态SQL,利用游标语句,可以实现
⑥ 嵌入SQL的C语言程序 怎么接收insert into 的返回值
select @@identity
⑦ 谁有2009年江西省计算机二级考试题目与答案还有2010年的
兄弟,你问题补充下吧,你是学那一门先啊。
有C语言,有JAVA 好多种的。
不知道你的二级是哪一类的 以下是VFP的:
2009年3月全国计算机等级考试二级笔试试卷
Visual FoxPro 数据库程序设计
(考试时间90分钟,满分100分)
选择题
(1)下列叙述中正确的是
A) 栈是“先进先出”的线性表
B) 队列是“先进先出”的线性表
C) 循环队列是非线性结构
D) 有序性表既可以采用顺序存储结构,也可以采用链式存储结构
(2)支持子程序调用的数据结构是
A) 栈 B) 树 C) 队列 D)二叉树
(3)某二叉树有5个度为2的结点,则该二叉树中的叶子结点数是
A)10 B)8 C)6 D)4
(4)下列排序方法中,最坏情况下比较次数最少的是
A)冒泡排序 B)简单选择排序 C)直接插入排序 D)堆排序
(5)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是
A)编译软件 B)操作系统 C)教务管理系统 D)汇编程序
(6)下面叙述中错误的是
A)软件测试的目的是发现错误并改正错误
B)对被调试的程序进行“错误定位”是程序调试的必要步骤
C)程序调试通常也称为Debug
D)软件测试应严格执行测试计划,排除测试的随意性
(7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是
A)提高耦合性降低内聚性有利于提高模块的独立性
B)降低耦合性提高内聚性有利于提高模块的独立性
C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度
D)内聚性是指模块间互相连接的紧密程度
(8)数据库应用系统中的核心问题是
A)数据库设计 B)数据库系统设计
C)数据库维护 D) 数据库管理员培训
(9)有两个关系R,S如下:
R S
A B C A B
a 3 2 a 3
b 0 1 b 0
c 2 1 c 2
由关系R通过运算得到关系S,则所使用的运算为
A) 选择 B)投影 C) 插入 D)连接
(10)将E-R图转换为关系模式时,实体和联系都可以表示为
A) 属性 B)键 C) 关系 D) 域
(11)数据库(DB)、数据库系统(DBS)和数据库管理系统(DBMS)三者之间的关系是
A)DBS包括DB和DBMS B)DBMS包括DB和DBS
C)DB包括DBS和DBMS D)DBS就是DB,也就是DBMS
(12)SQL语言的查询语句是
A)INSERT B)UPDATE C)DELETE D)SELECT
(13)下列与修改表结构相关的命令是
A)INSERT B)ALTER C)UPDATE D)CREATE
(14)对表SC(学号 C(8),课程号 C(2),成绩 N(3),备注 C(20)),可以插入的记录是
A)('20080101', 'c1', '90',NULL) B)('20080101', 'c1', 90, '成绩优秀')
C)('20080101', 'c1', '90', '成绩优秀') D)('20080101', 'c1', '79', '成绩优秀')
(15)在表单中为表格控件指定数据源的属性是
A)DataSource B)DateFrom C)RecordSource D)RecordFrom
(16)在Visual FoxPro中,下列关于SQL表定义语句(CREATE TABLE)的说法中错误的是
A)可以定义一个新的基本表结构
B)可以定义表中的主关键字
C)可以定义表的域完整性、有效性规则等信息的设置
D)对自由表,同样可以实现其完整性、有效性规则等信息的设置
(17)在Visual FoxPro中,若所建立索引的字段值不允许重复,并且一个表中只能创建一个,这种索引应该是
A)主索引 B)唯一索引 C)候选索引 D)普通索引
(18)在Visual FoxPro中,用于建立或修改程序文件的命令是
A)MODIFY<文件名> B)MODIFY COMMAND <文件名>
C)MODIFY PROCEDURE <文件名> D)上面B和C都对
(19)在Visual FoxPro中,程序中不需要用PUBLIC等命令明确申明和建立,可直接使用的内存变量是
A)局部变量 B)私有变量 C)公告变量 D)全局变量
(20)以下关于空值(NULL值)叙述正确的是
A)空值等于空字符串 B)空值等同于数值0
C)空值表示字段或变量还没有确定的值 D)Visual FoxPro不支持空值
(21)执行USE sc IN 0命令的结果是
A)选择0号工作区打开sc表
B)选择空闲的最小号的工作区打开sc表
C)选择第1号工作区打开sc
D)显示出错信息
(22)在Visual FoxPro中,关系数据库管理系统所管理的关系是
A)一个DBF文件 B)若干个二维表
C)一个DBC文件 D)若干个DBC文件
(23)在Visual FoxPro中,下面描述正确的是
A)数据库表允许对字段设置默认值
B)自由表允许对字段设置默认值
C)自由表或数据库表都允许对字段设置默认值
D)自由表或数据库表都不允许对字段设置默认值
(24)SQL的SELECT语句中,“HAVING<条件表达式>”用来筛选满足条件的
A)列 B)行 C)关系 D)分组
(25)在Visual FoxPro中,假设表单上有一个选项组:O男 O女,初始时该选项组的value属性值为1。若选项按钮“女”被选中,该选项组的value属性值是
A)1 B)2 C)“女” D)“男”
(26)在Visual FoxPro中,假设教师表T(教师号,姓名,性别,职称,研究生导师)中,性别是C型字段,研究生导师是L型字段。若要查询“是研究生导师的女老师”信息,那么SQL语句“SELECT * FROM T WHERE <逻辑表达式>”中的<逻辑表达式>应是
A)研究生导师 AND 性别= "女" B)研究生导师 OR 性别= "女"
C)性别= "女" AND 研究生导师=.F. D)研究生导师=.T. OR 性别=女
(27)在Visual FoxPro中,有如下程序,函数IIF()返回值是
*程序
PRIVATE X,Y
STORE "男" TO X
Y=LEN(X)+2
?IIF(Y<4, "男", "女")
RETURN
A)"女" B)"男" C).T. D).F.
(28)在Visual FoxPro 中,每一个工作区中最多能打开数据库表的数量是
A)1个 B)2个
C)任意个,根据内存资源而确定 D)35535个
(29)在Visual FoxPro 中,有关参照完整性的删除规则正确的描述是
A)如果删除规则选择的是"限制",则当用户删除父表中的记录时,系统将自动删除子表中的所有相关记录
B)如果删除规则选择的是"级联",则当用户删除父表中的记录时,系统将禁止删除与子表相关的父表中的记录
C)如果删除规则选择的是"忽略",则当用户删除父表中的记录时,系统不负责检查子表中是否有相关记录
D)上面三种说法都不对
(30)在Visual FoxPro中,报表的数据源不包括
A)视图 B)自由表 C)查询 D)文本文件
第(31)到第(35)题基于学生表S和学生选课表SC两个数据库表,它们的结构如下:
S(学号,姓名,性别,年龄)其中学号、姓名和性别为 C型字段,年龄为N型字段。
SC(学号,课程号,成绩),其中学号和课程号为C型字段,成绩为N型字段(初始为空值)。
(31)查询学生选修课程成绩小于60分的学号,正确的SQL语句是
A)SELECT DISTINCT 学号 FROM SC WHERE "成绩" <60
B)SELECT DISTINCT 学号 FROM SC WHERE 成绩 < "60"
C)SELECT DISTINCT 学号 FROM SC WHERE 成绩 <60
D)SELECT DISTINCT "学号" FROM SC WHERE "成绩" <60
(32) 查询学生表S的全部记录并存储于临时表文件one中的SQL命令是
A)SELECT * FROM 学生表 INTO CURSOR one
B)SELECT * FROM 学生表TO CURSOR one
C)SELECT * FROM 学生表 INTO CURSOR DBF one
D)SELECT * FROM 学生表TO CURSOR DBF one
(33)查询成绩在70分至85分之间学生的学号、课程号和成绩,正确的SQL语句是
A)SELECT 学号,课程号,成绩 FROM sc WHERE 成绩 BETWEEN 70 AND 85
B)SELECT 学号,课程号,成绩 FROM sc WHERE 成绩 >=70 OR 成绩 <=85
C)SELECT 学号,课程号,成绩 FROM sc WHERE 成绩 >=70 OR <=85
D)SELECT 学号,课程号,成绩 FROM sc WHERE 成绩 >=70 AND <=85
(34)查询有选课记录,但没有考试成绩的学生的学号和课程号,正确的SQL语句是
A)SELECT 学号,课程号 FROM sc WHERE 成绩 = ""
B)SELECT 学号,课程号 FROM sc WHERE 成绩 = NULL
C)SELECT 学号,课程号 FROM sc WHERE 成绩 IS NULL
D)SELECT 学号,课程号 FROM sc WHERE 成绩
(35)查询选修C2课程号的学生姓名,下列SQL语句中错误的是
A)SELECT 姓名 FROM S WHERE EXISTS;
(SELECT * FROM SC WHERE 学号=S.学号 AND 课程号= 'C2')
B)SELECT 姓名 FROM S WHERE 学号 IN;
(SELECT * FROM SC WHERE课程号= 'C2')
C)SELECT 姓名 FROM S JOIN ON S.学号=SC.学号 WHERE 课程号= 'C2'
D)SELECT 姓名 FROM S WHERE 学号=;
(SELECT * FROM SC WHERE课程号= 'C2')
二、填空题(每空2分,共30分)
请将每一个空的正确答案写在答题纸上【1】-【15】序号的横线上,答在试卷上,在试卷上不得分,
注意:以命令关键字填空的必须写完整。
(1)假设一个长度为50的数组(数组元素的下标从0到49)作为栈的存储空间,栈底指针bottom指向栈底元素,栈顶指针top指向栈顶元素,如果bottom=49,top=30(数组下标),则栈中具有 【1】 个元素。
(2)软件测试可分为白盒测试和黑盒测试。基本路径测试属于 【2】 测试。
(3)符合结构化原则的三种基本控制结构是:选择结构、循环结构和 【3】 。
(4)数据库系统的核心是 【4】
(5)在E-R图中,图形包括矩形框、菱形框、椭圆框。其中表示实体联系的是 【5 】框。
(6)所谓自由表就是那些不属于若任何【6】的表。
(7)常量{^2009-10-01,15:30:00}的数据类型是【7】 。
(8)利用SQL语句的定义功能建立一个课程表,并且为课程号建立主索引,语句格式为:
CREATE TABLE 课程表(课程号 C(5) 【8】 ,课程名 C(30))
(9)在Visual FoxPro中,程序文件的扩展名是【9】 。
(10)在Visual FoxPro中,SEELCT 语句能够实现投影、选择和【10】三种专门的关系运算。
(11)在Visual FoxPro中,LOCATE ALL 命令按条件对某个表中的记录进行查找,若查找不到满足条件的记录,函数EOF()的返回值应是【11】 。
(12)在Visual FoxPro中,设有一个学生表STUDENT,其中有学号、姓名、年龄、性别等字段,用户可以用命令“ 【12】 年龄 WITH 年龄+1”将表中所有学生的年龄增加一岁。
(13)在Visual FoxPro中,有如下程序:
*程序名:TEST.PRG
SET TALK OFF
PRIVATE X,Y
X= "数据库"
Y= "管理系统"
DO sub1
?X+Y
RETURN
*子程序:sub1
LOCAL X
X= "应用"
Y= "系统"
X= X+Y
RETURN
执行命令DO TEST后,屏幕显示的结果应是【13】 。
(14)使用SQL语言的SELECT语句进行分组查询时,如果希望去掉不满足条件的分组,应当在GROUP BY 中使用【14】子句。
(15)设有SC(学号,课程号,成绩)表,下面 SQL的SELECT语句检索成绩高于或等于平均成绩的学生的学号。
SELECT 学号 FROM sc;
WHERE 成绩>=(SELECT 【15】 FROM sc)
2009年4月二级VFP参考答案
一、选择题
1-5 DDCDC
6-10 ABAAC
11-15 ADBBC
16-20 DABBC
21-25 BBADB
26-30 AAACD
31-35 CAACD
二、填空题
1、20
2、白盒
3、顺序结构
4、数据库管理系统
5、菱形
6、数据库
7、日期时间型
8、primary key
9、.prg
10、联接
11、.T.
12、Replace all
13、数据库系统
14、Having
15、avg(成绩)
⑧ 怎样运行C语言和Postgres编写的嵌入SQL
嗯,正好,我这两天也在整这个,回答下啊。
1、把这个文件存为test.pgc
2、在linux下面运行:ecpg test.pgc -o test.c(ecpg似乎也可以在windows下安装,本行意思是将.pgc文件预编译为真正的c程序)。
3、在linux下面运行:gcc test.c -o test -l ecpg
4、./test就可以出结果了
5、上述所有的命令都必须在test.pgc这个文件所在的文件夹下面运行咯
6、参考书籍:http://www.php100.com/manual/PostgreSQL8