1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
101.
102.
103.
104.
105.
106.
107.
108.
109.
110.
111.
112.
113.
114.
115.
116.
117.
118.
119.
120.
121.
122.
123.
124.
125.
126.
127.
128.
129.
130.
131.
132.
133.
134.
135.
136.
137.
138.
139.
140.
141.
142.
143.
144.
145.
146.
147.
148.
149.
150.
151.
152.
153.
154.
155.
156.
157.
158.
159.
160.
161.
162.
163.
164.
165.
166.
167.
168.
169.
170.
171.
172.
173.
174.
175.
176.
177.
178.
179.
180.
181.
182.
183.
184.
185.
186.
187.
188.
189.
190.
191.
192.
193.
194.
195.
196.
197.
198.
199.
200.
201.
202.
203.
204.
205.
206.
207.
208.
209.
210.
211.
212.
213.
214.
215.
216.
217.
218.
219.
220.
221.
222.
223.
224.
225.
226.
227.
228.
229.
230.
231.
232.
233.
234.
235.
236.
237.
238.
239.
240.
241.
242.
243.
244.
245.
246.
247.
248.
249.
250.
251.
252.
253.
254.
255.
256.
257.
258.
259.
260.
261.
262.
263.
264.
265.
266.
267.
268.
269.
270.
271.
272.
273.
274.
275.
276.
277.
278.
279.
280.
281.
282.
283.
284.
285.
286.
287.
288.
289.
290.
291.
292.
293.
294.
295.
296.
297.
298.
299.
300.
301.
302.
303.
304.
305.
306.
307.
308.
309.
310.
311.
312.
313.
314.
315.
316.
317.
318.
319.
320.
321.
322.
323.
324.
325.
326.
327.
328.
329.
330.
// SQL_DialogDlg.cpp : implementation file
//
#include "stdafx.h"
#include "SQL_Dialog.h"
#include "SQL_DialogDlg.h"
#include <sql.h>
#include <sqlext.h>
#include <odbcss.h>
#include <afxdb.h>
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About
class CAboutDlg : public CDialog
{
public:
CAboutDlg();
// Dialog Data
//{{AFX_DATA(CAboutDlg)
enum { IDD = IDD_ABOUTBOX };
//}}AFX_DATA
// ClassWizard generated virtual function overrides
//{{AFX_VIRTUAL(CAboutDlg)
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
//}}AFX_VIRTUAL
// Implementation
protected:
//{{AFX_CAboutDlg
//}}AFX_MSG
DECLARE_MESSAGE_MAP()
};
CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
//{{AFX_DATA_INIT(CAboutDlg)
//}}AFX_DATA_INIT
}
void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CAboutDlg)
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
//{{AFX_MSG_MAP(CAboutDlg)
// No message handlers
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CSQL_DialogDlg dialog
CSQL_DialogDlg::CSQL_DialogDlg(CWnd* pParent /*=NULL*/ )
: CDialog(CSQL_DialogDlg::IDD, pParent)
{
//{{AFX_DATA_INIT(CSQL_DialogDlg)
// NOTE: the ClassWizard will add member initialization here
//}}AFX_DATA_INIT
// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}
void CSQL_DialogDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CSQL_DialogDlg)
// NOTE: the ClassWizard will add DDX and DDV calls here
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CSQL_DialogDlg, CDialog)
//{{AFX_MSG_MAP(CSQL_DialogDlg)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_BN_CLICKED(IDC_BUTTON1, OnButton1)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CSQL_DialogDlg message handlers
BOOL CSQL_DialogDlg::OnInitDialog()
{
CDialog::OnInitDialog();
// Add "About..." menu item to system menu.
// IDM_ABOUTBOX must be in the system command range.
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000);
CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
CString strAboutMenu;
strAboutMenu.LoadString(IDS_ABOUTBOX);
if (!strAboutMenu.IsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
}
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
// TODO: Add extra initialization here
return TRUE; // return TRUE unless you set the focus to a control
}
void CSQL_DialogDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialog::OnSysCommand(nID, lParam);
}
}
// If you add a minimize button to your dialog, you will need the code below
// to draw the icon. For MFC applications using the document/view model,
// this is automatically done for you by the framework.
void CSQL_DialogDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // device context for painting
SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);
// Center icon in client rectangle
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2;
// Draw the icon
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CDialog::OnPaint();
}
}
// The system calls this to obtain the cursor to display while the user drags
// the minimized window.
HCURSOR CSQL_DialogDlg::OnQueryDragIcon()
{
return (HCURSOR) m_hIcon;
}
void CSQL_DialogDlg::OnButton1()
{
// TODO: Add your control notification handler code here
SQLHENV henv = SQL_NULL_HENV;
SQLHDBC hdbc1 = SQL_NULL_HDBC;
SQLHSTMT hstmt1 = SQL_NULL_HSTMT;
RETCODE retcode;
// SQLBindCol variables
%af_src_comm_1
// Allocate the ODBC Environment and save handle.
retcode = SQLAllocHandle (SQL_HANDLE_ENV, NULL, &henv);
// Let ODBC know this is an ODBC 3.0 application.
retcode = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER) SQL_OV_ODBC3, SQL_IS_INTEGER);
// Allocate an ODBC connection and connect.
retcode = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc1);
retcode = SQLConnect(hdbc1,
(SQLCHAR*)"For_Test", SQL_NTS, (SQLCHAR*)"sa", SQL_NTS, (SQLCHAR*)"sql", SQL_NTS);
// Allocate a statement handle.CashierSystemARS For_Test
retcode = SQLAllocHandle(SQL_HANDLE_STMT, hdbc1, &hstmt1);
if ( retcode != SQL_SUCCESS )
{
}
// Prepare and execute an SQL statement on the statement handle.
// Uses a default result set because no cursor attributes are set.
SQLCHAR szSalesPerson[15];
SDWORD cbParm1=SQL_NTS;
SQLINTEGER cbName;
retcode = SQLBindParameter(hstmt1,1,SQL_PARAM_OUTPUT,SQL_C_CHAR,
SQL_CHAR,15,0,szSalesPerson,0,&cbParm1);
// Bind the output parameter to variable sParm2.
retcode = SQLExecDirect(hstmt1,(SQLCHAR*)"EXEC YYY_ttt1 \'d:\\mssql7\\data\\\' ",SQL_NTS);
if ( retcode == SQL_SUCCESS )
{
retcode = SQLFetch(hstmt1);
retcode = SQLGetData(hstmt1, 1, SQL_C_CHAR, szSalesPerson, 15, &cbName);
retcode = SQLFetch(hstmt1);
retcode = SQLGetData(hstmt1, 1, SQL_C_CHAR, szSalesPerson, 15, &cbName);
retcode = SQLMoreResults(hstmt1) ;
retcode = SQLFetch(hstmt1);
retcode = SQLGetData(hstmt1, 1, SQL_C_CHAR, szSalesPerson, 15, &cbName);
}
// retcode = SQLExecDirect(hstmt1,(SQLCHAR*)"EXEC cash_archive_22_create_z_db \'d:\\mssql7\\data\\\' ",SQL_NTS);
// retcode = SQLExecDirect(hstmt1,(SQLCHAR*)"EXEC cash_archive_22_create_z_db \'d:\\mssql7\\data\\\' ",SQL_NTS);
SQLCHAR SqlState[6 ], Msg[ 500 ];
SQLINTEGER NativeError;
SQLSMALLINT MsgLen;
SQLGetDiagRec(SQL_HANDLE_STMT, hstmt1, 1 , SqlState, &NativeError,
Msg, sizeof(Msg), &MsgLen);
if ( retcode != SQL_SUCCESS )
{
}
// Simplified result set processing. Bind one column and
// then fetch until SQL_NO_DATA.
/* Clean up. */
SQLFreeHandle(SQL_HANDLE_STMT, hstmt1);
SQLDisconnect(hdbc1);
SQLFreeHandle(SQL_HANDLE_DBC, hdbc1);
}
void CSQL_DialogDlg::OnButton_()
{
// CDatabase db;
// db.Open (NULL);
CListBox* pList1 = (CListBox*)GetDlgItem(IDC_LIST1);
CListBox* pList2 = (CListBox*)GetDlgItem(IDC_LIST2);
pList1->ResetContent();
pList2->ResetContent();
SQLHENV henv = SQL_NULL_HENV;
SQLHDBC hdbc1 = SQL_NULL_HDBC;
SQLHSTMT hstmt1 = SQL_NULL_HSTMT;
RETCODE retcode;
// SQLBindCol variables
/*
SQLCHAR szCode[10];
SQLCHAR szName[50];
SQLINTEGER cbName;
*/
// Allocate the ODBC Environment and save handle.
retcode = SQLAllocHandle (SQL_HANDLE_ENV, NULL, &henv);
// Let ODBC know this is an ODBC 3 . 0 application.
retcode = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER) SQL_OV_ODBC3, SQL_IS_INTEGER);
// Allocate an ODBC connection and connect.
retcode = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc1);
retcode = SQLConnect(hdbc1,
(SQLCHAR*)"CashierSystemARS ", SQL_NTS, (SQLCHAR*)" sa ", SQL_NTS, (SQLCHAR*)" sql ", SQL_NTS);
// Allocate a statement handle.
retcode = SQLAllocHandle(SQL_HANDLE_STMT, hdbc1, &hstmt1);
if ( retcode != SQL_SUCCESS )
{
}
// Prepare and execute an SQL statement on the statement handle.
// Uses a default result set because no cursor attributes are set.
// retcode = SQLPrepare(hstmt1, (SQLCHAR*)" SELECT * FROM AcctType " , SQL_NTS);
// retcode = SQLPrepare(hstmt1, (SQLCHAR*)" {Call cash_archive_70_copy_db(?,?)} " , SQL_NTS);
retcode = SQLPrepare(hstmt1, (SQLCHAR*)" {Call YYY_ttt(?)} " , SQL_NTS);
if ( retcode != SQL_SUCCESS )
{
}
SQLCHAR szNewFilePATH[ 40 ];
SQLCHAR tnWeeksToGoBack = 5 ;
::strcpy( (char*)szNewFilePATH, "d:\\mssql7\\data\\" );
SQLINTEGER cbBindPar;
cbBindPar = SQL_NTS;
retcode = SQLBindParameter( hstmt1, 1 , SQL_PARAM_INPUT,
SQL_C_CHAR, SQL_CHAR, 41 ,
0 , szNewFilePATH, 0 ,
&cbBindPar );
retcode = SQLExecute(hstmt1);
SQLCHAR SqlState[ 6 ], Msg[ 500 ];
SQLINTEGER NativeError;
SQLSMALLINT MsgLen;
SQLGetDiagRec(SQL_HANDLE_STMT, hstmt1, 1 , SqlState, &NativeError,
Msg, sizeof(Msg), &MsgLen);
if ( retcode != SQL_SUCCESS )
{
}
SQLFreeHandle(SQL_HANDLE_STMT, hstmt1);
SQLDisconnect(hdbc1);
SQLFreeHandle(SQL_HANDLE_DBC, hdbc1);
}