Qt6之默认取消MySQL支持?

这篇具有很好参考价值的文章主要介绍了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项目工程配置文件;

Qt6之默认取消MySQL支持?

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数据库了。文章来源地址https://www.toymoban.com/news/detail-458396.html

到了这里,关于Qt6之默认取消MySQL支持?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • error C4430 缺少类型说明符 - 假定为 int。注意 C++ 不支持默认 int

    出现原因:两个类头文件相互包含 使用声明类代替头文件包含

    2024年02月14日
    浏览(31)
  • linux:需要注意docker和aws的rds的mysql默认是UTC而不是中国时区

    问题:         如题 解决办法:         docker参考:                 mysql时间不对,修改时区_set global time_zone 无效_《小书生》的博客-CSDN博客         aws参考:                 https://www.youtube.com/watch?v=B-NaqV-A1BY                 mysql - AWS修改RDS时区

    2024年02月10日
    浏览(41)
  • 不讨论颜色的前提下,如何证明自己不是色盲?神奇的零知识证明

    《阿里巴巴与四十大盗》中有这样一段小故事: 阿里巴巴会芝麻开门的咒语,强盗向他拷问打开山洞石门的咒语,他不想让人听到咒语,又要向强盗证明他知道这个咒语。 那应该怎么办呢? 便对强盗说:「你们离我一箭之地,用弓箭指着我,你们举起右手,我念咒语打开石

    2024年02月02日
    浏览(34)
  • 如何取消文件的默认打开方式:

    具体步骤如下: 1. 首先 WIN + R 调出运行窗口,输入regedit ,回车调出注册表窗口; 2. 左边找到 HKEY_CLASSES_ROOT  并展开它; 3. 在展开的列表中找到你要取消的文件后缀,右击选择删除; 4. 然后退回到最初的列表,展开如图 HKEY_CURRENT_USER 再展开SOFTWARE; 5. 继续展开 Microsoft ; 6

    2024年02月03日
    浏览(59)
  • QT6 for android 安装教程记录(版本Qt6.5.2)

    本文记录首次安装QT for andriod的详细记录。 网上的信息和资料非常多,收集和整理以及遇到的问题也各异,对新手首次接触相关开发和部署环境并不是清晰,因此,特将相关详细配置记录。 首先,开发QT for andriod 不建议使用QT5.15的版本,因为该版本不能区分相关的CPU架构,而

    2024年02月03日
    浏览(49)
  • 取消默认进入conda的base环境

    即可

    2024年01月25日
    浏览(42)
  • Windows系统替换、取消按文件类型指定默认应用

    在操作windows系统的时候,经常会出现打开某一个类文件后,系统会提示选取默认打开应用,有时候会不小心选择了错的应用,一般解决的办法为: 1. 右键文件,选择打开方式,替换默认应用; 2. 设置→应用→默认应用→按文件类型指定默认应用: 在我们不希望使用默认应用

    2024年01月18日
    浏览(43)
  • 【QT教程】QT6物联网应用

    QT6物联网应用 使用AI技术辅助生成 QT界面美化视频课程 QT性能优化视频课程 QT原理与源码分析视频课程 QT QML C++扩展开发视频课程 免费QT视频课程 您可以看免费1000+个QT技术视频 免费QT视频课程 QT统计图和QT数据可视化视频免费看 免费QT视频课程 QT性能优化视频免费看 免费QT视

    2024年04月25日
    浏览(34)
  • Qt6中使用Qt Charts

     官方文档:Qt Charts 6.5.2           如果你是使用  CMake 构建的,则应在  CMakeLists.txt  中添加如下两行代码:         其中  mytarget 为你的项目名称。一共2处改动,如下截图:         改完之后,你在 .cpp 文件导入库名,就可以开始画图了。         关于怎么画出一个可

    2024年02月09日
    浏览(38)
  • 【Qt6】QStringList

    2023年10月31日,周二上午 QStringList 是 Qt 中的一个类,用于存储一组字符串。它提供了一些方便的方法来操作和管理字符串列表。 QStringList 可以用于存储任意数量的字符串,并提供了一些常用的操作,例如添加、删除、查找、排序等。它是基于 QStringList 类的 QVectorQString 的封装

    2024年02月06日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包