home *** CD-ROM | disk | FTP | other *** search
- // sqlcols.cpp: implementation of the CColumns class
- //
- // This is a part of the Microsoft Foundation Classes C++ library.
- // Copyright (C) 1992-1998 Microsoft Corporation
- // All rights reserved.
- //
- // This source code is only intended as a supplement to the
- // Microsoft Foundation Classes Reference and related
- // electronic documentation provided with the library.
- // See these sources for detailed information regarding the
- // Microsoft Foundation Classes product.
-
-
- #include "stdafx.h"
- #include "columnst.h"
-
- /////////////////////////////////////////////////////////////////////////////
- // CColumns implementation
-
- IMPLEMENT_DYNAMIC(CColumns, CRecordset)
-
- CColumns::CColumns(CDatabase* pDatabase)
- : CRecordset(pDatabase)
- {
- //{{AFX_FIELD_INIT(CColumns)
- m_strQualifier = "";
- m_strOwner = "";
- m_strTableName = "";
- m_strColumnName = "";
- m_nDataType = 0;
- m_strTypeName = "";
- m_lPrecision = 0;
- m_lLength = 0;
- m_nScale = 0;
- m_nRadix = 0;
- m_nFields = 11;
- //}}AFX_FIELD_INIT
- m_strQualifierParam = "";
- m_strOwnerParam = "";
- m_strTableNameParam = "";
- m_strColumnNameParam = "";
- }
-
- BOOL CColumns::Open(UINT nOpenType, LPCSTR lpszSQL, DWORD dwOptions)
- {
- RETCODE nRetCode;
-
- // Cache state info and allocate hstmt
- SetState(nOpenType, NULL, readOnly);
- if (!AllocHstmt())
- return FALSE;
-
- TRY
- {
- OnSetOptions(m_hstmt);
- AllocStatusArrays();
-
- // Call the ODBC catalog function
- AFX_SQL_ASYNC(this, ::SQLColumns(m_hstmt,
- (m_strQualifierParam.IsEmpty()? (UCHAR FAR *)NULL: (UCHAR FAR *)(const char*)m_strQualifierParam), SQL_NTS,
- (m_strOwnerParam.IsEmpty()? (UCHAR FAR *)NULL: (UCHAR FAR *)(const char*)m_strOwnerParam), SQL_NTS,
- (m_strTableNameParam.IsEmpty()? (UCHAR FAR *)NULL: (UCHAR FAR *)(const char*)m_strTableNameParam), SQL_NTS,
- NULL, SQL_NTS));
- if (!Check(nRetCode))
- ThrowDBException(nRetCode, m_hstmt);
-
- // Allocate memory and cache info
- AllocAndCacheFieldInfo();
- AllocRowset();
-
- // Fetch the first row of data
- MoveNext();
-
- // If EOF, result set is empty, set BOF as well
- m_bBOF = m_bEOF;
-
- }
- CATCH_ALL(e)
- {
- Close();
- THROW_LAST();
- }
- END_CATCH_ALL
-
- return TRUE;
- }
-
- CString CColumns::GetDefaultConnect()
- {
- // this minimal connect string will cause ODBC login dialog to be brought up
- return "ODBC;";
- }
-
- CString CColumns::GetDefaultSQL()
- {
- // there is no default SQL - a direct ODBC call is made instead
- ASSERT(FALSE);
- return "!";
- }
-
- void CColumns::DoFieldExchange(CFieldExchange* pFX)
- {
- //{{AFX_FIELD_MAP(CColumns)
- pFX->SetFieldType(CFieldExchange::outputColumn);
- RFX_Text(pFX, "table_qualifier", m_strQualifier);
- RFX_Text(pFX, "table_owner", m_strOwner);
- RFX_Text(pFX, "table_name", m_strTableName);
- RFX_Text(pFX, "column_name", m_strColumnName);
- RFX_Int(pFX, "data_type", m_nDataType);
- RFX_Text(pFX, "type_name", m_strTypeName);
- RFX_Long(pFX, "precision", m_lPrecision);
- RFX_Long(pFX, "length", m_lLength);
- RFX_Int(pFX, "scale", m_nScale);
- RFX_Int(pFX, "radix", m_nRadix);
- RFX_Int(pFX, "nullable", m_nNullable);
- //}}AFX_FIELD_MAP
- }
-