데이터 베이스 MySQL 튜토리얼 直接通过ADO操作Access数据库

直接通过ADO操作Access数据库

Jun 07, 2016 pm 03:42 PM
access 작동하다 데이터 베이스 통과하다

直接通过ADO操作Access数据库 作者/徐景周 下载源代 码 我在《VC知识库在线杂志》第十四期和第十五期上曾发表了两篇文章——“直接通过ODBC读、写Excel表文件”和“直接通过DAO读、写Access文件”,先后给大家介绍了ODBC和DAO两种数据库访问技术的基本使用方

直接通过ADO操作Access数据库 


作者/徐景周

下载源代 码 

    我在《VC知识库在线杂志》第十四期和第十五期上曾发表了两篇文章——“直接通过ODBC读、写Excel表格文件 ”和“直接通过DAO读、写Access文件 ”,先后给大家介绍了ODBC和DAO两种数据库访问技术的基本使用方 法,这次要给大家介绍的是ADO数据库访问技术的使用方法。ADO(Active Data Object,活动数据对象)实际上是一种基于COM(组件对象模型)的自动化接口(IDispatch)技术,并以OLE DB(对象连接和镶入的数据库)为基础,经过OLE DB精心包装后的数据库访问技术,利用它可以快速的创建数据库应用程序。 ADO提供了一组非常简单,将一般通用的数据访问细节进行封装的对象。由于ODBC数据源也提供了一般的OLE DB Privider,所以ADO不仅可以应用自身的OLE DB Privider,而且还可以应用所有的ODBC驱动程序。关于OLE DB和ADO的其它详细情况,读者可以自行查阅相关书籍或MSDN,这里就不一一说明了。让我们直接步入主题:如何掌握ADO这种数据库访问技术。ADO 的操作方法和前面讲过的DAO的操作在很多方面存在相似之处,在这里,笔者为了更有效的说明它的使用方法,用VC6.0做了一个示例程序—— AdoRWAccess,这个示例程序可以直接通过ADO来操作Access数据库,示例程序的运行效果如下图所示:

直接通过ADO操作Access数据库

 

在示例程序中我们仍采用原库结构,数据库名Demo.mdb,库内表名DemoTable,表内字段名为Name(姓名)和Age(年龄)的两个字 段,来构造示例程序操作所需的Access数据库,这也和上两篇文章的示例源码中的库结构相兼容。
下面让我们看看ADO数据库访问技术使用的基本步骤及方法:
    首先,要用#import语句来引用支持ADO的组件类型库(*.tlb),其中类型库可以作为可执行程序(DLL、EXE等)的一部分被定位在其自身程 序中的附属资源里,如:被定位在msado15.dll的附属资源中,只需要直接用#import引用它既可。可以直接在Stdafx.h文件中加入下面 语句来实现:

<p></p><p></p><p><strong>[cpp]</strong> view plaincopy</p><ol>
<li><span><span>// 加入ADO支持库, jingzhou xu</span><span>  </span></span></li>
<li><span><span>#import "c:/program files/common files/system/ado/msado15.dll" /</span><span>  </span></span></li>
<li><span>    no_namespace /  </span></li>
<li><span>    rename (<span>"EOF"</span><span>, </span><span>"adoEOF"</span><span>)      </span></span></li>
</ol>
     
로그인 후 복사

其中路径名可以根据自己系统安装的ADO支持文件的路径来自行设定。当编译器遇到#import语句时,它会为引用组件类型库中的接口生成包装 类,#import语句实际上相当于执行了API涵数LoadTypeLib()。#import语句会在工程可执行程序输出目录中产生两个文件,分别 为*.tlh(类型库头文件)及*.tli(类型库实现文件),它们分别为每一个接口产生智能指针,并为各种接口方法、枚举类型,CLSID等进行声明, 创建一系列包装方法。语句no_namespace说明ADO对象不使用命名空间,rename ("EOF", "adoEOF")说明将ADO中结束标志EOF改为adoEOF,以避免和其它库中命名相冲突。
    其次,在程序初始过程中需要初始化组件,一般可以用CoInitialize(NULL);来实现,这种方法在结束时要关闭初始化的COM,可以用下面语 句CoUnInitialize();来实现。在MFC中还可以采用另一种方法来实现初始化COM,这种方法只需要一条语句便可以自动为我们实现初始化 COM和结束时关闭COM的操作,语句如下所示: AfxOleInit();
    接着,就可以直接使用ADO的操作了。我们经常使用的只是前面用#import语句引用类型库时,生成的包装类.tlh中声明的智能指针中的三个,它们分 别是_ConnectionPtr、_RecordsetPtr和_CommandPtr。下面分别对它们的使用方法进行介绍

    在介绍前我们先写个函数,本例中添加为类变量的静态函数

[cpp] view plaincopy

  1. //打印调用ADO控件时产生的详细错误信息  
  2. void CAdoRWAccessDlg::dump_com_error(_com_error &e)  
  3. {  
  4.     CString ErrorStr;  
  5.     _bstr_t bstrSource(e.Source());  
  6.     _bstr_t bstrDescription(e.Description());  
  7.     ErrorStr.Format( "/n/tADO Error/n/tCode = %08lx/n/tCode meaning = %s/n/tSource = %s/n/tDescription = %s/n/n",  
  8.         e.Error(), e.ErrorMessage(), (LPCTSTR)bstrSource, (LPCTSTR)bstrDescription );  
  9.     //在调试窗口中打印错误信息,在Release版中可用DBGView查看错误信息  
  10.     ::OutputDebugString((LPCTSTR)ErrorStr);  
  11. #ifdef _DEBUG  
  12.     AfxMessageBox(ErrorStr, MB_OK | MB_ICONERROR);  
  13. #endif    
  14. }  

 

1、_ConnectionPtr智能指针,通常用于打开、关闭一个库连接或用它的Execute方法来执行一个不返回结果的命令语句(用法和 _CommandPtr中的Execute方法类似)。
——打开一个库连接。先创建一个实例指针,再用Open打开一个库连接,它将返回一个IUnknown的自动化接口指针。代码如下所示:

在CAdoRWAccessApp中添加一个public的成员变量

[cpp] view plaincopy

  1. _ConnectionPtr  m_pConnection;  

在BOOL CAdoRWAccessApp::InitInstance()函数中

[cpp] view plaincopy

  1. // 初始化COM,创建ADO连接等操作  
  2. AfxOleInit();  
  3. m_pConnection.CreateInstance(__uuidof(Connection));  
  4. // 在ADO操作中建议语句中要常用try...catch()来捕获错误信息,  
  5. // 因为它有时会经常出现一些想不到的错误。jingzhou xu  
  6. try                   
  7. {     
  8.     // 打开本地Access库Demo.mdb  
  9.     m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Demo.mdb","","",adModeUnknown);  
  10.       
  11. }  
  12. catch(_com_error& e)  
  13. {  
  14.     //调用在CAdoRWAccessDlg中打印错误信息的静态函数  
  15.     CAdoRWAccessDlg::dump_com_error(e);  
  16.     return FALSE;  
  17. }  

——关闭一个库连接(本例中在CAdoRWAccessApp::ExitInstance())。如果连接状态有效,则用Close方法关闭它并赋于它空值。代码如下所示:

[cpp] view plaincopy

  1. // 关闭ADO连接状态  
  2. if(m_pConnection->State)  
  3.     m_pConnection->Close();  
  4. m_pConnection= NULL;  

2、_RecordsetPtr智能指针,可以用来打开库内数据表,并可以对表内的记录、字段等进行各种操作。
——打开数据表。打开库内表名为DemoTable的数据表,代码如下:

添加类成员变量

[cpp] view plaincopy

  1. _RecordsetPtr   m_pRecordset;  

在CAdoRWAccessDlg::OnInitDialog()中

[cpp] view plaincopy

  1. // 使用ADO创建数据库记录集  
  2. m_pRecordset.CreateInstance(__uuidof(Recordset));  
  3. // 在ADO操作中建议语句中要常用try...catch()来捕获错误信息,  
  4. // 因为它有时会经常出现一些想不到的错误。jingzhou xu  
  5. try  
  6. {  
  7.     m_pRecordset->Open("SELECT * FROM DemoTable",                // 查询DemoTable表中所有字段  
  8.                         theApp.m_pConnection.GetInterfacePtr(),  // 获取库接库的IDispatch指针  
  9.                         adOpenDynamic,  
  10.                         adLockOptimistic,  
  11.                         adCmdText);  
  12. }  
  13. catch(_com_error& e)  
  14. {  
  15.     dump_com_error(e);  
  16. }  

——读取表内数据。将表内数据全部读出并显示在列表框内,m_AccessList为列表框的成员变量名。如果没有遇到表结束标志adoEOF,则用 GetCollect(字段名)或m_pRecordset->Fields->GetItem(字段名)->Value方法,来获取 当前记录指针所指的字段值,然后再用MoveNext()方法移动到下一条记录位置。代码如下所示:

 

[cpp] view plaincopy

  1. _variant_t var;  
  2. CString strName,strAge;  
  3. // 清空列表框  
  4. m_AccessList.ResetContent();  
  5. strName=strAge="";  
  6. // 在ADO操作中建议语句中要常用try...catch()来捕获错误信息,  
  7. // 因为它有时会经常出现一些想不到的错误。jingzhou xu  
  8. try  
  9. {  
  10.     if(!m_pRecordset->BOF)  
  11.         m_pRecordset->MoveFirst();  
  12.     else  
  13.     {  
  14.         AfxMessageBox("表内数据为空");  
  15.         return;  
  16.     }  
  17.     // 读入库中各字段并加入列表框中  
  18.     while(!m_pRecordset->adoEOF)  
  19.     {  
  20.         var = m_pRecordset->GetCollect("Name");  
  21.         if(var.vt != VT_NULL)  
  22.             strName = (LPCSTR)_bstr_t(var);  
  23.         var = m_pRecordset->GetCollect("Age");  
  24.         if(var.vt != VT_NULL)  
  25.             strAge = (LPCSTR)_bstr_t(var);  
  26.         m_AccessList.AddString( strName + " --> "+strAge );  
  27.         m_pRecordset->MoveNext();  
  28.     }  
  29.     // 默认列表指向第一项,同时移动记录指针并显示  
  30.     m_AccessList.SetCurSel(0);  
  31.     OnSelchangeListaccess();  
  32. }  
  33. catch(_com_error& e)  
  34. {  
  35.     dump_com_error(e);  
  36. }  
 

——插入记录。可以先用AddNew()方法新增一个空记录,再用PutCollect(字段名,值)输入每个字段的值,最后再Update()更新到库 中数据既可。其中变量m_Name和m_Age分别为姓名及年龄编辑框的成员变量名。代码所下所示:

[cpp] view plaincopy

  1. // 在ADO操作中建议语句中要常用try...catch()来捕获错误信息,  
  2. // 因为它有时会经常出现一些想不到的错误。jingzhou xu  
  3. try  
  4. {  
  5.     // 写入各字段值  
  6.     m_pRecordset->AddNew();  
  7.     m_pRecordset->PutCollect("Name", _variant_t(m_Name));  
  8.     m_pRecordset->PutCollect("Age", atol(m_Age));  
  9.     m_pRecordset->Update();  
  10.     AfxMessageBox("插入成功!");  
  11.     // 更新显示其库内容  
  12.     int nCurSel = m_AccessList.GetCurSel();  
  13.     OnReadAccess();  
  14.     m_AccessList.SetCurSel(nCurSel);  
  15.     // 移动记录指针到新的位置  
  16.     OnSelchangeListaccess();  
  17. }  
  18. catch(_com_error& e)  
  19. {  
  20.     dump_com_error(e);  
  21. }  

——移动记录指针。移动记录指针可以通过MoveFirst()方法移动到第一条记录、MoveLast()方法移动到最后一条记录、 MovePrevious()方法移动到当前记录的前一条记录、MoveNext()方法移动到当前记录的下一条记录。但我们有时经常需要随意移动记录指 针到任意记录位置时,可以使用Move(记录号)方法来实现,注意: Move()方法是相对于当前记录来移动指针位置的,正值向后移动、负值向前移动,如:Move(3),当前记录是3时,它将从记录3开始往后再移动3条 记录位置。代码如下所示:

[cpp] view plaincopy

  1. try  
  2. {  
  3.     int curSel = m_AccessList.GetCurSel();    
  4.     // 先将指针移向第一条记录,然后就可以相对第一条记录来随意移动记录指针  
  5.     m_pRecordset->MoveFirst();  
  6.     m_pRecordset->Move(long(curSel));  
  7.       
  8. }  
  9. catch(_com_error& e)  
  10. {  
  11.     dump_com_error(e);  
  12. }   

——修改记录中字段值。可以将记录指针移动到要修改记录的位置处,直接用PutCollect(字段名,值)将新值写入并Update()更新数据库既 可。可以用上面方法移动记录指针,修改字段值代码如下所示:

[cpp] view plaincopy

  1. // 修改当前记录的字段值  
  2. try  
  3. {  
  4.     m_pRecordset->PutCollect("Name", _variant_t(m_Name));  
  5.     m_pRecordset->PutCollect("Age", atol(m_Age));  
  6.     m_pRecordset->Update();  
  7.     // 重新读入库记录更新显示  
  8.     int nCurSel = m_AccessList.GetCurSel();  
  9.     OnReadAccess();  
  10.     m_AccessList.SetCurSel(nCurSel);  
  11.     // 移动记录指针到新的位置  
  12.     OnSelchangeListaccess();  
  13. }  
  14. catch(_com_error& e)  
  15. {  
  16.     dump_com_error(e);  
  17. }  

——删除记录。删除记录和上面修改记录的操作类似,先将记录指针移动到要修改记录的位置,直接用Delete()方法删除它并用Update()来更新数 据库既可。代码如下所示:

[cpp] view plaincopy

  1. try  
  2. {  
  3.     // 删除当前行记录  
  4.     m_pRecordset->Delete(adAffectCurrent);  
  5.     m_pRecordset->Update();  
  6.     // 删除列表中当前值  
  7.     int nCurSel = m_AccessList.GetCurSel();  
  8.     m_AccessList.DeleteString(nCurSel);  
  9.     if(nCurSel == 0 && (m_AccessList.GetCount() != 0))  
  10.         m_AccessList.SetCurSel(nCurSel);  
  11.     else if(m_AccessList.GetCount() != 0)  
  12.         m_AccessList.SetCurSel(nCurSel-1);  
  13.       
  14.     // 移动记录指针到新的位置  
  15.     OnSelchangeListaccess();  
  16. }  
  17. catch(_com_error& e)  
  18. {  
  19.     dump_com_error(e);  
  20. }  

——关闭记录集。直接用Close方法关闭记录集并赋于其空值。代码如下所示:

[cpp] view plaincopy

  1. // 关闭记录集  
  2. if ( m_pRecordset != NULL )  
  3. {  
  4.     m_pRecordset->Close();  
  5.     m_pRecordset.Release();  
  6.     m_pRecordset = NULL;  
  7. }  

3、CommandPtr智能指针,可以使用_ConnectionPtr或_RecordsetPtr来执行任务,定义输出参数,执行存储过程或SQL 语句。 
——执行SQL语句。先创建一个_CommandPtr实例指针,再将库连接和SQL语句做为参数,执行Execute()方法既可。代码如下所示:

[cpp] view plaincopy

  1. _CommandPtr     m_pCommand;  
  2. m_pCommand.CreateInstance(__uuidof(Command));  
  3. m_pCommand->ActiveConnection = theApp.m_pConnection;  // 将库连接赋于它  
  4. m_pCommand->CommandText = _bstr_t((LPCTSTR)m_strCommand);  // SQL语句  
  5. try   
  6. {  
  7.     // 执行SQL语句,返回记录集,此记录不能做插入操作  
  8.     // 故为了不和m_pRecordset相冲突, 放入新定义的m_pRecordset1  
  9.     m_pRecordset1 = m_pCommand->Execute( NULL, NULL, adCmdText);   
  10. }  
  11. catch(_com_error& e)  
  12. {  
  13.     dump_com_error(e);  
  14. }  

——执行存储过程。执行存储过程的操作和上面执行SQL语句类似,不同点仅是CommandText参数中不再是SQL语句,而是存储过程的名字,如 Demo。另一个不同点就是在Execute()中参数由adCmdText(执行SQL语句),改为adCmdStoredProc来执行存储过程。如 果存储过程中存在输入、输出参数的话,需要使用到另一个智能指针_ParameterPtr来逐次设置要输入、输出的参数信息,并将其赋于 _CommandPtr中Parameters参数来传递信息,有兴趣的读者可以自行查找相关书籍或MSDN。执行存储过程的代码如下所示:

[cpp] view plaincopy

  1. _CommandPtr     m_pCommand;  
  2. m_pCommand.CreateInstance(__uuidof(Command));  
  3.   m_pCommand->ActiveConnection = m_pConnection;  // 将库连接赋于它  
  4. m_pCommand->CommandText = "Demo";    
  5.   m_pCommand->Execute(NULL,NULL, adCmdStoredProc);     

最后,如果想知道详细实现细节的话,可以在下载示例源码后,仔细查看源码既可(内有详细注释)。 

联系方式: 地址:陕西省西安市劳动路2号院六单元  
邮编:710082 
作者EMAIL:jingzhou_xu@163.net 
未来工作室(Future Studio)


본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

DeepSeek PDF를 변환하는 방법 DeepSeek PDF를 변환하는 방법 Feb 19, 2025 pm 05:24 PM

DeepSeek은 파일을 PDF로 직접 변환 할 수 없습니다. 파일 유형에 따라 공통 문서 (Word, Excel, PowerPoint) : Microsoft Office, LibreOffice 및 기타 소프트웨어를 사용하여 PDF로 내보내십시오. 이미지 : 이미지 뷰어 또는 이미지 처리 소프트웨어를 사용하여 PDF로 저장하십시오. 웹 페이지 : 브라우저의 "PDF로 인쇄"기능 또는 전용 웹 페이지에서 PDF 도구를 사용하십시오. 드문 형식 : 오른쪽 변환기를 찾아 PDF로 변환하십시오. 올바른 도구를 선택하고 실제 상황에 따라 계획을 개발하는 것이 중요합니다.

오라클에서 dbf 파일을 읽는 방법 오라클에서 dbf 파일을 읽는 방법 May 10, 2024 am 01:27 AM

Oracle은 다음 단계를 통해 dbf 파일을 읽을 수 있습니다. 외부 테이블을 만들고 dbf 파일을 참조하여 데이터를 Oracle 테이블로 가져옵니다.

iOS 18에는 손실되거나 손상된 사진을 검색할 수 있는 새로운 '복구된' 앨범 기능이 추가되었습니다. iOS 18에는 손실되거나 손상된 사진을 검색할 수 있는 새로운 '복구된' 앨범 기능이 추가되었습니다. Jul 18, 2024 am 05:48 AM

Apple의 최신 iOS18, iPadOS18 및 macOS Sequoia 시스템 릴리스에는 사진 애플리케이션에 중요한 기능이 추가되었습니다. 이 기능은 사용자가 다양한 이유로 손실되거나 손상된 사진과 비디오를 쉽게 복구할 수 있도록 설계되었습니다. 새로운 기능에는 사진 앱의 도구 섹션에 '복구됨'이라는 앨범이 도입되었습니다. 이 앨범은 사용자가 기기에 사진 라이브러리에 포함되지 않은 사진이나 비디오를 가지고 있을 때 자동으로 나타납니다. "복구된" 앨범의 출현은 데이터베이스 손상으로 인해 손실된 사진과 비디오, 사진 라이브러리에 올바르게 저장되지 않은 카메라 응용 프로그램 또는 사진 라이브러리를 관리하는 타사 응용 프로그램에 대한 솔루션을 제공합니다. 사용자는 몇 가지 간단한 단계만 거치면 됩니다.

PHP에서 데이터베이스 연결 오류를 처리하는 방법 PHP에서 데이터베이스 연결 오류를 처리하는 방법 Jun 05, 2024 pm 02:16 PM

PHP에서 데이터베이스 연결 오류를 처리하려면 다음 단계를 사용할 수 있습니다. mysqli_connect_errno()를 사용하여 오류 코드를 얻습니다. 오류 메시지를 얻으려면 mysqli_connect_error()를 사용하십시오. 이러한 오류 메시지를 캡처하고 기록하면 데이터베이스 연결 문제를 쉽게 식별하고 해결할 수 있어 애플리케이션이 원활하게 실행될 수 있습니다.

PHP에서 MySQLi를 사용하여 데이터베이스 연결을 설정하는 방법에 대한 자세한 튜토리얼 PHP에서 MySQLi를 사용하여 데이터베이스 연결을 설정하는 방법에 대한 자세한 튜토리얼 Jun 04, 2024 pm 01:42 PM

MySQLi를 사용하여 PHP에서 데이터베이스 연결을 설정하는 방법: MySQLi 확장 포함(require_once) 연결 함수 생성(functionconnect_to_db) 연결 함수 호출($conn=connect_to_db()) 쿼리 실행($result=$conn->query()) 닫기 연결( $conn->close())

Astar 스테이킹 원칙, 수입 해체, 에어드랍 프로젝트 및 전략 및 운영 보모 수준 전략 Astar 스테이킹 원칙, 수입 해체, 에어드랍 프로젝트 및 전략 및 운영 보모 수준 전략 Jun 25, 2024 pm 07:09 PM

목차 Astar Dapp 스테이킹 원리 스테이킹 수익 잠재적 에어드랍 프로젝트 해체: AlgemNeurolancheHealThreeAstar Degens DAOVeryLongSwap 스테이킹 전략 및 운영 "AstarDapp 스테이킹"이 올해 초 V3 버전으로 업그레이드되었으며 스테이킹 수익에 많은 조정이 이루어졌습니다. 규칙. 현재 첫 번째 스테이킹 주기는 종료되었으며 두 번째 스테이킹 주기의 "투표" 하위 주기가 막 시작되었습니다. '추가 보상' 혜택을 받으려면 이 중요한 단계(6월 26일까지 지속 예정, 5일 미만 남았음)를 파악해야 합니다. 아스타 스테이킹 수익을 자세하게 분석해보겠습니다.

Golang에서 데이터베이스 콜백 함수를 사용하는 방법은 무엇입니까? Golang에서 데이터베이스 콜백 함수를 사용하는 방법은 무엇입니까? Jun 03, 2024 pm 02:20 PM

Golang의 데이터베이스 콜백 기능을 사용하면 다음을 달성할 수 있습니다. 지정된 데이터베이스 작업이 완료된 후 사용자 정의 코드를 실행합니다. 추가 코드를 작성하지 않고도 별도의 함수를 통해 사용자 정의 동작을 추가할 수 있습니다. 삽입, 업데이트, 삭제, 쿼리 작업에 콜백 함수를 사용할 수 있습니다. 콜백 함수를 사용하려면 sql.Exec, sql.QueryRow, sql.Query 함수를 사용해야 합니다.

Golang을 사용하여 원격 데이터베이스에 연결하는 방법은 무엇입니까? Golang을 사용하여 원격 데이터베이스에 연결하는 방법은 무엇입니까? Jun 01, 2024 pm 08:31 PM

Go 표준 라이브러리 데이터베이스/sql 패키지를 통해 MySQL, PostgreSQL 또는 SQLite와 같은 원격 데이터베이스에 연결할 수 있습니다. 데이터베이스 연결 정보가 포함된 연결 문자열을 생성합니다. sql.Open() 함수를 사용하여 데이터베이스 연결을 엽니다. SQL 쿼리 및 삽입 작업과 같은 데이터베이스 작업을 수행합니다. 리소스를 해제하기 위해 defer를 사용하여 데이터베이스 연결을 닫습니다.

See all articles