Mysql
 sql >> база данни >  >> RDS >> Mysql

jooq разширява съществуващия диалект. Приемете диалекта на MySQL към диалекта на Apache Hive

За съжаление, разширяването на jOOQ за цялостна поддръжка на нов SQL диалект не е много лесно. API на jOOQ се разрасна с течение на времето, поддържайки голям набор от стандартни и специфични за доставчика варианти на SQL синтаксис. Въпреки че диалектът Apache Hive може да изглежда подобен на MySQL, вероятно има много фини разлики, които трябва да бъдат внедрени във вътрешността на jOOQ. Различното изпълнение на клаузата LIMIT .. OFFSET е само един проблем. Въпреки това, обикновено не е добра идея да използвате jOOQ с „неизвестен“ или „неподдържан“ диалект.

Решение:В краткосрочен план

В краткосрочен план вероятно ще трябва да закърпите изобразения SQL на jOOQ. Най-добрата техника за това е да използвате ExecuteListener, както е документирано тук:

При получаване на събитие "renderEnd()" вие ще можете да осъществите достъп до изобразения SQL и да го промените с помощта на регулярни изрази или друга техника, която предпочитате.

Решение:В дългосрочен план

В дългосрочен план може да има по-добро решение, ако / когато #2337 е внедрено (но ние вероятно няма да приложим това)



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Пребройте посещенията до днес, тази седмица, миналия месец и общо [MySQL заявка]

  2. Модел на вложен набор, брой елементи в категории

  3. Настройки на mysql за часова зона на Codeigniter

  4. Command.Parameters[@name].Value Правилен синтаксис

  5. Естествената заявка на JPA за полето LONGTEXT в изглед на MySQL води до грешка