| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1341 人关注过本帖
标题:连接数据库时错误代码!!
只看楼主 加入收藏
若无其事NIE
Rank: 2
等 级:等待验证会员
帖 子:119
专家分:25
注 册:2008-10-28
结帖率:88%
收藏
 问题点数:0 回复次数:2 
连接数据库时错误代码!!
--------------------Configuration: adoconn - Win32 Debug--------------------
Linking...
adoconnDlg.obj : error LNK2005: "class _com_ptr_t<class _com_IIID<struct _Connection,&struct __s_GUID _GUID_00000550_0000_0010_8000_00aa006d2ea4> > m_pConnection" (?m_pConnection@@3V?$_com_ptr_t@V?$_com_IIID@U_Connection@@$1?_GUID_00000550_0000_0010
_8000_00aa006d2ea4@@3U__s_GUID@@A@@@@A) already defined in adoconn.obj
adoconnDlg.obj : error LNK2005: "class _com_ptr_t<class _com_IIID<struct _Recordset,&struct __s_GUID _GUID_00000556_0000_0010_8000_00aa006d2ea4> > m_pRecordset" (?m_pRecordset@@3V?$_com_ptr_t@V?$_com_IIID@U_Recordset@@$1?_GUID_00000556_0000_0010_800
0_00aa006d2ea4@@3U__s_GUID@@A@@@@A) already defined in adoconn.obj
Debug/adoconn.exe : fatal error LNK1169: one or more multiply defined symbols found
执行 link.exe 时出错.

adoconn.exe - 1 error(s), 0 warning(s)
完全按书上的,就是不可以运行。。。

[ 本帖最后由 若无其事NIE 于 2010-3-10 21:45 编辑 ]
搜索更多相关主题的帖子: 数据库 代码 
2010-03-10 18:04
若无其事NIE
Rank: 2
等 级:等待验证会员
帖 子:119
专家分:25
注 册:2008-10-28
收藏
得分:0 
按下面方法做的。。。


首先在VC++中建立一个基于对话框的工程(在这里取名为sjtest)

1、 在StdAfx.h头文件中导入msado15.dll文件。(代码如下)

#import "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace \

rename("EOF","adoEOF")rename("BOF","adoBOF")

2、 在主窗口类声明两个变量。(在CsjtestDlg.h中)

代码:

_ConnectionPtr m_pConnection;

       _RecordsetPtr m_pRecordset;

关于_ConnectionPtr 和_RecordsetPtr 两个智能指针具体作用网上很多,我不详述。想了解的请读者自己查询,本文旨在为大家建立起数据库连接并且显示出来!

3、 在对话框中添加一个ListControl控件,并且将其属性中的Style设置如图

将View设置成Report,Single selection,auto arrange no label wrap勾上!


4、 在CLASS WIZARD里面添加一个和LISTCONTROL想关联的变量m_Grid。


5、在CSjtestApp应用程序类中的初始化函数InitInstance()中初始化COM环境

在上面添加:       ::CoInitialize(NULL);

并在return之前释放:添加代码如下:    ::CoUninitialize();

5、 建立ADO连接数据库函数

在主窗口类(CSjktestDlg)库中添加函数OnInitADOConn()如图:


并在该函数添加如下代码:

       try

       {

              //创建连接对象实例

              m_pConnection.CreateInstance("ADODB.Connection");

              //设置连接字符串

              CString strConnect="DRIVER={Microsoft Access Driver (*.mdb)};\

                     uid=;pwd=;DBQ=shujuku.mdb;";

              //使用Open方法连接数据库

              m_pConnection->Open((_bstr_t)strConnect,"","",adModeUnknown);

       }

       catch(_com_error e)

       {

              AfxMessageBox("连接数据失败,请检查数据库路径是否正确!");

       }

在这里我的数据名字为shujuku.mdb,当然CString strConnect="DRIVER={Microsoft Access Driver (*.mdb)};    uid=;pwd=;DBQ=shujuku.mdb;";也可以使用如下字符串连接

       CString strConnect="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=shujuku.mdb;Persist Security Info=False";代替

6、 按照第五步那样建立关闭记录集和连接函数ExitConnect()并添加代码:

       //关闭记录集和连接

    if(m_pRecordset!=NULL)

              m_pRecordset->Close();

       m_pConnection->Close();

7、 接着在初始化对话框中调用OnInitADOConn函数,已经获取数据库表中数据并显示在列表控件中。代码如下:

       m_Grid.SetExtendedStyle(LVS_EX_FLATSB

              |LVS_EX_FULLROWSELECT

              |LVS_EX_HEADERDRAGDROP

              |LVS_EX_ONECLICKACTIVATE

              |LVS_EX_GRIDLINES);

       m_Grid.InsertColumn(0,"员工编号",LVCFMT_LEFT,80,0);

       m_Grid.InsertColumn(1,"员工姓名",LVCFMT_LEFT,80,1);

       m_Grid.InsertColumn(2,"所属部门",LVCFMT_LEFT,80,2);

       m_Grid.InsertColumn(3,"基本工资",LVCFMT_LEFT,80,3);

       //连接数据库

       OnInitADOConn();

       //设置查询字符串

       _bstr_t bstrSQL = "select * from employees order by 员工编号 desc";

       //创建记录集指针对象实例

       m_pRecordset.CreateInstance(__uuidof(Recordset));//该句也可以使用

//     m_pRecordset.CreateInstance(“ADODB.Recordset”);代替

       //打开记录集

       m_pRecordset->Open(bstrSQL,m_pConnection.GetInterfacePtr(),adOpenDynamic,

              adLockOptimistic,adCmdText);

       while(!m_pRecordset->adoEOF)

       {

              m_Grid.InsertItem(0,"");

              m_Grid.SetItemText(0,0,(char*)(_bstr_t)m_pRecordset->GetCollect("员工编号"));

              m_Grid.SetItemText(0,1,(char*)(_bstr_t)m_pRecordset->GetCollect("员工姓名"));

              m_Grid.SetItemText(0,2,(char*)(_bstr_t)m_pRecordset->GetCollect("所属部门"));

              m_Grid.SetItemText(0,3,(char*)(_bstr_t)m_pRecordset->GetCollect("基本工资"));

              //将记录集指针移动到下一条记录

              m_pRecordset->MoveNext();

       }

       //断开数据库连接

       ExitConnect();

8、 编译运行,就可以看到结果啦
sjtest.rar (2.2 MB)


[ 本帖最后由 若无其事NIE 于 2010-3-10 22:04 编辑 ]

如果没说路过,那我就是看上你了!!
2010-03-10 21:45
justcy
Rank: 2
等 级:论坛游民
帖 子:25
专家分:84
注 册:2009-7-25
收藏
得分:0 
  哈哈
2010-03-17 15:54
快速回复:连接数据库时错误代码!!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.012350 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved