《MySQL技术内幕》编写C程序示例代码勘误

     手动跑《MySQL技术内幕》(https://book.douban.com/subject/26436525/)自带的栗子时,第一个(P233页)就编译报错了。

root@ubuntu:~/mysqlc# make
gcc -c -I/usr/include/mysql connect1.c
gcc -o connect1 connect1.o -L/usr/lib/x86_64-linux-gnu -lmysqlclient -lpthread -lz -lm -lrt -ldl
connect1.o:在函数‘main’中:
connect1.c:(.text+0x19):对‘my_progname’未定义的引用
collect2: error: ld returned 1 exit status
makefile:11: recipe for target 'connect1' failed
make: *** [connect1] Error 1

     切到引用头文件的目录“ /usr/include/mysql ”,查看一下具体文件“ my_sys.h ”,找到对“ my_progname ”的定义,在原书示例脚步中也定义一下,“ const char *my_progname = argv[0]”,然后调用“ MY_INIT(my_progname) ”,重新编译执行OK(达到预设的报错目的)!

root@ubuntu:~/mysqlc# make
gcc -c -I/usr/include/mysql connect1.c
gcc -o connect1 connect1.o -L/usr/lib/x86_64-linux-gnu -lmysqlclient -lpthread -lz -lm -lrt -ldl
root@ubuntu:~/mysqlc# ./connect1 
mysql_real_connect() failed

     但是后面一些示例代码运行的时候遇到的错误越来越多。然后才发现我的MySQL版本是当下最新的5.7.18,而原书是基于MySQL5.5兼顾5.6早期版本写的,有点太老了。要顺利跑原书的栗子最好源码编译安装一个MySQL5.5版本。参考https://github.com/Bilery-Zoo/MySQL-Source-Code-Installation/blob/master/mysql5.5.56_ubuntu16.04_source_install_man.sh。安装好后需要将lib目录写入配置文件。视本地环境可能还需要安装一些依赖。

echo "/usr/local/mysql/lib" >> /etc/ld.so.conf
ldconfig
apt install zlib1g-dev

     最后是我本地编译用的makefile栗子。

CC = gcc
INCLUDES = -I/usr/local/mysql/include
LIBS = -L/usr/local/mysql/lib -lmysqlclient -lpthread -lz -lm -lrt -ldl

all: connect1

connect1.o: connect1.c
    $(CC) -c $(INCLUDES) connect1.c

connect1: connect1.o
    $(CC) -o connect1 connect1.o $(LIBS)

clean:
    rm -f connect1 connect1.o

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值