Qt6之默认取消MySQL支持?

说明:本篇不是讨论qt怎么使用MySQL,这类的文章一搜一大堆。

一、结论

Qt6开始确实默认取消了对MySQL的支持,用户需自行编译生成MySQL的驱动DLL库。

首先不是qt增加使用门槛是风向变了,而是自从Oracle 收购MySQL后对其进行了商业化,如今的MySQL已经不能算是一个完全开源的数据库了,而Qt官方则一直严格秉持着开源理念,故 Qt6 取消了对 MSOL 数据库的默认支持 。

MySQL怎么了?

MySQL 仍然是最流行的开源数据库,但多年来它一直在失去粉丝,包括很多大公司。

MySQL有一个良好的开端,但麻烦始于2008年被Sun Microsystem收购。顶级开发人员表达了他们对Sun Microsystem整个收购和意图的疑虑。后来,甲骨文公司收购Sun Microsystem引起了开源社区的大量批评,成为压垮骆驼的最后一根稻草。

早在 2008 年,当Sun Microsystems以大约 10 亿美元的价格收购 MySQL AB时,MySQL 迅速流行起来。次年,甲骨文收购了 Sun,而MySQL 是交易的一部分。MySQL 用户和开发人员开始质疑开源数据库的命运,其中许多人开始寻找替代方案。

收购后,MySQL的顶级开发人员创建了MySQL的分支。这个分支后来被称为MariaDB,并于2009年在GNU许可证下正式提供给开源社区。从那时起,MariaDB彻底改变了开源数据库领域,并继续突飞猛进地发展。由于MySQL的许可,更多的公司继续迁移到MariaDB,因为它与MySQL一样具有大量新功能和改进。

尽管如此,MySQL 的受欢迎程度仍在下降。原因如下:

1、MySQL 是开源的……但只是有点开源,不是纯开源了

从技术上讲,MySQL 是一个开源数据库,但实际上,它不再像它了。在 Oracle 的保护下,MySQL 现在拥有专有的闭源模块。“MySQL 在纸面上仍然存在,但甲骨文拖延开发并拒绝发布 MySQL 的错误和安全补丁的测试用例加强了对代码的控制,并将成群的开源开发人员送往更绿色的牧场,”Paula Rooney 在她的 ZDNet 中如此评价。

并不是说没有其他开源替代品。MariaDB 是 MySQL 的一个分支,仍然是“真正的开源”。MariaDB 开发商 SkySQL解释说,“MariaDB 中的所有代码都是在 GPL、LPGL 或 BSD 下发布的。MariaDB 没有像MySQL Enterprise Edition中那样的闭源模块。事实上,MySQL 5.5 企业版中所有的闭源特性都在 MariaDB 开源版本中找到了。”

结论就是:纯开源的MySQL本质上现在已经是MariaDB。

2、 MySQL 的性能不如它的竞争对手MariaDB

MariaDB 博客提供了最新 MySQL 与 MariaDB 版本的详细基准测试结果,尽管结果接近,但MariaDB 领先

3、 MySQL 现在是 Oracle 拥有的,而不是社区驱动的

MySQL 自从被 Oracle 收购后并没有显着改变方向,但 Oracle 仍然拥有它,这让一些开发人员感到紧张。“而且,可能最糟糕的是,社区不可能与 Oracle 的 MySQL 开发人员合作,”MySQL 和 MariaDB 的创始人 Michael “Monty” Widenius 说。

Widenius 指出,Oracle 不接受补丁或提供公共路线图。“无法与 MySQL 开发人员讨论如何实现事物或当前代码如何工作,”他说。如果一个开源的、社区开发的数据库对你很重要,Widenius 推荐 MariaDB(duh!),因为它建立在 MySQL 之上,提供更多的特性、速度和稳定性,安全问题更少。

4、大公司开始跳票

在 2013 年 6 月于波士顿举行的峰会上,Red Hat 宣布与 MySQL 分手。相反,Red Hat Enterprise Linux (RHEL) 将随 MariaDB 一起发布。Fedora 已经宣布将在 Fedora 19 中从 MySQL 迁移到 MariaDB 分支。Slackware Linux 于 2013 年 3 月宣布从 MySQL 迁移到 MariaDB,openSUSE 在 2013 年 1 月也发布了类似的公告

Qt官方一直秉承开源社区的理念,这与MySQL现在实质已经背道而驰了,所以qt6开始默认取消对MySQL支持。

5、为什么MySQL被越来越抛弃而MariaDB却持续增长

随着MySQL数据库的普及率下降和向MariaDB的大规模转变,您可能想知道是什么让MariaDB自成立以来取得了如此巨大的成功。在本节中,我们将重点介绍推动MariaDB增长和随之而来的流行度的一些关键改进和功能。

首先,MariaDB 不需要许可证,尤其是在生产/商业环境中。自从被Oracle收购以来,MySQL现在需要用于商业目的的许可证。此举迫使成千上万的开发人员选择MariaDB。XAMPP,一个流行的Web服务器堆栈,甚至在其LAMP堆栈中放弃了MariaDB的MySQL。由于部署不需要许可证,MariaDB因此被认为是真正的开源RDBMS - 关系数据库管理系统。

MariaDB 具有内置且强大的集群功能,称为 Galera 集群,能够提供主到主和主从复制。它提供自动节点加入、行级并行复制以及同步复制,并具有对群集中任何节点的读写功能。此外,您可以承受丢失集群中的节点,而不必担心集群操作中断,也无需部署复杂的故障转移计划。

MariaDB 还带有内置的强大存储引擎有用的插件Cassandra存储引擎支持NoSQL,可以同时容纳SQL和NoSQL系统。TokuDB有助于处理大数据,是高性能和资源密集型环境的理想选择。其他尖端的存储引擎包括AriaXtraDB,它们分别取代了MySQL中旧的MyISAM和InnoDB。

MariaDB中内置的其他新功能和超酷功能包括专门为数据仓库量身定制的ColumnStore引擎,为方便MariaDB访问本地和远程数据而构建的CONNECT存储引擎,MyRocks,这是一个LSM数据库,提供出色的压缩比,用于创建序列的SEQUENCE引擎(无论是从给定的参考点或起始值升序还是降序)和Spider引擎。 少。

MariaDB 不仅在查询优化方面拥有更好的性能,而且在其他功能方面也拥有更好的性能当客户端连接到MariaDB时,速度很快,MariaDB 10.1和10.2都添加了更多改进。这使得MariaDB成为MySQL更受欢迎的选择。

随着网络威胁和漏洞的不断增加,MariaDB 开发人员会定期发布安全公告并利用补丁和升级。此外,他们的发行说明包含所有最新的 CVE 标识符。这与MySQL相去甚远,MySQL的安全公告频率较低,并且被称为模糊,这使得补丁管理难以实施。此外,发行说明中列出的 CVE 标识符与当前存在的标识符之间存在巨大差异。
值得一提的是,MariaDB 有更好的测试,这有助于减少编译警告和错误中的错误。这主要是由于庞大的贡献者社区,以及以改进数据库系统为唯一目标的开发人员。所有源代码都在通用公共许可证(GPL)下发布,MySQL中的所有闭源模块都存在于开源MariaDB中。这使得MariaDB成为一个真正的开源数据库系统。

最后,MariaDB是MySQL的直接替代品,从MySQL迁移到MariaDB只需执行一些命令即可。如果您正在运行一些MySQL数据库实例,则只需删除/清除MySQL软件包并安装MariaDB,设置将自动迁移。

MariaDB的增长将保持不受阻碍,这主要是由于其充满活力和开源的社区促进了更好,更干净的代码的维护,而这恰恰是Oracle MySQL被批评的主要原因,缺少社区渠道,不接受补丁及公共路线,重点在商业版本。数据库系统还充满了大量有用的功能,有望获得身临其境的体验。在接下来的几年中,我们可能会看到更多的公司转向MariaDB,因为应用程序变得越来越复杂,需要更强大,稳定和安全的数据库系统。


Qt环境中不再内置MySQL的驱动(QMYSQL),用户若是还想使用0t连接操MVSQL只能用Qt的源码工程自行编译生成MySQL 的驱动DLL库,然后引入开发环境使用,过程比较麻烦,下面介绍具体操作步骤。

1、首先打开MySQL 安装目录下的“lib”文件夹,看到里面有两个文件“libmysqldll”和“libmysqllib”,将它们复制到Qt的MinGw编译器的“bin”目录;

2、找到 Qt 安装目录下源代码目录中的“mysql”文件夹(“C:Qt\6.5\Src\qtbase\src\plugins\sqldrivers\mysql”,请根据自己安装的实际路径寻找)进入此文件夹,可见其中有一个名为“mysql.pro”的Qt项目工程配置文件;

3、启动QtCreator,定位到“mysql”文件夹下,打开“mysql.pro”对应的Qt项目,运行此项目;

4、打开“mysql”文件夹,可看到其中多了个“lib”子文件夹,进入可看到编译生成的3个文件;

其中,qsqlmysql.dll”和“qsqlmysql.dll.debug即是我们需要的Qt环境MySQL数据库的驱动。

5、复制MySQL驱动到Qt的“sqldrivers”文件夹中选中上面生成的“qsqlmysql.dll”和“qsqlmysql.dll.debug”驱动文件并复制,然后将其粘贴到qt安装目录下的“sqldrivers”文件夹,这就成功地给qt环境添加了 MySQL驱动,后面编程中就可以使用这个驱动访问MySQL数据库了。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

闫有尽意无琼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值