mysql使用VS2013编译

mysql-5.7.43使用boost boost_1_59_0.tar.gz

ssl版本必须与mysql版本对应,这里用3就不行,用Win64OpenSSL-1_1_1v.msi可以通过;安装SSL后还需要下载ssl 1.1.1.tar.gz,用perl 采用no-nasm参数编译出库,记住ssl只能采用1.1.1g版本。

1.编译环境准备
(1).perl(OpenSSL的编译需要使用到perl的环境)
推荐perl下载ActivePerl安装,activePerl只能采用5.20以下版本。

(2).openssl(推荐下载最新 https://www.openssl.org/source/openssl-1.1.1g.tar.gzopenssl-1.1.1g.tar.gz)
下载完成之后解压。

(3).vs2015
会用到vs的vc中的nmake。开始程序打开VS2013,VS2013 x64 本机工具命令提示.

  1. 编译
    2.1先打开vs2015中的vc命令行。执行vcvarsall.bat 批处理文件。(在OpenSSL目录下使用nmake做准备,否则会报错找不到nmake)
    2.2 cd到OpenSSL源码所在路径。
perl Configure VC-WIN64A no-asm --prefix=d:\openssl_lib

注意是VC-WIN64A

Configure 后面的选项可选值有 VC-WIN32(32位) | VC-WIN64A(64位AMD) | VC-WIN64I(64位Intel) | VC-CE(Windows CE)
prefix: 表示生成的lib文件存放路径

编译源码:
nmake

生成可执行文件:
nmake install

执行完成上面的三个步骤之后在d:\openssl_lib这个目录下面会生成四个文件夹(include/lib/bin/html):

include目录下面存放的shi头文件
lib目录是生成的静态库文件,文件的后缀是.lib
bin目录下面存放的是dll文件和exe文件
html目录下面存放的是文档

重点:要把源码包openssl-1.1.1g.tar.gz里面的libcrypto_static.lib,libssl_static.lib文件复制到c:\program files\OpenSSL-Win64的lib文件夹里面,否则后面报错

再把源码包里面的静态库复制到安装好的SSL文件夹,c:\program files\OpenSSL-Win64文件夹

bison这块安装在C盘根目录无空格文件后,将文件夹复制到别处,卸载BISON,再复制到C盘根目录并添加PATH,采用路径CMAKE

在mysql5.7.43下新建bld,在bld下面运行:

cmake ..   -DDOWNLOAD_BOOST=1  -DWITH_BOOST="D:\mysql-5.7.43\zodboost" -G "Visual Studio 12 2013 Win64" -DBISON_EXECUTABLE="C:\GnuWin32\bin\bison.exe" 

win7测试
cmake ..  -DWITH_BOOST="D:\mysql-5.7.43\BOOST\boost_1_59_0.tar.gz"  -G "Visual Studio 12 2013 Win64" -DBISON_EXECUTABLE="C:\GnuWin32\bin\bison.exe" 


win11测试成功的:

cmake .. -DDOWNLOAD_BOOST=1 -DWITH_BOOST="D:\mysql-5.7.43\BOOST\boost_1_59_0.tar.gz"  -G "Visual Studio 12 2013 Win64" -DBISON_EXECUTABLE="C:\GnuWin32\bin\bison.exe" 

打开sln后,

1.打开 MySQL 的调试模式,文件路径如下:D:\mysql-5.7.43\sql\sql_locale.cc,记事本打开UTF8保存

Mysql源码阅读 -- Windows10编译运行MySQL源码_c++_萧_InfoQ写作社区

Windows下编译MySQL源码 - alvin131 - 博客园

如果遇到boost 和ssl报错要检查上面命令有没有指定路径

部分文件需要进行UTF8转换

最后再bld里面用

注意"D:\mysql-5.7.43\bld\sql\Debug\gen_lex_hash.exe"

gen_lex_hash.exe >lex_hash.h

编译MySQL时找不到"lex_hash.h"文件的解决方法-CSDN博客

cmake --build . --config relwithdebinfo --target package

打包即可

如果遇到bison.exe m4 invalid argument错误

把m4.exe复制到工作目录sql里,同时下载regex2.dll放到WOW64和system32下

regex2.dll下载,regex2.dll文件丢失修复 (ijinshan.com)

debug模式记得mysqld --console --initialize

mysqld --initialize建立data文件,data文件里找err里的密码

必须用mysql -uroot -p密码登录,在>后输入set password=password('root');

alter user 'root'@'localhost'password expire never;//设置永不过期

flush privileges;//刷新

skip-grant-tables

update user set authentication_string = password ( 'root' ) where user = 'root';

SET GLOBAL time_zone='+08:00';

show global variables like "%datadir%";

show global variables like "%basedir%";

root密码

*81F5E21E35407D884A6CD4A731AEBFB6AF209E1B

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值