c/c++使用VS2013连接MySQL_MySQL
vs连接数据库其实就是将mysql数据库.h头文件接口、lib链接文件和dll执行文件加入到项目中。下面是配置如何加入。
转于http://www.cnblogs.com/justinzhang/archive/2011/09/23/2185963.html
一、VS2013工程设置工作
首先,建立一个windows应用程序的工程,将C/C++->预处理器->预处理器定义下的_WINDOWS改为_CONSOLE,
将连接器->系统->子系统 选择为控制台。
由于我们要使用Mysql的API,并且我们机子上肯定安装了Mysql数据库,所以我们要将工程的头文件路径指向Mysql安装目录的同文件mysql.h所在的位置,将连接库路径指向libmysql.lib所在的路径,
在我的机子上,Mysql 的安装路径为:C:\Program Files\MySQL\MySQL Server 5.1
我们需要把VS2008的工程中的头文件路径和连接库路径指向上面的两个地方:
将x项目属性页的C/C++->常规->附加包含目录指向:C:\Program Files\MySQL\MySQL Server 5.1\include
将项目属性页的链接器->常规->附加库目录指向:C:\Program Files\MySQL\MySQL Server 5.1\lib\opt.
将链接器->输入->附加依赖项中添加libmysql.lib。
如果不设置链接器->输入->附加依赖项中添加libmysql.lib,那么会出现如下的错误:
1>------ 已启动全部重新生成: 项目: MySql-Connect, 配置: Debug Win32 ------
1>正在删除项目“MySql-Connect”(配置“Debug|Win32”)的中间文件和输出文件
1>正在编译...
1>MySql_Connect.cpp
1>x:\编程练习\c-c++\c\mysql_connect.cpp(35) : warning C4996: 'scanf': This function or variable may be unsafe. Consider using scanf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
1> d:\program files\microsoft visual studio 9.0\vc\include\stdio.h(306) : 参见“scanf”的声明
1>x:\编程练习\c-c++\c\mysql_connect.cpp(72) : warning C4996: 'sprintf': This function or variable may be unsafe. Consider using sprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
1> d:\program files\microsoft visual studio 9.0\vc\include\stdio.h(366) : 参见“sprintf”的声明
1>x:\编程练习\c-c++\c\mysql_connect.cpp(86) : warning C4996: 'sprintf': This function or variable may be unsafe. Consider using sprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
1> d:\program files\microsoft visual studio 9.0\vc\include\stdio.h(366) : 参见“sprintf”的声明
1>正在编译资源清单...
1>Microsoft (R) Windows (R) Resource Compiler Version 6.1.6723.1
1>Copyright (C) Microsoft Corporation. All rights reserved.
1>正在链接...
1>LINK : 没有找到 d:\我的文档\Visual Studio 2008\Projects\MySql-Connect\Debug\MySql-Connect.exe 或上一个增量链接没有生成它;正在执行完全链接
1>MySql_Connect.obj : error LNK2019: 无法解析的外部符号 _mysql_close@4,该符号在函数 _main 中被引用
1>MySql_Connect.obj : error LNK2019: 无法解析的外部符号 _mysql_free_result@4,该符号在函数 _main 中被引用
1>MySql_Connect.obj : error LNK2019: 无法解析的外部符号 _mysql_num_fields@4,该符号在函数 _main 中被引用
1>MySql_Connect.obj : error LNK2019: 无法解析的外部符号 _mysql_fetch_row@4,该符号在函数 _main 中被引用
1>MySql_Connect.obj : error LNK2019: 无法解析的外部符号 _mysql_store_result@4,该符号在函数 _main 中被引用
1>MySql_Connect.obj : error LNK2019: 无法解析的外部符号 _mysql_error@4,该符号在函数 _main 中被引用
1>MySql_Connect.obj : error LNK2019: 无法解析的外部符号 _mysql_real_query@12,该符号在函数 _main 中被引用
1>MySql_Connect.obj : error LNK2019: 无法解析的外部符号 _mysql_select_db@8,该符号在函数 _main 中被引用
1>MySql_Connect.obj : error LNK2019: 无法解析的外部符号 _mysql_real_connect@32,该符号在函数 _main 中被引用
1>MySql_Connect.obj : error LNK2019: 无法解析的外部符号 _mysql_init@4,该符号在函数 _main 中被引用
1>d:\我的文档\Visual Studio 2008\Projects\MySql-Connect\Debug\MySql-Connect.exe : fatal error LNK1120: 10 个无法解析的外部命令
1>生成日志保存在“file://d:\我的文档\Visual Studio 2008\Projects\MySql-Connect\MySql-Connect\Debug\BuildLog.htm”
1>MySql-Connect - 11 个错误,3 个警告
========== 全部重新生成: 成功 0 个,失败 1 个,跳过 0 个 ==========
如果到这里你还没成功,继续看下面的解析:
之前经过配置,成功的在vs2013中成功的用c语言连接上的MySQL数据库,但是最近连接MySQL数据库,无论怎么配置,老是出错。
代码如下:
<ol class="dp-cpp"><li class="alt">#include <windows.h> #include <stdio.h> <li class="alt">#include <string.h> #include <mysql.h> <li class="alt"> #pragma comment (lib, "libmysql.lib") <li class="alt">#pragma comment (lib, "mysqlclient.lib") <li class="alt">int main() { <li class="alt"> char szTargetDSN[] = "test"; char szSqlText[500]=""; <li class="alt"> MYSQL * myData; myData = mysql_init((MYSQL*)0); <li class="alt"> //连接数据库 <li class="alt"> if(mysql_real_connect( myData, NULL, "root", "123456", szTargetDSN, MYSQL_PORT, NULL, 0)) { <li class="alt"> printf("数据库连接成功!/n"); //构造SQL语句 <li class="alt"> sprintf(szSqlText, "create table mytable" "(time datetime, s1 char(6), " "s2 char(11), s3 int, s4 int)"); if (mysql_query( myData, szSqlText)) <li class="alt"> {//执行SQL语句出错 printf( "Can't create table"); <li class="alt"> mysql_close( myData ); return FALSE; <li class="alt"> } printf("表创建成功/n"); <li class="alt"> mysql_close(myData); } <li class="alt"> return TRUE; <li class="alt">}
错误如下:
error LNK2019: 无法解析的外部符号 _mysql_real_connect@32,该符号在函数 _main 中被引用
error LNK2019: 无法解析的外部符号 _mysql_query@8,该符号在函数 _main 中被引用
error LNK2019: 无法解析的外部符号 _mysql_init@4,该符号在函数 _main 中被引用
error LNK2019: 无法解析的外部符号 _mysql_close@4,该符号在函数 _main 中被引用
采用了以下的办法:
点击
1.项目->属性->vc++目录。
然后在"包含目录"中添加"E:/Program Files/MySQL/MySQL Server 5.5/include"
“库目录”中添加"E:/Program Files/MySQL/MySQL Server 5.5/lib"和"E:/Program Files/MySQL/MySQL Server 5.5/lib/Debug"。
2.项目->属性->链接器->输入->附加依赖项中添加libmysql.lib
但是编译依旧还是同样的问题。
于是开始思考,
lib是编译时需要的,dll是运行时需要的。
如果要完成源代码的编译,有lib就够了。
如果也使动态连接的程序运行起来,有dll就够了。
在开发和调试阶段,当然最好都有。
一般的动态库程序有lib文件和dll文件。lib文件是必须在编译期就连接到应用程序中的,而dll文件是运行期才会被调用的。如果有dll文件,那么对应的lib文件一般是一些索引信息,具体的实现在dll文件中。如果只有lib文件,那么这个lib文件是静态编译出来的,索引和实现都在其中。静态编译的lib文件有好处:给用户安装时就不需要再挂动态库了。但也有缺点,就是导致应用程序比较大,而且失去了动态库的灵活性,在版本升级时,同时要发布新的应用程序才行。
1.编译是通过静态链接库(lib)去找到接口的。
2.#pragma comment (lib, "libmysql.lib")
#pragma comment (lib, "mysqlclient.lib")
但是这两句代码并没有报错,证明这两个链接库也正常加入了啊。怎么还是出现“无法解析的外部符号”,很纳闷。
百思不得其解,踏遍百度谷歌必应。还是木有办法,或许就是那么灵光一闪,我擦。突然想起一个问题了。哥哥我装的是win7 64位啊,MySQL也是赤裸裸的64位,丫的,我用WIN32 项目搞毛线。于是有一个猜想就是,MySQL 64位的lib也是64位的接口。
于是用了两部去证明这个想法,
.项目->属性->配置管理器
活动解决方案平台,下拉选新建,出现一个新的对号框,在键入选择新平台中选择X64
最后重新编译,这次完全证明的我想法是对的。编译成功。哦也!
最后分析一下解决这个问题关键,其实这个问题很简单。搞明白dll和lib的作用,或许都能分析出这个问题了原因了。
写到这,再去搜索果不其然
http://www.linuxso.com/sql/19105.html
再一次说明,遇到问题要善于思考。
本文出自 “小桥流水的技术博客” 博客,请务必保留此出处http://idear.blog.bitsCN.com/4097017/871174
最后,也可以直接将.h文件和dll文件加到你的工程目录里。

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











상수는 변수라고도 하며 일단 정의되면 프로그램이 실행되는 동안 그 값이 변경되지 않습니다. 따라서 변수를 고정된 값을 참조하는 상수로 선언할 수 있습니다. 텍스트라고도 합니다. 상수는 Const 키워드를 사용하여 정의해야 합니다. 구문 C 프로그래밍 언어에서 사용되는 상수의 구문은 다음과 같습니다. - consttypeVariableName; (또는) consttype*VariableName; 다양한 유형의 상수 C 프로그래밍 언어에서 사용되는 다양한 유형의 상수는 다음과 같습니다. 정수 상수 - 예: 1,0 ,34, 4567 부동 소수점 상수 - 예: 0.0, 156.89, 23.456 8진수 및 16진수 상수 - 예: 16진수: 0x2a, 0xaa.. 8진수

VS Code 및 Visual Studio C++ IntelliSense는 특히 대규모 프로젝트에서 작업할 때 라이브러리를 선택하지 못할 수 있습니다. #Include<wx/wx.h> 위로 마우스를 가져가면 "소스 파일 'string.h'를 열 수 없습니다."("wx/wx.h"에 따라 다름)라는 오류 메시지가 표시되며, 자동 완성 기능이 응답하지 않는 경우도 있습니다. 이 문서에서는 VSCode 및 VSC++ IntelliSense가 작동하지 않거나 라이브러리를 추출하지 않는 경우 수행할 수 있는 작업을 살펴보겠습니다. 내 Intellisense가 C++에서 작동하지 않는 이유는 무엇입니까? 대용량 파일을 작업할 때 IntelliSense가 가끔

오류 코드 8C230002로 인해 Xbox에서 콘텐츠를 구매하거나 시청할 수 없습니까? 일부 사용자가 본체에서 콘텐츠를 구매하거나 시청하려고 할 때 이 오류가 계속 발생합니다. 죄송합니다. Xbox 서비스에 문제가 있습니다. 나중에 다시 시도해 보세요. 이 문제에 대한 도움말을 보려면 www.xbox.com/errorhelp를 방문하세요. 상태 코드: 8C230002 이 오류 코드는 일반적으로 일시적인 서버 또는 네트워크 문제로 인해 발생합니다. 그러나 계정의 개인 정보 보호 설정이나 자녀 보호 기능 등 다른 이유로 인해 특정 콘텐츠를 구매하거나 시청하지 못할 수도 있습니다. Xbox 오류 코드 8C230002 수정 Xbox 콘솔에서 콘텐츠를 보거나 구매하려고 할 때 오류 코드 8C가 나타나는 경우

정수 배열 Arr[]을 입력으로 사용합니다. 목표는 재귀적 방법을 사용하여 배열에서 가장 큰 요소와 가장 작은 요소를 찾는 것입니다. 재귀를 사용하고 있으므로 길이 = 1에 도달할 때까지 전체 배열을 반복한 다음 기본 사례를 구성하는 A[0]을 반환합니다. 그렇지 않은 경우 현재 요소는 현재 최소값 또는 최대값과 비교되고 해당 값은 후속 요소에 대해 반복적으로 업데이트됩니다. 이에 대한 다양한 입력 및 출력 시나리오를 살펴보겠습니다. −Input −Arr={12,67,99,76,32} Output −배열의 최대값: 99 설명 &mi

25일 뉴스에 따르면 중국동방항공은 성과보고회에서 C919 여객기의 최신 진행 상황을 공개했다. 회사에 따르면 COMAC과 체결한 C919 구매 계약은 2021년 3월 공식 발효됐으며, 첫 번째 C919 항공기는 2022년 말까지 인도됐다. 조만간 해당 항공기가 정식으로 실제 운항에 들어갈 것으로 예상된다. 중국동방항공은 상하이를 C919 상용 운항의 주요 기지로 삼아 2022년과 2023년 총 5대의 C919 여객기를 도입할 계획이다. 회사 측은 향후 도입 계획은 실제 운행 상황과 노선망 계획 등을 토대로 결정할 예정이라고 밝혔다. 편집자의 이해에 따르면 C919는 완전히 독립적인 지적 재산권을 보유하고 국제적으로 인정된 감항성 표준을 준수하는 중국의 차세대 글로벌 단일 통로 간선 여객기입니다. 해야 한다

숫자를 다양한 형식으로 표시하는 것은 학습의 기본 코딩 문제 중 하나입니다. 조건문 및 루프문과 같은 다양한 코딩 개념. 별표와 같은 특수 문자를 사용하여 삼각형이나 사각형을 인쇄하는 다양한 프로그램이 있습니다. 이 기사에서는 C++의 사각형처럼 나선형 형태로 숫자를 인쇄합니다. 행 수 n을 입력으로 사용하고 왼쪽 상단에서 시작하여 오른쪽, 아래, 왼쪽, 위, 다시 오른쪽 등으로 이동합니다. 숫자가 포함된 나선형 패턴 123456724252627282982340414243309223948494431102138474645321120373635343312191817161514

C에서 void는 특정 유형이 없는 데이터를 의미하는 빈 유형을 나타내는 데 사용되는 특수 키워드입니다. C 언어에서 void는 주로 다음 세 가지 측면에서 사용됩니다. 함수 반환 유형은 void입니다. C 언어에서 함수는 int, float, char 등과 같은 다양한 반환 유형을 가질 수 있습니다. 그러나 함수가 어떤 값도 반환하지 않는 경우 반환 유형을 void로 설정할 수 있습니다. 이는 함수가 실행된 후에 특정 값을 반환하지 않음을 의미합니다. 예: voidhelloWorld()

프로그래밍 언어의 인기도를 측정하는 벤치마크 중 하나인 TIOBE 프로그래밍 커뮤니티 지수(TIOBE 프로그래밍 커뮤니티 지수)에 따르면 전 세계 엔지니어, 강좌, 벤더, 검색 엔진으로부터 데이터를 수집하여 평가합니다. 최근 2024년 1월 TIOBE 지수가 발표되었으며, 2023년 공식 프로그래밍 언어 순위가 발표되었습니다. C#이 TIOBE 2023 올해의 프로그래밍 언어상을 수상한 것은 C#이 23년 만에 처음입니다. TIOBE의 공식 보도 자료에 따르면 C#은 20년 넘게 상위 10위 안에 들었으며 이제 4대 언어를 따라잡으며 1년 만에 가장 큰 성장(+1.43%)을 달성한 프로그래밍 언어가 되었습니다. 이 상을 받는 것은 당연한 일입니다. 2위는 스크래치(+0.83%)와 포트란(+0)입니다.
