说明:本篇不是讨论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有助于处理大数据,是高性能和资源密集型环境的理想选择。其他尖端的存储引擎包括Aria和XtraDB,它们分别取代了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数据库的驱动。文章来源:https://www.toymoban.com/news/detail-458396.html
5、复制MySQL驱动到Qt的“sqldrivers”文件夹中选中上面生成的“qsqlmysql.dll”和“qsqlmysql.dll.debug”驱动文件并复制,然后将其粘贴到qt安装目录下的“sqldrivers”文件夹,这就成功地给qt环境添加了 MySQL驱动,后面编程中就可以使用这个驱动访问MySQL数据库了。文章来源地址https://www.toymoban.com/news/detail-458396.html
到了这里,关于Qt6之默认取消MySQL支持?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!