mysql 常用计算和字符处理

需求 mysql 中常用的字符串处理和数值计算? 解决 字符串 Concat: 拼接 Upper,Lower: 大写,小写 Left, Rigth: 返回左边,右边的字符 Length: 长度 Locate: 找出字串 LTrim, RTrim: 去掉左边,右边的空格 SubString: 字串字符 数值计算 加减乘除,都是直接用数学符号就可以了。 Abs: 绝对值 Sin, Cos, Tan: 正弦,余弦,正切 Exp, Sqrt: 指数,平方根 Mod: 余数 Pi: 圆周率 Rand: 随机数 SIGN: 获取正负号, 正1,负-1,零0 日期时间 AddDate, AddTime: 增加日期,时间 CurDate, CurTime, Now: 返回当前日期,时间, 日期和时间 Date, Time, Day, DayOfWeek, Hour, Minute, Month, Second, Year: 日期,时间,天数,星期几,小时,分钟,月,秒,年 DateDiff: 日期差 Date_Add: 灵活的日期运算 Date_Formate: 格式化的日期和时间 比较 = : 判断是否相等,相等1,不相等0 <, >, <=, >= : 正常的大于和小于 <>, !...

2024-01-04 · 1 min · 94 words · RamLife

c++ reserve, resize 区别

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

2024-01-01 · 1 min · 24 words · 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() 的区别

2023-12-31 · 1 min · 30 words · 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....

2023-12-30 · 1 min · 139 words · RamLife

mysql error: Cannot delete or update a parent row: a foreign key constraint fails

需求 使用 mysql 在删除数据表时,报错: =“Cannot delete or update a parent row: a foreign key constraint fails” = 解决 这个问题其实很简单,就是需要删除的表关联到了其他副表,想要删除无非就几种方法: 先把其他相关联的副表中的内容给删除掉,再回头删除主表中的内容 先禁用外键约束,等删除好了,再启用外键约束 SET FOREIGN_KEY_CHECKS=0; -- 禁用外键约束 SET FOREIGN_KEY_CHECKS=1; -- 启用外键约束 外键约束中,删除也选择 CASCADE 级联约束。 参考 mysql 删除数据表报错 表删除时 Cannot delete or update a parent row: a foreign key constraint fails 异常处理 删除数据提示1451:cannot delete or update a parent row:a foreign key constraint fails 删除带外键的表【foreign key constraint fails】报错 Mysql - 删除表时出现: Cannot delete or update a parent row: a foreign key constraint fails

2023-12-24 · 1 min · 79 words · RamLife

mysql 多表外键联查视图

需求 使用 mysql,建立了多张表,表之间使用外键进行关联,现在需要通过视图进行多表联查。 多表内容 reagent key_id project type 1 coag gbact itemrange key_id fk_reagent item 1 1 act 2 1 cr 3 1 pf filereportdata key_id fk_item value strip 1 2 1.1 sid01 2 1 2.2 sid02 3 3 3.3 sid03 多表关系 filereportdata.fk_item = itemrange.key_id itemrange.fk_reagent = reagent.key_id 期望结果 strip project type item value sid01 coag gbact cr 1.1 sid02 coag gbact act 2.2 sid03 coag gbact pf 3.3 解决 多表查询 SELECT f....

2023-12-18 · 1 min · 156 words · 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:日 示例 [ ]代表取整,即只要整数部分。...

2023-12-15 · 3 min · 575 words · 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....

2023-12-11 · 1 min · 100 words · 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()

2023-12-02 · 1 min · 47 words · RamLife

printf 格式化输出

需求 printf 格式话输出具体有哪些? 解决 控制符 控制符 说明 %d 十进制整形输出 %ld 长整形 %md 指定宽度至少 m 输出,宽度不够就空格补,宽度超过就按照实际输出 %u 无符号整形 %c 单个字符 %f 浮点数,小数为6位,超过6位四舍五入 %s 字符串 格式 具体格式: %[flags][width][.precision][length]specifier 整形 %d, 整形 %4d, 大于等于4位宽度,补空格 %04d, 大于等于4位宽度,补0 浮点数 %f, 浮点数,小数6位 %.4f, 小数4位 %6.2f, 大于等于6位,小数2位,不足补空格 %06.2f, 大于等于6位,小数2位,不足补0 字符串 %s, 字符串 %6s, 大于等于6位,不足补空格 参考 C语言printf指定宽度的格式化输出

2023-11-30 · 1 min · 49 words · RamLife