C语言中嵌入式SQL语句

实验内容

掌握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

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值