从MySQL切换PostgreSQL后,改动的地方,注意事项!!!

1、大写字段加上双引号,写了脚本可以参考:mysql转pg脚本

2、IFNULL转换为COALESCE。

3、LIMIT分页两个参数一个page,limit转换为如下写法:

xml 复制代码
  // 计算 offset,这里假设 page 从 1 开始
    int offset = (page - 1) * limit;
    sql:limit #{limit} OFFSET #{offset}

4、如果是利用mybatisplus的提供的构造器,大写字段的话要加上双引号。代码如下:

java 复制代码
QueryWrapper<RepBasicInfo> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("\"ACCOUNT_ITEM_ID\"", accountId)
.select("\"ID\"",  "COALESCE(\"REVIEW\", '') AS \"REVIEW\"");

5、如果你的数据库字段是数字类型,代码中是string类型,需要进行转换。代码如下:

xml 复制代码
<if test="payment != '' and payment != null">
    AND "PAYMENT" = CAST(#{payment} AS numeric)  <!-- 假设 PAYMENT 应该是 numeric 类型 -->
</if>

6、MySQL中的YEAR()和MONTH()函数替换为了PostgreSQL的EXTRACT(YEAR FROM CURRENT_DATE)和EXTRACT(MONTH FROM CURRENT_DATE)。

xml 复制代码
YEAR()  --》EXTRACT(YEAR FROM CURRENT_DATE)
MONTH()  --》EXTRACT(MONTH FROM CURRENT_DATE)

7、DATE_FORMAT的替换,代码如下:

xml 复制代码
DATE_FORMAT(fu."CREATE_DT",'%m') 
转换为
to_char(fu."CREATE_DT", 'MM')
%Y => YYYY
%m => MM
%d => DD
%H => HH24
%i => MI
%s => SS

8、查询结果原本是数字类型,但我想要字符串怎么办,代码如下:

xml 复制代码
COALESCE(al."LAST_END_DEBIT" - al."LAST_END_CREDIT", '0')
转换为
COALESCE(NULLIF(al."INITIAL DEBIT", 0)::text,'')

待补充...

相关推荐
马克学长6 小时前
SSM青岛恒星科技学院机房管理系统0k0u9(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·科技·ssm 框架·教育信息化·机房管理系统·青岛恒星科技学院
7***68437 小时前
Spring Boot 从 2.7.x 升级到 3.3注意事项
数据库·hive·spring boot
('-')7 小时前
《从根上理解MySQL是怎样运行的》第十章学习笔记
笔记·学习·mysql
L***d6707 小时前
Spring Boot 各种事务操作实战(自动回滚、手动回滚、部分回滚)
java·数据库·spring boot
java_logo7 小时前
MySQL Server Docker 容器化部署指南
linux·运维·数据库·docker·容器
likuolei7 小时前
XSL-FO 软件
java·开发语言·前端·数据库
p***95007 小时前
Springboot3 Mybatis-plus 3.5.9
数据库·oracle·mybatis
CS_浮鱼7 小时前
【MySQL】InnoDB存储引擎
数据库·mysql
合作小小程序员小小店7 小时前
桌面开发,在线%信息管理%系统,基于vs2022,c#,winform,sql server数据。
开发语言·数据库·sql·microsoft·c#