QT mysql 连接远端数据库无法打开

需求 Qt生成的 release,经过 windeployqt 之后,放到另外一台机器上,但是打不开网络上面的 mysql 服务器。 解决 检查 mysql 是否安装 其实很简单,因为新机器上面没有 mysql 相关的可执行文件,在机器上安装 mysql 的 client 端即可解决这个问题。 检查源码是否配置正确 另外 qt 源码当中也需要检查 连接 mysql 的配置有没有问题: // 创建一个数据库连接 QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL"); db.setHostName("your_mysql_server_ip"); // 替换为你的 MySQL 服务器 IP 地址 db.setDatabaseName("your_database_name"); db.setUserName("your_username"); db.setPassword("your_password"); 检查 mysql 服务端是否开启了网络帐号 mysql 只有创建了可以网络登陆的帐号,才可以通过网络连接过来。 参考 windows安装mysql client 命令行客户端

<span title='2024-02-20 19:04:00 +0800 CST'>2024-02-20</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;50 words&nbsp;·&nbsp;RamLife

QT 获取编译时间

需求 Qt 为了功能上的需要,需要获取软件编译的时间. 解决 qt 默认的编译时间,使用的是英文字符,类似 Feb 13 2024, 而且当日期小于 10 的时候,使用的还是单个字符,没有补 0. QString build_date = QString(__DATE__); // qDebug() << "build time: " << build_date; build_date.replace(" "," 0"); //注意" "是两个空格,用于日期为单数时需要转成“空格+0” QDate build = QDate::fromString(build_date, "MMM dd yyyy"); 参考 Qt 获取编译时间 Qt获取编译时间

<span title='2024-02-01 18:44:00 +0800 CST'>2024-02-01</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;41 words&nbsp;·&nbsp;RamLife

QT chart 更加清晰

需求 qt chart 在打印的时候,因为缩放的问题,导致图标不清晰,需要能够更加清晰一些。 解决 chart 其实主要就是几个部分: 曲线,坐标轴及文字,辅助线 曲线 主要就是加粗即可,使用 QPen, 修改 width 即可。 QPen pen; pen.setStyle(Qt::SolidLine); //Qt::SolidLine, Qt::DashLine, Qt::DotLine, Qt::DashDotLine pen.setWidth(2); pen.setColor(Qt::red); series0->setPen(pen); //序列series0的线条设置 坐标轴 为了方便修改也使用 QPen QPen axis_pen; axis_pen.setStyle(Qt::SolidLine); //Qt::SolidLine, Qt::DashLine, Qt::DotLine, Qt::DashDotLine axis_pen.setWidth(3); axis_pen.setColor(Qt::black); axisX->setLinePen(axis_pen); 辅助线 辅助线分为两种,一种是文字对应的辅助线,另外一种是文字之间的辅助线. QPen grid_pen; grid_pen.setStyle(Qt::DashLine); //Qt::SolidLine, Qt::DashLine, Qt::DotLine, Qt::DashDotLine grid_pen.setWidth(2); grid_pen.setColor(Qt::darkGray); QPen minor_grid_pen; minor_grid_pen.setStyle(Qt::DotLine); //Qt::SolidLine, Qt::DashLine, Qt::DotLine, Qt::DashDotLine minor_grid_pen.setWidth(1); minor_grid_pen.setColor(Qt::darkGray); axisX->setGridLinePen(grid_pen); axisX->setMinorGridLinePen(minor_grid_pen); 坐标轴文字 文字一般就是两种方法: 加粗和加大 QFont axis_font = axisX->labelsFont(); axis_font.setBold(true); int axis_font_point_size = axis_font....

<span title='2024-02-01 18:34:00 +0800 CST'>2024-02-01</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;80 words&nbsp;·&nbsp;RamLife

QT 构造函数中,检查配置文件,有问题就退出程序

需求 Qt 需要检查配置文件中的内容,如果有问题,就退出程序 解决 一般检查配置文件,是在构造函数环节,这个时候普通的退出是不行的。只能使用 QTimer 然后连接 qApp->quit() 来退出。 QSettings* configIni = new QSettings(file_path, QSettings::IniFormat, this); server_ip_ = configIni->value("ip", "192.168.1.100").toString(); server_port_ = configIni->value("port", "6666").toInt(); if (CheckServerIpAndPort(server_ip_, server_port_) == false) { QTimer *myTimer = new QTimer(); myTimer->start(10); connect(myTimer, &QTimer::timeout, this, [=](){this->close(); qApp->quit();}); } configIni->endGroup(); bool MainWindow::CheckServerIpAndPort(const QString &ip, uint16_t port) { QStringList list = ip.split('.'); if (list.size() != 4) { QMessageBox::critical(this, "IP格式错误", "请重新配置IP"); return false; } for (auto& s : list) { int address = s....

<span title='2024-01-14 18:44:00 +0800 CST'>2024-01-14</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;113 words&nbsp;·&nbsp;RamLife

c++ reserve, resize 区别

需求 cpp 里面的容器,reserve() 和 resize() 使用时有什么区别? 解决 reserve 只是增加了 capacity,没有增加 size; resize 增加了 capacity 和 size reserve 增加的容量里面没有相应的对象。resize 增加的是实实在在的对象,可以直接通过 at 来使用的。 参考 C++ vector中resize()和reserve()区别

<span title='2024-01-01 11:22:00 +0800 CST'>2024-01-01</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;24 words&nbsp;·&nbsp;RamLife

c/c++ string 的 length(), size(), strlen() 区别

需求 c/cpp 字符串长度,使用 length(), size(), strlen() 结果区别? 解决 strlen() 会查找 string 中的 ‘\0’,如果找到了,那么就是结束 length() 和 size() 其实一样,都是 string 实际的长度,不管其中是否有 ‘\0’ 参考 C++ string 成员函数 length() size() 和 C strlen() 的区别

<span title='2023-12-31 11:22:00 +0800 CST'>2023-12-31</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;30 words&nbsp;·&nbsp;RamLife

c/c++ 实现 _gettimeofday

需求 c/cpp 在一些嵌入式应用中,使用 time() 时,编译会报警告 warning: _gettimeofday is not implemented and will always fail 解决 这个警告的原因其实是因为,嵌入式环境中,有些是没有实现 _gettimeofday(), 所以就需要自己来实现这个函数,实现从 rtc 时间到秒之间的转换。 int _gettimeofday(struct timeval *tv, struct timezone *tz) { Rtc::Date date; Rtc::Time time; Rtc::GetRtcValue(date, time); tm time_tm {time.second, time.minute, time.hour, date.day, date.month - 1, date.year - 1900}; time_t time_second = mktime(&time_tm); tv->tv_sec = time_second; tv->tv_usec = 0; // tz->tz_minuteswest = 480; // tz->tz_dsttime = DST_NONE; return 0; } 参考 _gettimeofday_r error come while i am building with latest stm cube ide STM32 之 时间戳的解析与生成 STM32CubeMX使用(六)之RTC及制作时间戳 mktime很慢就自己去实现一个吧 linux几种时间函数总结 时间获取相关函数mktime()、gmtime() 【c/c++】linux时间获取与时间转换函数总结 杂谈:Linux时间管理之gettimeofday实现 gettimeofday()函数的使用方法 linux中time, ctime, gmtime, localtime, gettimeofday和strftime C语言的时间函数(1)gettimeofday,timeval,timezone linux系统中struct timeval结构体、struct timezone结构体以及gettimeofday函数 C 标准库 - <time....

<span title='2023-12-30 11:22:00 +0800 CST'>2023-12-30</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;139 words&nbsp;·&nbsp;RamLife

c/c++ 实现 calendar

需求 c/cpp 在一些嵌入式应用中,需要自己来实现对输入日期的校验和星期几的计算。 解决 日期校验还好说,主要是闰年的判断。 星期几的计算就比较麻烦了,一般是使用蔡勒公式。 蔡勒公式 1582年10月4日之后 w = (d + 1 + 2 * m + 3 * (m + 1) / 5 + y + y / 4 - y / 100 + y / 400) % 7 1582年10月4日或之前 w = (d + 1 + 2 * m + 3 * (m + 1) / 5 + y + y / 4 + 5) % 7 解释: w:星期; w对7取模得:0-星期日,1-星期一,2-星期二,3-星期三,4-星期四,5-星期五,6-星期六 c:世纪(注:一般情况下,在公式中取值为已经过的世纪数,也就是年份除以一百的结果,而非正在进行的世纪,也就是现在常用的年份除以一百加一;不过如果年份是公元前的年份且非整百数的话,c应该等于所在世纪的编号,如公元前253年,是公元前3世纪,c就等于-3) y:年(一般情况下是后两位数,如果是公元前的年份且非整百数,y应该等于 cMOD100+100) m:月(m大于等于3,小于等于14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月来计算,比如2003年1月1日要看作2002年的13月1日来计算) d:日 示例 [ ]代表取整,即只要整数部分。...

<span title='2023-12-15 11:22:00 +0800 CST'>2023-12-15</span>&nbsp;·&nbsp;3 min&nbsp;·&nbsp;575 words&nbsp;·&nbsp;RamLife

QT QJson 使用

需求 Qt 如何使用 QJson 解析 json 解决 int NetworkDataParse::Parse(const QByteArray& data, QJsonObject& obj) { QJsonParseError error; QJsonDocument doc = QJsonDocument::fromJson(data, &error); if (doc.isNull()) { return -1; } obj = doc.object(); int type = obj.value("type").toString().toInt(); // QJsonValue type_value = obj.value("type"); // QString type_string = type_value.toString(); // qDebug() << "Parse: " << type_string << ", " << type; // switch (type) { // case kTypeAlive: // return ParseAlive(obj); // break; // default: // break; // } // return 0; return type; } 参考 Qt平台下使用QJson解析和构建JSON字符串 Qt 学习之路 :使用 QJson 处理 JSON JSON Support in Qt QJson的生成和解析 QJson读取及写入 使用fastjson解析JSON数据 QJsonArray....

<span title='2023-12-11 21:41:00 +0800 CST'>2023-12-11</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;100 words&nbsp;·&nbsp;RamLife

QT5 升级到 Qt6, QRegExp 不能用

需求 Qt5 的工程升级到 Qt6 之后,找不到 QRegExp 等一系列类。 解决 QRegExp -> QRegularExpression QRegExpValidator -> QRegularExpressionValidator // Qt5 QRegExp version(QLatin1String("(.+)_v(\\d+)")); if (version.exactMatch(completeBaseName/*QString*/)) { // some code } // Qt6 QRegularExpression version(QLatin1String("(.+)_v(\\d+)")); QRegularExpressionMatch match = version.match(completeBaseName); if (match.hasMatch()) { // Find exact match or not } 参考 QT6找不到QRegExpValidator类问题解决办法 关于QRegExpValidator头文件不存在的问题 Qt6中的端口QRegExp::exactMatch()

<span title='2023-12-02 21:41:00 +0800 CST'>2023-12-02</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;47 words&nbsp;·&nbsp;RamLife