database.sarang.net
UserID
Passwd
Database
DBMS
ㆍMySQL
PostgreSQL
Firebird
Oracle
Informix
Sybase
MS-SQL
DB2
Cache
CUBRID
LDAP
ALTIBASE
Tibero
DB 문서들
스터디
Community
공지사항
자유게시판
구인|구직
DSN 갤러리
도움주신분들
Admin
운영게시판
최근게시물
MySQL Q&A 29791 게시물 읽기
No. 29791
[초보] 시리얼통신 값을 mysql과 mfc로 연동 하여 DB로 저장하는데 문제가..
작성자
김학순(킬랜이)
작성일
2010-09-14 10:25
조회수
9,131

// smartdbDlg.cpp : 구현 파일
//

#include "stdafx.h"
#include "smartdb.h"
#include "smartdbDlg.h"
#include "SrialDlg.h"

#include <winsock2.h>
#include <mysql.h>

#pragma comment(lib, "libmysql.lib")
#pragma comment(lib, "ws2_32.lib")

 

#define MYSQL_HOST  "127.0.0.1"
#define MYSQL_USER  "root"
#define MYSQL_PWD   "apmsetup"
#define MYSQL_DB "mem"

 

#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// 응용 프로그램 정보에 사용되는 CAboutDlg 대화 상자입니다.

class CAboutDlg : public CDialog
{
public:
 CAboutDlg();

// 대화 상자 데이터입니다.
 enum { IDD = IDD_ABOUTBOX };

 protected:
 virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV 지원입니다.

// 구현입니다.
protected:
 DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
}

 

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
 CDialog::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
END_MESSAGE_MAP()


// CsmartdbDlg 대화 상자

 


CsmartdbDlg::CsmartdbDlg(CWnd* pParent /*=NULL*/)
 : CDialog(CsmartdbDlg::IDD, pParent)
{
 m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CsmartdbDlg::DoDataExchange(CDataExchange* pDX)
{
 CDialog::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CsmartdbDlg, CDialog)
 ON_WM_SYSCOMMAND()
 ON_WM_PAINT()
 ON_WM_QUERYDRAGICON()
 //}}AFX_MSG_MAP
 ON_BN_CLICKED(IDC_BUTTON1, &CsmartdbDlg::OnBnClickedButton1)
END_MESSAGE_MAP()


// CsmartdbDlg 메시지 처리기

BOOL CsmartdbDlg::OnInitDialog()

 MYSQL mysql;
 mysql_init(&mysql);
 if (!mysql_real_connect(&mysql, MYSQL_HOST,MYSQL_USER,MYSQL_PWD,MYSQL_DB,3306,0,0))
 {
  AfxMessageBox(_T("mysql_error(&mysql)"),MB_OK);
  //return 0;
 }
else
 {
  AfxMessageBox(_T("DB 연결 성공"),MB_OK);
  mysql_close(&mysql);
  //return 0;
 }
 CDialog::OnInitDialog();


 // 시스템 메뉴에 "정보..." 메뉴 항목을 추가합니다.

 // IDM_ABOUTBOX는 시스템 명령 범위에 있어야 합니다.
 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);
  }
 }

 // 이 대화 상자의 아이콘을 설정합니다. 응용 프로그램의 주 창이 대화 상자가 아닐 경우에는
 //  프레임워크가 이 작업을 자동으로 수행합니다.
 SetIcon(m_hIcon, TRUE);   // 큰 아이콘을 설정합니다.
 SetIcon(m_hIcon, FALSE);  // 작은 아이콘을 설정합니다.

 // TODO: 여기에 추가 초기화 작업을 추가합니다.

 return TRUE;  // 포커스를 컨트롤에 설정하지 않으면 TRUE를 반환합니다.
}

void CsmartdbDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
 if ((nID & 0xFFF0) == IDM_ABOUTBOX)
 {
  CAboutDlg dlgAbout;
  dlgAbout.DoModal();
 }
 else
 {
  CDialog::OnSysCommand(nID, lParam);
 }
}

// 대화 상자에 최소화 단추를 추가할 경우 아이콘을 그리려면
//  아래 코드가 필요합니다. 문서/뷰 모델을 사용하는 MFC 응용 프로그램의 경우에는
//  프레임워크에서 이 작업을 자동으로 수행합니다.

void CsmartdbDlg::OnPaint()
{
 if (IsIconic())
 {
  CPaintDC dc(this); // 그리기를 위한 디바이스 컨텍스트

  SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);

  // 클라이언트 사각형에서 아이콘을 가운데에 맞춥니다.
  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;

  // 아이콘을 그립니다.
  dc.DrawIcon(x, y, m_hIcon);
 }
 else
 {
  CDialog::OnPaint();
 }
}

// 사용자가 최소화된 창을 끄는 동안에 커서가 표시되도록 시스템에서
//  이 함수를 호출합니다.
HCURSOR CsmartdbDlg::OnQueryDragIcon()
{
 return static_cast<HCURSOR>(m_hIcon);
}


void CsmartdbDlg::OnBnClickedButton1()
{
 CSrialDlg dlg;
 dlg.DoModal();
}
 

=======================================================================

// smartdb.h : PROJECT_NAME 응용 프로그램에 대한 주 헤더 파일입니다.
//

#pragma once

#ifndef __AFXWIN_H__
 #error "PCH에 대해 이 파일을 포함하기 전에 'stdafx.h'를 포함합니다."
#endif

#include "resource.h"  // 주 기호입니다.


// CsmartdbApp:
// 이 클래스의 구현에 대해서는 smartdb.cpp을 참조하십시오.
//

class CsmartdbApp : public CWinApp
{
public:
 CsmartdbApp();

// 재정의입니다.
 public:
 virtual BOOL InitInstance();

// 구현입니다.

 DECLARE_MESSAGE_MAP()
};

extern CsmartdbApp theApp;

===================================================================

// smartdbDlg.h : 헤더 파일
//

#pragma once


// CsmartdbDlg 대화 상자
class CsmartdbDlg : public CDialog
{
// 생성입니다.
public:
 CsmartdbDlg(CWnd* pParent = NULL); // 표준 생성자입니다.

// 대화 상자 데이터입니다.
 enum { IDD = IDD_SMARTDB_DIALOG };

 protected:
 virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 지원입니다.


// 구현입니다.
protected:
 HICON m_hIcon;

 // 생성된 메시지 맵 함수
 virtual BOOL OnInitDialog();
 afx_msg void OnSysCommand(UINT nID, LPARAM lParam);
 afx_msg void OnPaint();
 afx_msg HCURSOR OnQueryDragIcon();
 DECLARE_MESSAGE_MAP()
public:
 afx_msg void OnBnClickedButton1();
};
 

======================================================================

이렇게 만들었습니다. 그런데 db로 연결 성공은 했는데 db저장이 되질않네요,,

mfc를 처음 써보아서 미숙한대다가 오늘 꼭 완성시켜야해서요...

부탁좀 드립니다. 제발.

이 글에 대한 댓글이 총 1건 있습니다.

 시간이 좀 지나긴 했지만...

일단 올려주신 소스에는 DB에 연결을 위한 내용만 있고, 값을 저장하는 부분은 없는데 확인해보시기 바랍니다.

박현우(lqez)님이 2010-09-27 03:56에 작성한 댓글입니다.
[Top]
No.
제목
작성자
작성일
조회
29794root 비밀번호 확인 절차 관련 문의 [2]
초보자
2010-09-15
6938
29793쿼리문 좀 도와 주세요 [1]
강삼수
2010-09-15
7419
29792select 문 쿼리 최적화에 대해서 [1]
정현철
2010-09-14
7016
29791[초보] 시리얼통신 값을 mysql과 mfc로 연동 하여 DB로 저장하는데 문제가.. [1]
김학순
2010-09-14
9131
29790mysql 4.x -> 5.x upgrade 문제점좀 도와주새요 [1]
김기범
2010-09-12
7044
29789저장프로시져 실행중 발생한 sql 에러코드와 sql 오류메시지 알아내는 방법이..? [1]
알고파
2010-09-09
12680
29788sql 쿼리 좀 알려주세요.. [1]
ㅎㅎ
2010-09-09
6885
Valid XHTML 1.0!
All about the DATABASE... Copyleft 1999-2024 DSN, All rights reserved.
작업시간: 0.024초, 이곳 서비스는
	PostgreSQL v16.2로 자료를 관리합니다