嵌入SQL
连接到SAMPLE数据库,查询LASTNAME为JOHNSON的FIRSTNAME信息。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "util.h"
#include <sqlca.h>
EXEC SQL INCLUDE SQLCA; (1)
main()
{
EXEC SQL BEGIN DECLARE SECTION; (2)
char firstname[13];
char userid[9];
char passwd[19];
EXEC SQL END DECLARE SECTION;
EXEC SQL CONNECT TO sample; (3)
EXEC SQL SELECT FIRSTNME INTO :firstname (4)
FROM employee
WHERE LASTNAME = 'JOHNSON';(4)
printf( "First name = %s/n", firstname );
EXEC SQL CONNECT RESET; (5)
return 0;
}
上面是一个简单的静态嵌入SQL语句的应用程序。它包括了嵌入SQL的主要部分:
(1)中的include SQLCA语句定义并描述了SQLCA的结构。SQLCA用于应用程序和数据库之间的通讯,其中的SQLCODE返回SQL语句执行后的结果状态。
(2) 在BEGIN DECLARE SECTION和END DECLARE SECTION之间定义了宿主变量。宿主变量可被SQL语句引用,也可以被C语 言语句引用。它用于将程序中的数据通过SQL语句传给数据库管理器,或从数据库管理器接收查询的结果。在SQL语句中,主变量前均有“:”标志以示区别。
(3)在每次访问数据库之前必须做CONNECT操作,以连接到某一个数据库上。这时,应该保证数据库实例已经启动。
(4) 是一条选择语句。它将表employee中的LASTNAME为“JOHNSON”的行数据的FIRSTNAME查出,并将它放在firstname变量 中。该语句返回一个结果。可以通过游标返回多个结果。当然,也可以包含update、insert和delete语句。
(5)最后断开数据库的连接。
从上例看出,每条嵌入式SQL语句都用EXEC SQL开始,表明它是一条SQL语句。这也是告诉预编译器在EXEC SQL和“;”之间是嵌入SQL语句。如果一条嵌入式SQL语句占用多行,在C程序中可以用续行符“/”。
【jixingzhong】:
用C操作MySql示例
mysql_c_exam.c
#include <stdio.h>
#include <mysql.h>
int main(char **args)
{
MYSQL_RES *query_result;
MYSQL_ROW row;
MYSQL *db_handle, mysql;
int query_error;
mysql_init(&mysql);
db_handle=mysql_real_connect(&mysql, "localhost", "root", "12345678", "crm", 0, 0, 0);
if(db_handle==NULL)
{
printf(mysql_error(&mysql));
return 1;
}
query_error=mysql_query(db_handle, "select * from bargain");
if(query_error!=0)
{
printf(mysql_error(db_handle));
return 1;
}
query_result=mysql_store_result(db_handle);
while((row=mysql_fetch_row(query_result))!=NULL)
{
printf("%s %s %s/n",(row[0]?row[0]:"NULL"),(row[1] ? row[1]:"NULL"),(row[2] ? row[2]:"NULL"));
}
mysql_free_result(query_result);
mysql_close(db_handle);
return 0;
}
2)编译
[cnscn@test mysql]$ gcc -o mysql_c_exam mysql_c_exam.c -I /usr/local/mysql/include/mysql -L /usr/local/mysql/lib/mysql -l mysqlclient -lz
3)执行
[cnscn@test mysql]$ ./mysql_c_exam
1 060108-1901001 34342432
2 060110-10001
3 060118-101001 34342432222
4 060118-1021013 3434sde
5 060118-10210133 3434sded
6 060118-10001 lkfgksdl2455
7 060124-19001 dfgg555
8 060124-11204 sdfsf
C嵌入SQL
最新推荐文章于 2024-05-28 17:12:48 发布