http://blog.csdn.net/cnlht/archive/2007/12/12/1930960.aspx原文地址
实验内容:
掌握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文件如下:
    #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 HP-08D6CXF128B\SQL2000 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:

