В свободное время потихоньку пилю свой
фреймворк. По сути, в общем и целом ничего нового там нет. Но я предлагаю свой взгляд на некоторые моменты, прежде всего обусловленный моими собственными тараканами. Например, я панически боюсь всего, что напоминает динамическую типизацию и потому вместо строк у меня повсюду интерфейсы. В принципе, можно
(
Read more... )
WHERE 2 = (SELECT COUNT(*) FROM t1 WHERE t1.id = t.id)
Пришлось немного допилить поддержку подзапросов в библиотеке. В последней ревизии работает вот такой юнит-тест:
@Test
public void shouldGenerateCountSubquery() {
FooSource t1 = qb.get(FooSource.class);
FooSource t2 = qb.get(FooSource.class);
String sql = sql(qb.with(t1)
.filter(qb.wrap(2).allEq(
qb.with(t2)
.filter(t2.id().eq(t1.id()))
.fetch(qb.rowCount())))
.fetch(qb.rowCount()));
assertEquals("SELECT\n" +
" COUNT(*)\n" +
"FROM foo AS src0\n" +
"WHERE (2 = ALL (\n" +
" SELECT\n" +
" COUNT(*)\n" +
" FROM foo AS src1\n" +
" WHERE (src1.id = src0.id)\n" +
"))\n\n", sql);
}
Для второго примера пока не поддерживается row constructor и union. Но допилить поддержку - это вопрос лишь времени, никаких принципиальных ограничений я не вижу. Почему я считаю, что подобный генератор лучше, чем просто SQL, даже в статическом случае - уже отписался. Всякие отмазки вида "сделай хранимку" считаю левыми. Да и лично у меня очень много динамического SQL на работе.
По шаблонизатору - насколько я вижу, вы практически в точности повторили современный JSP, в частности тэги JSTL и expression language. Чем же тогда мерзок JSP?
Как раз JSTL и EL как инструменты выглядят ещё сносно. Но то, как они вкрячены в JSP, который изначально крив - мне не нравится. А так можно рассуждать на тему "а зачем нужен был JSP, когда есть XSLT", только на основании того, что внешне синтаксис похож. Ну, например, мой шаблонизатор - это именно шаблонизатор, т.е. его можно использовать вообще вне контекста веб-приложений. Т.е. там нет всякой свойственной для JSP мишуры вроде времени жизни bean'ов. Более подбробно по поводу шаблонизатора я, повторяю, могу отписаться. Но это уже нужно отдельный пост писать, а не коммент.
Reply
Reply
Leave a comment