您的位置:首页 > 编程语言 > C语言/C++

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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息