OS: Windows XP sp3

IDE: VS2010

MariaDB: V5.5

(到目前为止2016.5,中文域(.cn)只有清华大学 TUNA 镜像源可用)

(.tar.gz为源码;.zip为执行程序)

Source: https://mirrors.tuna.tsinghua.edu.cn/mariadb//mariadb-5.5.49/source/mariadb-5.5.49.tar.gz

Zip: https://mirrors.tuna.tsinghua.edu.cn/mariadb//mariadb-5.5.49/win32-packages/mariadb-5.5.49-win32.zip

首先安装如下工具和Boost库:

(1) Bazzar

https://launchpad.net/bzr/2.5/2.5.1/+download/bzr-2.5.1-1-setup.exe

(2) Bison from GnuWin32

http://jaist.dl.sourceforge.net/project/gnuwin32/bison/2.4.1/bison-2.4.1-setup.exe

(3) Cmake

https://cmake.org/files/v3.4/cmake-3.4.3-win32-x86.exe

V3.4.3是可以在XP中运行的。

Boost库:

(1) 下载

http://www.boost.org/users/download/

当前最新版本为V1.61.0

(2) 设置系统变量

a. BOOST_HOME

C:\boost_1_61_0

b. 增加变量到path

然后执行编译:

检查系统变量path,以保证包含如下设置:

C:\Program Files\Bazaar;C:\GnuWin32\bin;C:\boost_1_61_0;C:\Program Files\CMake\bin

(1)cmake ..

Microsoft Windows XP [版本 ]
(C) 版权所有 - Microsoft Corp.

C:\Documents and Settings\Administrator>d:

D:\>cd mariadb-

D:\mariadb->mkdir bld

D:\mariadb->cd bld

D:\mariadb-\bld>cmake ..
-- Building
-- Running cmake version
-- The C compiler identification is MSVC 16.0.40219.1
-- The CXX compiler identification is MSVC 16.0.40219.1
-- Check
-- Check   -- works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Check
-- Check   -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Detecting CXX compile features
-- Detecting CXX compile features - done
-- Looking for isnan
-- Looking for isnan - not found
-- Looking for snprintf
-- Looking for snprintf - not found
-- Looking for _snprintf
-- Looking for _snprintf - found
-- MariaDB
-- Check size of void *
-- Check size of void * - done
-- Packaging as: mariadb--win32
-- Looking for pthread.h
-- Looking for pthread.h - not found
-- Found Threads: TRUE
-- Looking for isnan
-- Looking for isnan - not found
-- Check size of time_t
-- Check size of time_t - done
-- Performing Test STRUCT_TIMESPEC_HAS_TV_SEC
-- Performing Test STRUCT_TIMESPEC_HAS_TV_SEC - Failed
-- Performing Test STRUCT_TIMESPEC_HAS_TV_NSEC
-- Performing Test STRUCT_TIMESPEC_HAS_TV_NSEC - Failed
-- Looking for malloc_stats_print in jemalloc
-- Looking for malloc_stats_print in jemalloc - not found
-- Performing Test HAVE_WVLA
-- Performing Test HAVE_WVLA - Failed
-- Performing Test HAVE_WERROR
-- Performing Test HAVE_WERROR - Failed
-- Boost version:
-- Performing Test HAVE_XUCRED
-- Performing Test HAVE_XUCRED - Failed
-- Looking for MFC
-- Looking for MFC - found
-- Configuring done
-- Generating done
-- Build files have been written to: D:/mariadb-/bld

D:\mariadb-\bld>

(2) sql/sql_locale.cc

使用UE打开此文件并另存为同名。不同之处在于,更改“Format”!

(3) 生成

cmake --build . --config Relwithdebinfo

最后,拷贝文件。

拷贝以下两个文件覆盖到D:\progFiles\MariaDB55\bin,以替换不能在XP运行的程序。

bld\sql\RelWithDebInfo\mysqld.exe

bld\sql\RelWithDebInfo\mysqld.pdb

FAQ:

1. error C2027: use of undefined type 'boost::STATIC_ASSERTION_FAILURE'

在进行storage\oqgraph目录编译时发生错误。

编译日志:file:///D:/mariadb-5.5.49/bld/storage/oqgraph/oqgraph.dir/RelWithDebInfo/BuildLog.htm

Build Log

Build started: Project: oqgraph, Configuration: RelWithDebInfo|Win32

Command Lines

Creating temporary file "d:\mariadb-5.5.49\bld\storage\oqgraph\oqgraph.dir\RelWithDebInfo\RSP00015042369588.rsp" with contents
[
/O2 /Ob1 /I "C:\boost_1_61_0" /I "D:\mariadb-5.5.49\bld\include" /I "D:\mariadb-5.5.49\include" /I "D:\mariadb-5.5.49\sql" /I "D:\mariadb-5.5.49\regex" /I "D:\mariadb-5.5.49\extra\yassl\include" /I "D:\mariadb-5.5.49\extra\yassl\taocrypt\include" /I "D:\mariadb-5.5.49\zlib" /D "WIN32" /D "_WINDOWS" /D "NDEBUG" /D "DBUG_OFF" /D "MYSQL_DYNAMIC_PLUGIN" /D "__WIN__" /D "_CRT_SECURE_NO_DEPRECATE" /D "_WIN32_WINNT=0x0501" /D "NOMINMAX" /D "WIN32_LEAN_AND_MEAN" /D "HAVE_CONFIG_H" /D "HAVE_OQGRAPH" /D "CMAKE_INTDIR=\"RelWithDebInfo\"" /D "oqgraph_EXPORTS" /D "_WINDLL" /D "_MBCS" /FD /EHsc /MT /Fo"oqgraph.dir\RelWithDebInfo\\" /Fd"oqgraph.dir\RelWithDebInfo\vc90.pdb" /W3 /c /Z7 /TP /wd4800 /wd4805 /wd4996 /wd4291   /MP /we4099

"..\..\..\storage\oqgraph\graphcore.cc"

"..\..\..\storage\oqgraph\ha_oqgraph.cc"
]
Creating command line \bld\storage\oqgraph\oqgraph.dir\RelWithDebInfo\RSP00015042369588.rsp" /nologo /errorReport:queue"
Output Window

Compiling...
graphcore.cc
ha_oqgraph.cc
C:\boost_1_61_0\boost/type_traits/detail/common_arithmetic_type.hpp : warning C4819: The ). Save the file in Unicode format to prevent data loss
C:\boost_1_61_0\boost/graph/named_graph.hpp() : error C2027: use of undefined type 'boost::STATIC_ASSERTION_FAILURE'
        with
        [
            x=false
        ]
        C:\boost_1_61_0\boost/graph/detail/adjacency_list.hpp() : see reference to function template instantiation 'void boost::graph::named_graph::removing_vertex(Vertex,VertexIterStability)' being compiled
        with
        [
            Graph=boost::adjacency_list,
            Vertex=unsigned int,
            VertexProperty=open_query::VertexInfo,
            VertexIterStability=boost::graph_detail::unstable_tag
        ]
        ..\..\..\storage\oqgraph\graphcore.) : see reference to function template instantiation 'void boost::remove_vertex::config,boost::bidirectional_graph_helper_with_property>(unsigned int,boost::vec_adj_list_impl &)' being compiled
        with
        [
            Graph=boost::adjacency_list,
            VertexListS=boost::vecS,
            OutEdgeListS=boost::vecS,
            DirectedS=boost::bidirectionalS,
            VertexProperty=open_query::VertexInfo,
            EdgeProperty=open_query::EdgeInfo,
            GraphProperty=boost::no_property,
            EdgeListS=boost::listS,
            Config=boost::detail::adj_list_gen,boost::vecS,boost::vecS,boost::bidirectionalS,open_query::VertexInfo,open_query::EdgeInfo,boost::no_property,boost::listS>::config,
            Base=boost::bidirectional_graph_helper_with_property,boost::vecS,boost::vecS,boost::bidirectionalS,open_query::VertexInfo,open_query::EdgeInfo,boost::no_property,boost::listS>::config>
        ]
Results

Build log was saved at "file://d:\mariadb-5.5.49\bld\storage\oqgraph\oqgraph.dir\RelWithDebInfo\BuildLog.htm"
oqgraph -  error(s),  warning(s)

Build Log

解决办法:

注释掉named_graph.hpp(C:\boost_1_61_0\boost\graph)的314行代码。

参考文档:

1. Building MariaDB on Windows

https://mariadb.com/kb/en/mariadb/Building_MariaDB_on_Windows/

2. 关于mysqld不是有效的win32程序

http://www.cnblogs.com/xiaobin-hlj80/p/5500152.html

3. 安装boost库(Windows)

http://www.cnblogs.com/xiaobin-hlj80/p/5503842.html

在windows编译MariaDB的更多相关文章

  1. OGRE 2.1 Windows 编译

    版权所有,转载请注明链接 OGRE 2.1 Windows 编译 环境: Windows 7 64Bit Visual Studio 2012 OGRE 2.1 CMake 2.8.12.1 OGRE ...

  2. Windows编译ejabberd

    Windows编译ejabberd(金庆的专栏)安装 erlang OTP. 添加路径到 PATH, 使 erl 可以运行.git clone ejabberd安装 rebar:git clone g ...

  3. 【转载】OGRE 2.1 Windows 编译

    OGRE 2.1 Windows 编译 环境: Windows 7 64Bit Visual Studio 2012 OGRE 2.1 CMake 2.8.12.1 OGRE: OGRE官方推出了最新 ...

  4. CEF3.2623使用记录:windows编译

    CEF3.2623使用记录:windows编译 1:cef3.2623下载地址 2623是cef3最后一个支持xp系统的版本,且可以支持html的audio标签,可以用作对html音频的处理下载地址为 ...

  5. Windows 编译安装 nginx 服务器 + rtmp 模块

    有关博客: <Windows 编译安装 nginx 服务器 + rtmp 模块>.<Ubuntu 编译安装 nginx>.<Arm-Linux 移植 Nginx> ...

  6. php beast windows编译教程

    git clone https://github.com/Microsoft/php-sdk-binary-tools.git c:\php-sdk cd c:\php-sdk git checkou ...

  7. Windows编译Nginx源码

    Windows下的Nginx战役,人不作就不会死!就像是拿着麦当劳的优惠券去买肯德基一样,别扭啊 Nginx是一款轻量级的Web 服务器.反向代理服务器.邮件服务器等等集一大串荣誉于一身的大牌人物!他 ...

  8. Windows编译安装OpenSSL

    windows下使用vs2008中的nmake编译安装openssl的脚本build.bat: echo off & color 0A :: 项目名称 set PROJECT=openssl ...

  9. 专题:Windows编译x264、SDL、faac、ffmpeg过程

    Windows上编译ffmpeg完整过程,包括编译x264.SDL.faac.在Windows上编译ffmpeg需要用MinGW+msys,本专题用于记录编译过程中遇到的各种问题及解决方法,转载请注明 ...

随机推荐

  1. 最新AFNetworking

    1.网络监测 /** * 网络检测 */ - (void)networkingMonitoring { //打开网络监测 [[AFNetworkReachabilityManager sharedMa ...

  2. c语言数据结构之 插入排序

    算法:从第二个元素开始,与前一个元素进行比较,如果小于前一个元素,两者交换位置,一直循环到不再小为止 编译器:VS2013 代码 #include "stdafx.h"#inclu ...

  3. c数据结构 顺序表和链表 相关操作

    编译器:vs2013 内容: #include "stdafx.h"#include<stdio.h>#include<malloc.h>#include& ...

  4. MySQL初探

    慕课网http://www.imooc.com/learn/122 课程学习笔记     修改MySQL提示符        shell>mysql --prompt 提示符        my ...

  5. C#的类及应用

    1.int i=x.Length;//Length(获取字符串的长度,返回一个int类型的值) 2.x=x.Trim();(去掉字符串前后的空格) trimStart();(去掉前面的空格) Trim ...

  6. codeforces Expecting Trouble

    link:http://codeforces.com/contest/345/problem/A 写完这道题目才发现这场比赛只能用Ada语言提交== 好吧,逗我玩呢 考的是数学期望公式,二项分布的期望 ...

  7. 使用TCP的HelloServer

    HelloServer是一个在1234端口监听的服务端程序,它接受客户送来的数据,并且把这些数据解释为响应的ASCII字符,再对客户做出类似“Hello,...!"这样的响应.以下是Hell ...

  8. esxi 升级

    开启ssh esxcli software vib install -d="/vmfs/volumes/53034105-a8b88330-c096-40f2e993407b/update- ...

  9. 用crontab跑定时任务[转]

    前一天学习了 at 命令是针对仅运行一次的任务,循环运行的例行性计划任务,linux系统则是由 cron (crond) 这个系统服务来控制的.Linux 系统上面原本就有非常多的计划性工作,因此这个 ...

  10. 更新日志(建议升级到2016.12.17) && 更新程序的方法

    更新程序的方法: 1,在控制面板里点击备份当前数据库文件到磁盘,把当天获取的信息从内存写到磁盘/存储卡.2,下载最新版的源码 wget -O "infopi.zip" " ...