Win32 API 和 ODBC 访问数据库一
?
準備用Win32 API和ODBC來訪問數據庫;
代碼如下;
/*------------------------------------------------------------win32, ODBC, by bobo, 2018-09-09------------------------------------------------------------*/#include <windows.h> #include "sql.h" #include "sqlext.h" #include "sqltypes.h" #include "sqlucode.h" #include "odbcss.h"LRESULT CALLBACK WndProc (HWND, UINT, WPARAM, LPARAM); #define DSNAME "testDS1" #define DSUSERNAME "sa" #define DSUSERPWD "123"#pragma comment(lib, "odbc32.lib")SQLRETURN ret; SQLHENV henv; SQLHDBC hdbc;int WINAPI WinMain (HINSTANCE hInstance, HINSTANCE hPrevInstance,PSTR szCmdLine, int iCmdShow) {static TCHAR szAppName[] = TEXT ("HelloWin") ;HWND hwnd ;MSG msg ;WNDCLASS wndclass ;wndclass.style = CS_HREDRAW | CS_VREDRAW ;wndclass.lpfnWndProc = WndProc ;wndclass.cbClsExtra = 0 ;wndclass.cbWndExtra = 0 ;wndclass.hInstance = hInstance ;wndclass.hIcon = LoadIcon (NULL, IDI_APPLICATION) ;wndclass.hCursor = LoadCursor (NULL, IDC_ARROW) ;wndclass.hbrBackground = (HBRUSH) GetStockObject (WHITE_BRUSH) ;wndclass.lpszMenuName = NULL ;wndclass.lpszClassName = szAppName ;if (!RegisterClass (&wndclass)){MessageBox (NULL, TEXT ("This program requires Windows NT!"), szAppName, MB_ICONERROR) ;return 0 ;}hwnd = CreateWindow (szAppName, // window class nameTEXT ("The Hello ODBC"), // window captionWS_OVERLAPPEDWINDOW, // window styleCW_USEDEFAULT, // initial x positionCW_USEDEFAULT, // initial y position300, // initial x size100, // initial y sizeNULL, // parent window handleNULL, // window menu handlehInstance, // program instance handleNULL) ; // creation parametersShowWindow (hwnd, iCmdShow) ;UpdateWindow (hwnd) ;while (GetMessage (&msg, NULL, 0, 0)){TranslateMessage (&msg) ;DispatchMessage (&msg) ;}return msg.wParam ; }LRESULT CALLBACK WndProc (HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam) {HDC hdc ;PAINTSTRUCT ps ;RECT rect ;DWORD err;switch (message){case WM_CREATE:ret= SQLAllocEnv(&henv); ret = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc);//ret = SQLConnect(hdbc, (unsigned char *)"testDS1", SQL_NTS, (unsigned char *)"sa", SQL_NTS,(unsigned char *)"123", SQL_NTS);ret = SQLConnect(hdbc, (SQLCHAR*)"testDS41", SQL_NTS, (SQLCHAR*)"sa", SQL_NTS,(SQLCHAR*)"123", SQL_NTS);//err=GetLastError();if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO) //成功連接到數據庫{MessageBox (NULL, TEXT ("SUCCESS"), TEXT ("HelloODBC"), 0);}else{MessageBox (NULL, TEXT ("FAIL"), TEXT ("HelloODBC"), 0);}return 0 ;case WM_PAINT:hdc = BeginPaint (hwnd, &ps) ;GetClientRect (hwnd, &rect) ;DrawText (hdc, TEXT ("Hello, ODBC!"), -1, &rect,DT_SINGLELINE | DT_CENTER | DT_VCENTER) ;EndPaint (hwnd, &ps) ;return 0 ;case WM_DESTROY:PostQuitMessage (0) ;return 0 ;}return DefWindowProc (hwnd, message, wParam, lParam) ; }在調試的時候發現SQLConnect總是返回1,不知道是否連接成功;
使用ODBC的預定義值來判斷是否連接成功;
原來,
SQL_SUCCESS的enum值為0, SQL_SUCCESS_WITH_INFO的enum值為1;
進入調試,查看一下;
henv和hdbc兩個句柄已經分配成功;ret為1;
這兩種寫法一樣;
ret = SQLConnect(hdbc, (unsigned char *)"testDS1", SQL_NTS, (unsigned char *)"sa", SQL_NTS,(unsigned char *)"123", SQL_NTS);
ret = SQLConnect(hdbc, (SQLCHAR*)"testDS41", SQL_NTS, (SQLCHAR*)"sa", SQL_NTS,(SQLCHAR*)"123", SQL_NTS);
?? ?
SQL_NTS參數的位置,本來是字符串的長度,此處可以用預定義的SQL_NTS代替;
NTS => "Null-Terminated String"
如果參數對就連接成功,改個不對的參數,例如"testDS101",則會失敗;
如果構建時報錯
cannot open Debug/XXXX.exe for writing
關閉開發環境,重來;或者看任務管理器里,正在做的程序是否還在運行,結束之即可;
?
另外需要先在系統中建立ODBC數據源;
先做這么多吧,這活老難了;
截圖如下;
? ?
總結
以上是生活随笔為你收集整理的Win32 API 和 ODBC 访问数据库一的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Eclipse基本使用
- 下一篇: Win32 API 打开另一个进程