Delphi 델파이 XE2 DataSnap Client 만들기

2011.12.22 01:03

관리자 조회 수:12896

델파이 XE2의 DataSnap 클라이언트는 TSQLConnection 컴포넌트를 기반으로 연결됩니다. TSQLConnection는 기본적으로 dbExpress 기반의 데이터베이스 연결용 컴포넌트 이지만 델파이 XE2에서는 DataSnap과 통합되어 드라이버를 선택하는 방식으로 DanaSnap 드라이버를 선택하여 서버와 쉽고 빠르게 연결 할 수 있습니다.

다음과 같은 몇 가지 방법으로 DataSnap 서버를 연결할 수 있습니다.

  1. 1. 코딩이 필요 없는 데이터베이스 연결

메뉴에서 File – New – VCL Form Application 을 선택하여 새 프로젝트를 생성하고 위의 그림과 같이 5개의 컴포넌트를 배열합니다. 첫번째 SQLConnection1의 프로퍼티를 설정합니다. Driver를 Datasnap 으로 선택하고 + 를 눌러 확장하여 Hostname 에 실행되고 있는 DataSnap서버의 아이피를 입력하고 포트를 설정합니다.

DSProviderConnection1 컴포넌트는 다음과 같이 셋팅합니다.

ClientDataSet1은 아래와 같이 셋팅합니다.

그리고 DataSource1와 DBGrid1을 프로퍼티에서 연결하면 Grid1에 서버의 데이터가 조회 되는것을 확인할 수 있습니다.

 

  1. 2. 서버 메소드 호출

두번째 방법은 DataSnap 서버에 이미 만들어 놓은 메소드를 TSQLConnection을 이용하여 호출하는 방법을 알아 보겠습니다. 1번의 방법과 동일하게 프로젝트를 생성하고 화면에 TSQLConnection 컴포넌트와 함께 다음과 같이 화면을 구성합니다.

화면에서 SQLConnection1을 선택하고 오른쪽 버튼을 누르면 아래의 그림과 같이 Generate Datasnap client classes 메뉴를 확인할 수 있습니다.

메뉴를 누르면 Unit2를 자동으로 생성하면서 서버 메소드를 자동으로 생성 시켜줍니다. 이것을 위하여 서버생성시에 컴파일러 지시자 {$METHODINFO ON} 를 사용했습니다. (서버만들기 참조) 생성된 클래스 유닛을 저장하고 uses 구문에 저장된 파일을 참조로 추가한 후 아래의 코드와 같이 호출합니다.

다음 화면은 실행된 결과 화면 입니다.

  1. 3. OSX를 위한 DataSnap Client

OSX (맥)용 DataSnap 클라이언트는 기본적으로 델파이 DataSnap 클라이어트와 동일합니다. 단지 프로젝트를 생성할 때 파이어몽키 기반의 프로젝트를 생성하면 위의 열거한 두가지 방법을 공히 사용할 수 있습니다. (파이어몽키 애플리케이션 생성 참조)

아래 그림은 OSX에서 실행한 DataSnap 클라이언트 입니다.

번호 제목 글쓴이 날짜 조회 수
공지 [DelphiCon 요약] 코드사이트 로깅 실전 활용 기법 (Real-world CodeSite Logging Techniques) 관리자 2021.01.19 15442
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 13962
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 16499
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 22055
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 23268
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 18923
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 39257
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 174713
503 [시애틀] 안드로이드 서비스 앱을 만들 수 있습니다. Humphery 2015.09.07 691
502 [시애틀] 블루투스 LE를 지원하는 디바이스에서 비콘 광고데이터를 발생할 수 있습니다. file Humphery 2015.10.06 689
501 [10.4 시드니][패치] RAD스튜디오 10.4 '세 번째 패치(Patch 3)': VCL그리드, C++Win64 디버깅, C++ 안드로이드 예외처리 핸들링 및 리소스 등 관리자 2020.07.29 686
500 [고객사례-유틸리티, 델파이] 녹음기 앱 - Voice Recorder 관리자 2019.12.10 686
499 [고객 사례- 3D, 시뮬레이션, 델파이] 3D Train Studio 관리자 2017.03.02 681
498 [베를린 U1] 윈도우 태스크바 알림의 뱃지를 제어할 수 있습니다. 험프리 2016.09.20 680
497 [10.4 시드니 신기능] iOS와 맥OS 지원 강화 관리자 2020.06.04 680
496 [커뮤니티 에디션] 사용 자격 기준 정리 관리자 2018.11.29 680
495 [고객 사례- 의료, 델파이+임베디드DB] Siemens Healthcare 의 체외진단기기 (IVD, In Vitro Diagnostics) file 관리자 2016.11.03 680
494 [도서/PDF/소스코드] 시작하는 사람들을 위한 델파이 프로그래밍-모듈 17. 1차원 정적 배열 관리자 2019.03.29 678
493 [10.4 시드니 신기능] 언어 서버 프로토콜 (LSP, Language Server Protocol) 관리자 2020.06.04 677
492 [프로그래밍 애피타이저] 8장 SQL 정의와문법 file 김원경 2020.04.09 677
491 n [도서/PDF/소스코드] 시작하는 사람들을 위한 델파이 프로그래밍-모듈 7. 중접된 If...Then...Else 문. 작업 해결 실습하기 관리자 2019.03.29 676
490 [업데이트][핫픽스][10.1 베를린] 갤럭시 S7 Edge(안드로이드 6.0.1) 디버깅이 되지않는 이슈 패치 험프리 2016.05.27 676
489 [델파이 샘플 코드] 안드로이드, iOS, OSX, 윈도우, 리눅스, HTML5 관리자 2019.11.13 674
488 [도서/PDF/소스코드] 시작하는 사람들을 위한 델파이 프로그래밍-모듈 23. 타이머 관리자 2019.03.29 674
487 Class에서 Interface 두 개 구현할 때, 이 둘이 동일한 이름의 메소드(Method)를 가지고 있다면? file 험프리 2019.12.11 672
486 [도서/PDF/소스코드] 델파이 Begin...End - 14장. 분산처리(DataSnap) 관리자 2019.08.20 672
485 가장 강력한 ‘데이터베이스 연동’ 기능을 자체적으로 제공하는 프레임워크는? (델파이 VS. WPF VS. ELECTRON) 관리자 2021.03.04 669
484 델파이, C++빌더의 윈도우10과 High DPI 디스플레이 지원 김원경 2020.02.28 668