如何在VC++中执行SQL语句?

lastday 2001-07-11 03:11:14
最好能给出一段代码,谢谢。
...全文
152 点赞 收藏 6
写回复
6 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
Ashura 2001-07-11
哦,忘了,头两行不用的
回复
flagfly 2001-07-11
怎么不行?用api
char sql[100];
strcpy(sql,"select * from userfiles");
SQLExecDirect(hStmt, (SQLCHAR *)sql, SQL_NTS);
回复
wjyasd 2001-07-11
关注!
回复
Ashura 2001-07-11
我昨天刚写的,看看吧,或许有用:
QueryPrimaryKey()
{
SQLHENV henv;
SQLRETURN retcode;
SQLHDBC hdbc;
SQLHSTMT hstmt;
SQLCHAR szPkCol[COL_LEN];
SQLINTEGER cbPkCol;
CString strSQLQueryPK;
LPSTR pSQLQueryPK;

strSQLQueryPK = "sp_pkeys @table_name = 'test'";
pSQLQueryPK = strSQLQueryPK.GetBufferSetLength(strSQLQueryPK.GetLength());
//分配环境句柄
retcode = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &henv);
//设置环境属性
if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO)
retcode = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (void*)SQL_OV_ODBC3, 0);
//分配连接句柄
if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO)
retcode = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc);

if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO)
{
retcode = SQLConnect(hdbc,(SQLCHAR*) "JHMY", SQL_NTS,
(SQLCHAR*) "SA", SQL_NTS,
(SQLCHAR*) "", SQL_NTS);
//分配语句句柄
if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO)
{
retcode = SQLAllocHandle(SQL_HANDLE_STMT, hdbc, &hstmt);
//执行SQL语句
if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO)
{
retcode = SQLExecDirect(hstmt,(unsigned char*)"sp_pkeys @table_name = 'test'", SQL_NTS);
if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO)
{
retcode = SQLBindCol(hstmt, 4, SQL_C_CHAR, szPkCol, COL_LEN, &cbPkCol);
retcode = SQLFetch(hstmt);
AfxMessageBox((LPCTSTR)szPkCol);
}
SQLFreeHandle(SQL_HANDLE_STMT, hstmt);
}
SQLDisconnect(hdbc);
}
SQLFreeHandle(SQL_HANDLE_DBC, hdbc);

}
SQLFreeHandle(SQL_HANDLE_ENV, henv);

}
回复
lastday 2001-07-11
我想我表达的不准确,我的意思是我可以在VC中直接使用SQL的语句吗?如:select * from *
谢谢
回复
xwchena 2001-07-11
CString sql="select * from userfiles";
try
{
m_pRecordset->Open(_variant_t(sql),(IDispatch*)m_pConnection,
adOpenDynamic,
adLockOptimistic,
adCmdText);
while(!m_pRecordset->EndOfFile)
{
TheValue=m_pRecordset->GetCollect("FStatus");
if(TheValue.vt!=VT_NULL)
.....
m_pRecordset->MoveNext();
}
}
catch(...)
{
}
回复
相关推荐
发帖
VC/MFC
创建于2007-09-28

1.5w+

社区成员

VC/MFC相关问题讨论
申请成为版主
帖子事件
创建了帖子
2001-07-11 03:11
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……