当前位置: 首页 > news >正文

ChatGPT教我将MySQL中where find_in_set改成PostgreSQL支持的写法

问题

之前使用Mybatis,在MySQL中使用如下SQL语句没有问题:

SELECT *
FROM dept
WHERE find_in_set('5',dept_parent);

现在切换到PostgreSQL,发现find_in_set函数不能使用。

解决

SELECT *
FROM dept
WHERE '5' = ANY(string_to_array(dept_parent, ','));

总结

能不在一个字段里面反应一对多关系,尽可能不要这样设计,最好是使用中间表设计这种一对多关系;如果对性能要求一般的用那种不用在代码里面写sql纯ORM框架也行,如果出现开发一半换库的问题,像hibernate这种框架就能比较好解决这种开发一半从mysql换postgresql库的问题。感谢ChatGPT,教我改SQL。

http://www.lryc.cn/news/420653.html

相关文章:

  • Python命令模式:掌控你的代码指令
  • 【物联网】(防水篇)电子产品 IPX7 防水级别测试的具体流程
  • Redis 实现消息队列
  • 模板初阶(详解)
  • 对称加密算法解析:DES、AES及其在`pycryptodome` 和 `crypto-js` 模块中的应用
  • C++设计模式(代理模式)
  • Linux系统驱动(十三)Linux内核定时器
  • Visual Studio 调试时加载符号慢
  • Spring Cloud Config:动态配置的魔法师
  • Webpack入门基础知识及案例
  • 对中国人工智能与国外人工智能的思考
  • 【debian系统arm架构安装docker】且换源后依旧不行就离线导入镜像
  • Readwise 官方 Obsidian 插件使用
  • A. A+B Again?
  • pr样机模板视频素材|城市户外高速路广告牌视频样机
  • 谷歌大中华区总裁:所有企业都在问这个问题
  • GPT-4o:AI视觉识别的革命性飞跃
  • 将电脑打造成私人网盘,支持外网访问之详细操作教程
  • spring同一个接口如何分页实现主表或主+联表group by查询
  • SpringDataJpa源码分析
  • 卷积神经网络 - 卷积神经网络与深度学习的历史篇
  • 初识 Floodfall 算法
  • [Linux] LVM挂载的硬盘重启就掉的问题解决
  • YOLOv8改进 | 主干网络 | 用EfficientNet卷积替换backbone【教程+代码 】
  • 数据库规范化设计 5大基本原则
  • 【nginx】解决k8s中部署nginx转发不会自动更新域名解析启动失败的问题
  • LeetCode637 二叉树的层平均值
  • 王学岗ASM
  • 【数据结构】—— 队列
  • vue中openlayers过滤高亮显示某个图层