mysql 转pg 两者不同的地方

news2024/11/23 23:41:21

        因项目数据库(原来是MySQL)要改成PostgreSQL。 项目里面的sql要做一些调整。

1,写法上的区别:

1,数据准备:

新建表格:

CREATE TABLE property_config ( 
   CODE       VARCHAR(50)         NULL,
   VALUE      VARCHAR(1000)         NULL,
   remark     VARCHAR(250)         NULL 
);

插入数据:

INSERT INTO property_config 
VALUES (1, 'test', 'test'),(2, 'test2', 'test2');

2,select 写法

1,查询条件

1,类型

pg的会更严格,字符串的,要加引号

msyql:

SELECT CODE, VALUE, remark
FROM property_config WHERE CODE = 1;

        这样写,虽然mysql支持,但是要进行类型转换。

pg:

改为:

SELECT CODE, VALUE, remark
FROM property_config WHERE CODE = '1';

这样就正常。

2,别名 as

1,特殊处理:

别名中带 type的需要带as

mysql:

select code, value, remark,  'property' type  from property_config;
select code, value, remark,  'property' types  from property_config;
select code, value, remark,  'property' typess  from property_config;

这个执行正常。

pg:执行会报错

修改为

select code, value, remark,  'property' as type  from property_config;
select code, value, remark,  'property' as types  from property_config;
select code, value, remark,  'property' typess  from property_config;

2,as 不能加 ''

mysql:

SELECT CODE, VALUE, remark,  'property' AS 'key_1'  
FROM property_config;

这个执行正常。

pg:

执行报错:

修改为:

SELECT CODE, VALUE, remark,  'property' AS key_1  
FROM property_config;

3,返回值大小写

        mysql: 区分大小写,根据写的字段大小写返回

        pg: 返回小写

        因此,写sql的时候,mysql的平时都用小写。如果写java代码,使用对象。

2,数据类型的区别:

mysql数据类型

pg数据类型

datetime

timestamp

bigint

int8

        mysql也有timestamp,但是跟datetime的精度不同。

日期格式化的区别:

数据类型

mysql格式

pg格式

日期时间

%Y-%m-%d %H:%i:%s

YYYY-MM-DD HH24:MI:SS

日期

%Y-%m-%d

YYYY-MM-DD

时间

%H:%i:%s

HH24:MI:SS

3,函数上的区别:

1,判断函数:

mysql函数

pg函数

ifnull()

COALESCE()

COALESCE() 是两边都可以用

2,日期函数:

mysql函数

pg函数

作用

date_format()

to_char()

把日期转为日期字符串

STR_TO_DATE()

to_date()

把日期字符串转为日期

STR_TO_DATE()

to_timestamp()

把日期时间字符串转为日期时间

CURRENT_TIMESTAMP()、LOCALTIME()、

NOW()、

SYSDATE()

NOW()

获取当前日期时间

1,把日期转为日期字符串

mysql:

SELECT DATE_FORMAT(NOW(),'%Y-%m-%d %H:%i:%s') AS format_datetime;
SELECT DATE_FORMAT(NOW(),'%Y-%m-%d') AS format_date;
SELECT DATE_FORMAT(NOW(),'%H:%i:%s') AS format_time;

pg:

SELECT to_char(NOW(), 'YYYY-MM-DD HH24:MI:SS') AS format_datetime;
SELECT to_char(NOW(), 'YYYY-MM-DD') AS format_date;
SELECT to_char(NOW(), 'HH24:MI:SS') AS format_time; 

2,把日期字符串转为日期

mysql:

SELECT STR_TO_DATE('2024-02-28', '%Y-%m-%d') AS format_date;

pg:

SELECT TO_DATE('2024-02-28', 'YYYY-MM-DD') AS format_date;

3,把日期时间字符串转为日期时间

mysql:

SELECT STR_TO_DATE('2024-02-28 12:15:16', '%Y-%m-%d %H:%i:%s');

pg:

select to_timestamp('2024-02-28 12:15:16','yyyy-MM-dd hh24:mi:ss');

3,字符串函数:

mysql函数

pg函数

作用

find_in_set()

ANY(string_to_array('', ','))

查找字符串

GROUP_CONCAT()

array_to_string(array_agg(cname), ',') 、 string_agg(cname, ',')

字符串聚合

INSTR()

strpos()

查找字符串位置

1,查找字符串

mysql:

SELECT * FROM property_config  WHERE FIND_IN_SET('test', VALUE);

ps:

SELECT * FROM property_config t WHERE 'test' = ANY(string_to_array(value, ','));

2,字符串聚合

mysql:

SELECT GROUP_CONCAT(CODE) AS codes FROM property_config;

pg:

SELECT array_to_string(array_agg(code),',') as codes 
from property_config;
SELECT string_agg(code, ',') as codes from property_config;

3,查找字符串位置

mysql:

SELECT LOCATE('ba1l', 'footba1l');
SELECT POSITION('ba1l' IN 'footba1l');
SELECT INSTR('footba1l', 'ba1l');

pg:

 SELECT strpos('football', 'ball');  
 SELECT POSITION('ball' in 'football');

这边查找位置的POSITION()函数是一样的。

4,分页写法

mysql:

        分页limit x,y,x代表跳过的条数,y代表查询的数量,

pg:

        采用 limit y offset x,写法等价于mysql的limit x,y

mysql 也支持 offset 后续用,都用offset

通用写法:  LIMIT size offset size * page

java代码的话,用分页插件

5,id插入

pg没有对应于值就不能写

mysql:

insert into form_cfg(id, form_id, attr_name, attr_value, attr_type)
values(#{id}, #{formId}, #{attrName}, #{attrValue}, #{attrType})

pg:

insert into form_cfg(form_id, attr_name, attr_value, attr_type)
values(#{formId}, #{attrName}, #{attrValue}, #{attrType})

2,总结:

        在平时写代码的时候,如果有不同数据库的,要考虑通用性。像判断是否为空这种,由代码去判断,没办法兼容的,再考虑用不同的方法实现。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1600959.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PHP一句话木马

一句话木马 PHP 的一句话木马是一种用于 Web 应用程序漏洞利用的代码片段。它通常是一小段 PHP 代码,能够在目标服务器上执行任意命令。一句话木马的工作原理是利用 Web 应用程序中的安全漏洞,将恶意代码注入到服务器端的 PHP 脚本中。一旦执行&#xf…

免费ssl通配符证书申请教程

在互联网安全日益受到重视的今天,启用HTTPS已经成为网站运营的基本要求。它不仅保障用户数据传输的安全,提升搜索引擎排名,还能增强用户对网站的信任。通配符证书是一种SSL/TLS证书,用于同时保护一个域名及其所有下一级子域名的安…

【Qt】:界面优化(一:基本语法)

界面优化 一.基本语法1.设置指定控件样式2.设置全局控件样式3.从文件加载样式表4.使⽤Qt Designer编辑样式(最常用) 二.选择器1.概述2.子控件选择器3.伪类型选择器 三.盒模型 在网页前端开发领域中,CSS是一个至关重要的部分.描述了一个网页的"样式&…

基于JavaWeb开发的springboot网约车智能接单规划小程序[附源码]

基于JavaWeb开发的springboot网约车智能接单规划小程序[附源码] 🍅 作者主页 央顺技术团队 🍅 欢迎点赞 👍 收藏 ⭐留言 📝 🍅 文末获取源码联系方式 📝 🍅 查看下方微信号获取联系方式 承接各种…

Weakly Supervised Audio-Visual Violence Detection 论文阅读

Weakly Supervised Audio-Visual Violence Detection 论文阅读 摘要III. METHODOLOGYA. Multimodal FusionB. Relation Modeling ModuleC. Training and Inference IV. EXPERIMENTSV. CONCLUSION阅读总结 文章信息: 发表于:IEEE TRANSACTIONS ON MULTIME…

上海亚商投顾:沪指低开低走跌 两市逾千股跌超10%

上海亚商投顾前言:无惧大盘涨跌,解密龙虎榜资金,跟踪一线游资和机构资金动向,识别短期热点和强势个股。 一.市场情绪 三大指数昨日低开低走,沪指跌超1.6%,深成指、创业板指尾盘跌逾2%,微盘股指…

【c 语言】结构体指针

🎈个人主页:豌豆射手^ 🎉欢迎 👍点赞✍评论⭐收藏 🤗收录专栏:C语言 🤝希望本文对您有所裨益,如有不足之处,欢迎在评论区提出指正,让我们共同学习、交流进步&…

2024年4月最新版GPT

2024年4月最新版ChatGPT/GPT4, 附上最新的使用教程。 随着人工智能技术的不断发展,ChatGPT和GPT4已经成为了人们日常生活中不可或缺的助手。2024年4月,OpenAI公司推出了最新版本的GPT4,带来了更加强大的功能和更加友好的用户体验。本文将为大家带来最新版GPT4的实用…

外网如何访问内网数据库?

企业和个人常常需要在外部网络环境中访问内部的数据库资源。这也是为了实现更大范围的资源共享和便捷的工作模式。由于网络安全和防火墙的限制,外网访问内网数据库并不是一件容易的事情。 在解决这个问题的过程中,天联组网应运而生。天联组网是一款异地组…

AIGC实战——VQ-GAN(Vector Quantized Generative Adversarial Network)

AIGC实战——VQ-GAN 0. 前言1. VQ-GAN2. ViT VQ-GAN小结系列链接 0. 前言 本节中,我们将介绍 VQ-GAN (Vector Quantized Generative Adversarial Network) 和 ViT VQ-GAN,它们融合了变分自编码器 (Variational Autoencoder, VAE)、Transformer 和生成对…

科技驱动未来,提升AI算力,GPU扩展正当时

要说这两年最火的科技是什么?我想“AI人工智能”肯定是最有资格上榜的,尤其ChatGPT推出后迅速在社交媒体上走红,短短5天,注册用户数就超过100万,2023年一月末,ChatGPT的月活用户更是突破1亿,成为…

内网kift私有网盘如何实现在外网公网访问?快解析映射方案

KIFT是一款面向个人、团队、小型组织的网盘服务器系统,安装运行比较简单,开箱即用,下载解压,双击jar文件即可启动。因为是开源的,不少人选择使用KIFT做开源私有网盘,有能力的大佬还可以对它进行定制开发。 …

python 列表对象函数

对象函数必须通过一个对象调用。 列表名.函数名() append() 将某一个元素对象添加在列表的表尾 如果添加的是其他的序列,该序列也会被看成是一个数据对象 count() 统计列表当中 某一个元素出现的次数 extend() 在当前列表中 将传入的其他序列的元素添加在表尾…

养猫必看!毛发护理秘籍,猫粮选择大揭秘!

亲爱的猫友们,我们都知道,猫咪的毛发是它们健康与美丽的象征。选择一款合适的猫粮,对于猫咪的毛发健康至关重要。那么,如何根据猫咪的毛发情况来选择合适的猫粮呢?接下来,就让我来为你详细解答吧&#xff0…

5.前后端分离

目录 一、前后端分离上传文件 1.在yml中设置port和localhost 2.如何使用postman测试上传文件的接口 二、如何导出excel文件 ​编辑1.在pom.xml中导包 2.在实体类中给每个字段添加注解,导出表格时,列名将会改为对应的中文 3.controller中方法的具体…

Swoole 实践篇之结合 WebRTC 实现音视频实时通信方案

原文首发链接:Swoole 实践篇之结合 WebRTC 实现音视频实时通信方案 大家好,我是码农先森。 引言 这次实现音视频实时通信的方案是基于 WebRTC 技术的,它是一种点对点的通信技术,通过浏览器之间建立对等连接,实现音频…

4.Labview簇、变体与类(上)

在Labview中,何为簇与变体,何为类?应该如何理解?具体有什么应用场景? 本文基于Labview软件,独到的讲解了簇与变体与类函数的使用方法和场景,从理论上讲解其数据流的底层概念,从实践上…

CSS基础之伪元素选择器(如果想知道CSS的伪元素选择器知识点,那么只看这一篇就足够了!)

前言:我们已经知道了在CSS中,选择器有基本选择器、复合选择器、伪类选择器、那么选择器学习完了吗?显然是没有的,这篇文章讲解最后一种选择器——伪元素选择器。 ✨✨✨这里是秋刀鱼不做梦的BLOG ✨✨✨想要了解更多内容可以访问我…

如何把npm切换成yarn管理项目

1.删掉项目中package-lock.json和依赖包 这一步手动删掉就好 2.全局安装yarn npm install -g yarn 3.可以开始执行yarn install安装依赖 1)执行yarn init 这一步是修改npm生成的package.json文件,可能会遇到这个问题: 这个查了一下是有…

cesium primitive 移动 缩放 旋转 矩阵

旋转参考:cesium 指定点旋转rectangle Primitive方式 矩阵篇-CSDN博客 平移参考:cesium 调整3dtiles的位置 世界坐标下 相对坐标下 平移矩阵-CSDN博客 一、primitive方式添加polygon let polygonInstance new Cesium.GeometryInstance({geometry: Ce…