本网站(662p.com)打包出售,且带程序代码数据,662p.com域名,程序内核采用TP框架开发,需要联系扣扣:2360248666 /wx:lianweikj
精品域名一口价出售:1y1m.com(350元) ,6b7b.com(400元) , 5k5j.com(380元) , yayj.com(1800元), jiongzhun.com(1000元) , niuzen.com(2800元) , zennei.com(5000元)
需要联系扣扣:2360248666 /wx:lianweikj
怎样写出可以在各个数据库中都能执行的SQL?
codesky · 261浏览 · 发布于2021-12-27 +关注

不同类型数据库的函数语法或多或少存在差异,要想让功能相同的 SQL 查询语句在不同类型的数据库中都能被顺利执行,就要把各数据库都有的那些差异化函数语法进行翻译。

不同类型数据库的函数语法或多或少存在差异,要想让功能相同的 SQL 查询语句在不同类型的数据库中都能被顺利执行,就要把各数据库都有的那些差异化函数语法进行翻译。

使用 ORM 技术能够将程序员书写的查询转换成不同数据库的 SQL,相当于有一定的移植能力。但 ORM 技术只适合应对 OLTP 场景下的简单 SQL,难以实现 OLAP 场景下较复杂 SQL 的移植,例如,使用了 ORM 技术中不直接支持的函数,或者遇到 FROM 中包含子查询的复杂 SQL。

集算器 SPL 设计了一套标准的 SQL 查询语法,该语法内置大量函数(还在持续追加中),可描述更多常运算。SPL 中有一个 sqltranslate 函数,可以把这种标准 SQL 翻译成不同数据库的 SQL,实现数据库的迁移。

比如这样的标准 SQL:

SELECT CLIENT, YEAR(ORDERDATE), SUM(AMOUNT) 
            , COUNT(ORDERID) 
FROM ORDERS 
GROUP BY CLIENT, YEAR(ORDERDATE) 
HAVING SUM(AMOUNT) > 2000

    用.sqltranlate(“MYSQL”) 翻译后就得到:

    SELECT CLIENT, YEAR(ORDERDATE), SUM(AMOUNT) 
                , COUNT(ORDERID) 
    FROM ORDERS 
    GROUP BY CLIENT, YEAR(ORDERDATE) 
    HAVING SUM(AMOUNT) > 2000

      而如果使用.sqltranslate(“ORACLE”) 将返回:

      SELECT CLIENT, EXTRACT(YEAR FROM ORDERDATE), SUM(AMOUNT) 
                  , COUNT(ORDERID) 
      FROM ORDERS 
      GROUP BY CLIENT, EXTRACT(YEAR FROM ORDERDATE) 
      HAVING SUM(AMOUNT) > 2000

        可以看到,标准函数能够正确地根据数据库选择相应的函数。

        SPL 实现 SQL 移植,采取的策略是只对标准 SQL 中的函数进行翻译,不翻译(原样照抄)语句,从而使标准 SQL 可描述更多的运算。比如,对于下面的子查询无论翻译成哪种数据库 SQL 都不会变,也都可以正常执行。

        SELECT 
            ORDERID, 
            M 
        FROM 
            ( 
            SELECT 
                ORDERID, 
                MONTH(ORDERDATE) M 
            FROM 
                ORDERS) T1

          集算器 SPL 是 Java 写的开源软件,很容易被 JAVA 应用 集成而使用这个 SQL 移植的功能,在应用程序中如果需要翻译 SQL 语句,可以直接调用 api 方法:

          String sql = “SELECT CLIENT, YEAR(ORDERDATE), SUM(AMOUNT) , COUNT(ORDERID) FROM ORDERS GROUP BY CLIENT, YEAR(ORDERDATE) HAVING SUM(AMOUNT) > 2000”;  
          sql = com.raqsoft.dm.sql.SQLUtil.translate(sql, “ORACLE”);


            相关推荐

            使用SELECT语句检索数据

            奔跑的男人 · 804浏览 · 2019-06-03 09:33:43
            部署MySQL延迟从库的几个好处

            吴振华 · 663浏览 · 2019-05-14 21:57:51
            MongoDB凭什么跻身数据库排行前五?

            iamitnan · 723浏览 · 2019-06-18 10:04:56
            Oracle开启和关闭的几种模式

            qq2360248666 · 751浏览 · 2019-06-04 10:18:47
            加载中

            0评论

            评论
            分类专栏
            小鸟云服务器
            扫码进入手机网页