C语言中嵌入式SQL语句
2011-01-22 21:43
162 查看
实验内容
:
掌握SQL Server 2000
的预编译程序NSQLPREP.EXE
的使用(以课本例题1
进行调试);
实验步骤
:
一、数据库环境配置
1
、创建xuesheng
数据库,建立student
表等;
2
、关闭sql server 2000
服务管理器;
3
、将devtools
文件夹拷贝到:C:/Program Files/Microsoft SQL Server
4
、将Binn
文件夹拷贝到:C:/Program Files/Microsoft SQL Server/MSSQL
5
、启动服务器;
二、VC++6.0
编辑器配置(初始化Vc++
环境)
1.
工具—>
选择—>
目录—>Include Files
添加: C:/Program Files/Microsoft SQL Server/devtools/include
并设为第一项
2.
选择Library Files
添加:C:/Program Files/Microsoft SQL Server/devtools/x86lib
并设为第一项
三、写程序,预编译,最后在VC++
中编译、执行
1
、编辑EXEC.sqc
文件,保存到:C:/Program Files/Microsoft SQL Server/MSSQL/Binn
目录
EXEC.sqc文件如下:
// EXEC.cpp : Defines the entry point for the console application.
//
#include <stdio.h>
#include <stdlib.h>
EXEC SQL BEGIN DECLARE SECTION; /*主变量说明开始*/
char deptname[64];
char HSno[64];
char HSname[64];
char HSsex[64];
int HSage;
int NEWAGE;
long SQLCODE;
EXEC SQL END DECLARE SECTION; /*主变量说明结束*/
EXEC SQL INCLUDE sqlca; /*定义SQL通信区*/
/*************************************************************************/
int main(void) /*C语言主程序开始*/
{
int count = 0;
char yn; /*变量yn代表yes或no*/
printf("Please choose the department name(CS/MA/IS): ");
scanf("%s", deptname); /*为主变量deptname赋值*/
EXEC SQL CONNECT TO demin USER
sa; /*连接数据库TEST*/
EXEC SQL DECLARE SX CURSOR FOR /*定义游标*/
SELECT Sno, Sname, Ssex, Sage /*SX对应语句的执行结果*/
FROM Student
WHERE SDept = :deptname;
EXEC SQL OPEN SX; /*打开游标SX便指向查询结果的第一行*/
for ( ; ; ) /*用循环结构逐条处理结果集中的记录*/
{
EXEC SQL FETCH SX INTO :HSno, :HSname, :HSsex,:HSage;
/*推进游标,将当前数据放入主变量*/
if (sqlca->sqlcode != 0) /* sqlcode != 0,表示操作不成功*/
break; /*利用SQLCA中的状态信息决定何时退出循环*/
if(count++ == 0) /*如果是第一行的话,先打出行头*/
printf("/n%-10s %-20s %-10s %-10s/n", "Sno", "Sname", "Ssex", "Sage");
printf("%-10s %-20s %-10s %-10d/n", HSno, HSname, HSsex, HSage);
/*打印查询结果*/
printf("UPDATE AGE(y/n)?"); /*询问用户是否要更新该学生的年龄*/
do{
scanf("%c",&yn);
}
while(yn != 'N' && yn != 'n' && yn != 'Y' && yn != 'y');
if (yn == 'y' || yn == 'Y') /*如果选择更新操作*/
{
printf("INPUT NEW AGE:");
scanf("%d",&NEWAGE); /*用户输入新年龄到主变量中*/
EXEC SQL UPDATE Student /*嵌入式SQL*/
SET Sage = :NEWAGE
WHERE CURRENT OF SX ;
} /*对当前游标指向的学生年龄进行更新*/
}
EXEC SQL CLOSE SX; /*关闭游标SX不再和查询结果对应*/
EXEC SQL COMMIT WORK; /*提交更新*/
EXEC SQL DISCONNECT TEST; /*断开数据库连接*/
}
2
、使用MS-DOS
进行预编译:
1
)进到Binn
文件下:cd
C:/Program Files/Microsoft SQL Server/MSSQL/Binn
2
)调用预编译程序nsqlprep.exe
程序:nsqlprep EXEC
成功编译完成结果:
见附件1
3
、使用Vc++
进行编译,见附件2
4、
添加库文件:工程—>设置—>Link—>对象/库模块
输入SQLakw32.lib Caw32.lib
两个文件名。附件3
注意,两个文件之间用空格分开。
5
、将动态链接库SQLakw32.dll,sqlaiw32.dll文件拷贝到操作系统目录下的子目录C:/WINDOWS/system32中
6、连接:附件4
7、执行:附件5
:
掌握SQL Server 2000
的预编译程序NSQLPREP.EXE
的使用(以课本例题1
进行调试);
实验步骤
:
一、数据库环境配置
1
、创建xuesheng
数据库,建立student
表等;
2
、关闭sql server 2000
服务管理器;
3
、将devtools
文件夹拷贝到:C:/Program Files/Microsoft SQL Server
4
、将Binn
文件夹拷贝到:C:/Program Files/Microsoft SQL Server/MSSQL
5
、启动服务器;
二、VC++6.0
编辑器配置(初始化Vc++
环境)
1.
工具—>
选择—>
目录—>Include Files
添加: C:/Program Files/Microsoft SQL Server/devtools/include
并设为第一项
2.
选择Library Files
添加:C:/Program Files/Microsoft SQL Server/devtools/x86lib
并设为第一项
三、写程序,预编译,最后在VC++
中编译、执行
1
、编辑EXEC.sqc
文件,保存到:C:/Program Files/Microsoft SQL Server/MSSQL/Binn
目录
EXEC.sqc文件如下:
// EXEC.cpp : Defines the entry point for the console application.
//
#include <stdio.h>
#include <stdlib.h>
EXEC SQL BEGIN DECLARE SECTION; /*主变量说明开始*/
char deptname[64];
char HSno[64];
char HSname[64];
char HSsex[64];
int HSage;
int NEWAGE;
long SQLCODE;
EXEC SQL END DECLARE SECTION; /*主变量说明结束*/
EXEC SQL INCLUDE sqlca; /*定义SQL通信区*/
/*************************************************************************/
int main(void) /*C语言主程序开始*/
{
int count = 0;
char yn; /*变量yn代表yes或no*/
printf("Please choose the department name(CS/MA/IS): ");
scanf("%s", deptname); /*为主变量deptname赋值*/
EXEC SQL CONNECT TO demin USER
sa; /*连接数据库TEST*/
EXEC SQL DECLARE SX CURSOR FOR /*定义游标*/
SELECT Sno, Sname, Ssex, Sage /*SX对应语句的执行结果*/
FROM Student
WHERE SDept = :deptname;
EXEC SQL OPEN SX; /*打开游标SX便指向查询结果的第一行*/
for ( ; ; ) /*用循环结构逐条处理结果集中的记录*/
{
EXEC SQL FETCH SX INTO :HSno, :HSname, :HSsex,:HSage;
/*推进游标,将当前数据放入主变量*/
if (sqlca->sqlcode != 0) /* sqlcode != 0,表示操作不成功*/
break; /*利用SQLCA中的状态信息决定何时退出循环*/
if(count++ == 0) /*如果是第一行的话,先打出行头*/
printf("/n%-10s %-20s %-10s %-10s/n", "Sno", "Sname", "Ssex", "Sage");
printf("%-10s %-20s %-10s %-10d/n", HSno, HSname, HSsex, HSage);
/*打印查询结果*/
printf("UPDATE AGE(y/n)?"); /*询问用户是否要更新该学生的年龄*/
do{
scanf("%c",&yn);
}
while(yn != 'N' && yn != 'n' && yn != 'Y' && yn != 'y');
if (yn == 'y' || yn == 'Y') /*如果选择更新操作*/
{
printf("INPUT NEW AGE:");
scanf("%d",&NEWAGE); /*用户输入新年龄到主变量中*/
EXEC SQL UPDATE Student /*嵌入式SQL*/
SET Sage = :NEWAGE
WHERE CURRENT OF SX ;
} /*对当前游标指向的学生年龄进行更新*/
}
EXEC SQL CLOSE SX; /*关闭游标SX不再和查询结果对应*/
EXEC SQL COMMIT WORK; /*提交更新*/
EXEC SQL DISCONNECT TEST; /*断开数据库连接*/
}
2
、使用MS-DOS
进行预编译:
1
)进到Binn
文件下:cd
C:/Program Files/Microsoft SQL Server/MSSQL/Binn
2
)调用预编译程序nsqlprep.exe
程序:nsqlprep EXEC
成功编译完成结果:
见附件1
3
、使用Vc++
进行编译,见附件2
4、
添加库文件:工程—>设置—>Link—>对象/库模块
输入SQLakw32.lib Caw32.lib
两个文件名。附件3
注意,两个文件之间用空格分开。
5
、将动态链接库SQLakw32.dll,sqlaiw32.dll文件拷贝到操作系统目录下的子目录C:/WINDOWS/system32中
6、连接:附件4
7、执行:附件5
相关文章推荐
- C语言中嵌入式SQL语句
- 【转载】C语言中嵌入式SQL语句
- C语言中嵌入式SQL语句
- C语言中嵌入式SQL语句
- PROC是ORACEL提供的编程接口之一,将过程化的C语言与非过程化的SQL语句结合,PROC连ORACLE小例子。
- [Sqlite] 移动嵌入式数据库Sqlite的日常SQL操作语句汇总
- [代码实例][C语言][sqlite3]用SQL语句查询数据库的实例
- 使用C语言访问MySQL数据 —— 执行SQL语句(1)
- Proc *C/C++入门之常用嵌入式SQL语句
- 支持SQL语句的嵌入式数据库:SQLite
- 让你提前认识软件开发(20):如何在C语言里面执行SQL语句?
- T-SQL是否有循环语句?类似C语言的for?如何查看有哪些用户连接到服务器上?如何强制其退出?
- 【PB】在PB中嵌入式sql语句"in"的用法
- 如何在C语言里面执行SQL语句?
- 使用C语言访问MySQL数据 —— 执行SQL语句(2)
- [代码实例][C语言][sqlite3]用SQL语句查询数据库的实例
- PB中嵌入式SQL语句技巧1
- 嵌入式SQL应用(C语言)
- 使用C语言访问MySQL数据 —— 执行SQL语句(3)
- [Sqlite] 移动嵌入式数据库Sqlite日报SQL操作语句汇总