亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

C語言中嵌入式SQL語句

系統 2260 0

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&690 6c0f946an97bf85b0bacf&690 ???

?

?

?

?

6c0f946an97bf85b3a1ff&690 6c0f946an759326ec9d2f&690

C語言中嵌入式SQL語句


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 伊人成综合 | 四虎网站1515hh四虎免费 | 青草福利在线 | 成人短视频在线在线观看 | 日本特级全黄一级毛片 | 久艾草国产成人综合在线视频 | 国产精品伦视频观看免费 | 亚洲 国产精品 日韩 | 五月天久久婷婷 | 99国产精品热久久久久久夜夜嗨 | 欧美aaaa在线观看视频免费 | 狠狠综合| 日韩精品视频在线观看免费 | 四虎影视永久地址www成人污 | 久九九久福利精品视频视频 | 亚洲成色999久久网站 | 黄片毛片一级 | 日本伊人 | 国产美女久久久 | 欧美日韩国产超高清免费看片 | 久久精品国产免费中文 | 久久久国产高清 | 成人免费视频在线看 | 性xxx69xxx视频在线观看 | 免费又黄又爽视频 | 成人国产视频在线观看 | 国产精品视频一区二区猎奇 | av大片 | 欧美特黄一级aa毛片 | 激情时刻 | 91成年人视频 | 成人性一级视频在线观看 | 中文字幕在线日韩 | 欧美xxxwww| 亚洲精品欧美在线 | 特黄特级毛片免费视 | 免费毛片在线 | 夜精品a一区二区三区 | 一本伊大人香蕉久久网手机 | 天天干天天操 | 亚洲国产色综合有声小说 |