LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

pgsql语法不兼容和双向兼容sqlserver的地方

maoxiaoming
2025年8月13日 17:23 本文热度 55

双向兼容:

例子1:因为pgsql大小写敏感,统一用引号引上,sqlserver会自己变成小写

sql
SELECT "ID" FROM table

例子2:因为pgsql的数据类型比较少,通一转换之后比较

sql
SELECT * FROM dept WHERE CAST(label AS INTEGER) < 7 ORDER BY dept_all_code

不兼容:

例子1:

sql
--pgsql
SELECT
MAX(CAST(newnotice.notice_no AS integer)) AS notice_no FROM newnotice WHERE newnotice.sendusername = '"& dept_inner_id &"' AND newnotice.sendyear = CAST(EXTRACT(YEAR FROM CURRENT_TIMESTAMP) AS text) AND newnotice.notice_no <> '转发文档' AND SUBSTRING(newnotice.notice_no FROM 1 FOR 1) ~ '[0-9]'

sql
--sqlserver
SELECT
max(cast(newnotice.notice_no as int)) AS notice_no FROM newnotice WHERE newnotice.sendusername='"& dept_inner_id &"' AND newnotice.sendyear=year(getdate()) and newnotice.notice_no<>'转发文档' and CHARINDEX(left(newnotice.notice_no,1),'0123456789')>0

​1. 数据库年份获取方式

PostgreSQL版本

sql
newnotice.sendyear = CAST(EXTRACT(YEAR FROM CURRENT_TIMESTAMP) AS text)
  • 使用EXTRACT(YEAR FROM CURRENT_TIMESTAMP)获取当前年份

  • 需要将结果转为文本(AS text)与sendyear字段比较

SQL Server版本

sql
newnotice.sendyear=year(getdate())
  • 使用YEAR(GETDATE())函数获取当前年份

  • 不需要显式类型转换

2. 检查首字符是否为数字的方法

PostgreSQL版本

sql
SUBSTRING(newnotice.notice_no FROM 1 FOR 1) ~ '[0-9]'
  • 使用SUBSTRING(... FROM ... FOR ...)语法

  • 使用正则表达式操作符~匹配数字模式

SQL Server版本

sql
CHARINDEX(left(newnotice.notice_no,1),'0123456789')>0
  • 使用LEFT()函数获取第一个字符

  • 使用CHARINDEX()检查字符是否在'0123456789'字符串中

3.数据库日期获取方式

PostgreSQL版本

sql
-- PostgreSQLWHERE create_date > now() - interval '1 day'

SQL Server版本

sql
-- SQL ServerWHERE create_date > GETDATE() - 1

总结:想实现双向兼容时(前提是先兼容了pgsql),pgsql语句只有NOW(),EXTRACT(YEAR FROM CURRENT_TIMESTAMP)有待补充....需要注意一下。



该文章在 2025/8/13 17:23:24 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved