【转载】C语言中嵌入式SQL语句

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:

6c0f946an97bf850e4643&6906c0f946an97bf85b0bacf&690   

 

 

 

 

6c0f946an97bf85b3a1ff&6906c0f946an759326ec9d2f&690

转载于:https://www.cnblogs.com/ZJoy/archive/2010/12/24/1916287.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的嵌入式SQL应用学生信息管理系统的代码示例。本示例使用SQLite数据库,并使用C语言编写。 首先,我们需要包含SQLite的头文件和标准C库头文件: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <sqlite3.h> ``` 接下来,我们定义一个结构体来表示学生信息: ```c typedef struct { int id; char name[50]; int age; char gender[10]; } Student; ``` 然后,我们定义一些函数来执行SQL语句。这些函数将在后面的代码使用。首先,我们定义一个回调函数,用于处理从数据库检索到的结果: ```c int callback(void *data, int argc, char **argv, char **azColName) { int i; printf("%s: ", (const char*)data); for(i = 0; i<argc; i++) { printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL"); } printf("\n"); return 0; } ``` 接下来,我们定义一个函数来执行SELECT语句并打印结果: ```c void select_students(sqlite3 *db) { char *err_msg = 0; char sql[100] = "SELECT * FROM students"; const char* data = "Callback function called"; int rc = sqlite3_exec(db, sql, callback, (void*)data, &err_msg); if (rc != SQLITE_OK ) { fprintf(stderr, "SELECT failed: %s\n", sqlite3_errmsg(db)); sqlite3_free(err_msg); } else { printf("SELECT done successfully\n"); } } ``` 接下来,我们定义一个函数来插入新的学生信息: ```c void insert_student(sqlite3 *db, Student *student) { char *err_msg = 0; char sql[100]; sprintf(sql, "INSERT INTO students (id, name, age, gender) VALUES (%d, '%s', %d, '%s');", student->id, student->name, student->age, student->gender); int rc = sqlite3_exec(db, sql, 0, 0, &err_msg); if (rc != SQLITE_OK ) { fprintf(stderr, "INSERT failed: %s\n", sqlite3_errmsg(db)); sqlite3_free(err_msg); } else { printf("INSERT done successfully\n"); } } ``` 最后,我们定义一个主函数来测试我们的代码: ```c int main(int argc, char* argv[]) { sqlite3 *db; int rc = sqlite3_open("students.db", &db); if (rc != SQLITE_OK) { fprintf(stderr, "Cannot open database: %s\n", sqlite3_errmsg(db)); sqlite3_close(db); return 1; } else { printf("Database opened successfully\n"); } char *sql = "CREATE TABLE IF NOT EXISTS students (id INTEGER PRIMARY KEY, name TEXT, age INTEGER, gender TEXT);"; char *err_msg = 0; rc = sqlite3_exec(db, sql, 0, 0, &err_msg); if (rc != SQLITE_OK ) { fprintf(stderr, "SQL error: %s\n", err_msg); sqlite3_free(err_msg); } else { printf("Table created successfully\n"); } Student student; student.id = 1; strcpy(student.name, "John Doe"); student.age = 20; strcpy(student.gender, "Male"); insert_student(db, &student); select_students(db); sqlite3_close(db); return 0; } ``` 这个示例代码将创建一个名为“students.db”的数据库,并在其创建一个名为“students”的表。然后,它将插入一个名为“John Doe”的学生,并使用SELECT语句检索所有学生的信息。注意,这里我们使用了嵌入式SQL来执行这些操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值