无论是应用开发还是数据库管理,在不同类型数据库,实现其同样功能的 SQL 查询,都会遇到 SQL 写法或多或少不一样的问题。这与每一个数据库都有自己所特有的一些函数和功能有关。
不同类型的数据库,虽然 SQL 语法大体相似,但是它们各自的函数或符号却有些不同,有的甚至也不通用。比如将字符串 "2020-02-05" 转换成日期,标准 SQL 为 select DATE('2020-02-05') from USER, 不同数据库有不同的写法:
ORACLE:select TO_DATE('2020-02-05', 'YYYY-MM-DD') from USER;
SQLServer:select CONVERT(varchar(100), '2020-02-05', 23) from USER;
MYSQL:select DATE_FORMAT('2020-02-05','%Y-%m-%d') from USER;
如果希望应用在不同的数据库之间切换,就需要改写 SQL 语句,很麻烦。
使用集算器的 sqltranslate 函数,可以自动将 SQL 语句中的函数变换成各数据库方言的写法,这样就方便得多了。
我们以计算员工出生日期位于当年的第几周为例描述实现步骤:
1. 运行集算器,配置数据库连接并命名。填写的参数和 JDBC 连接时一样。
2. 按集算器支持的标准函数写出这句 SQL: