Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Сравнение коллекций в Hibernate 
V
    Опции темы
ShamanTrirukiy
Дата 16.4.2007, 15:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 65
Регистрация: 12.4.2006
Где: Харьков

Репутация: нет
Всего: 5



Драсьте всем. Столкнулся с проблемой, возникающей при попытке сравнения коллекций в запросе.
Убедительная просьба не посылать сразу же в ФАК - я его уже вдоль и поперёк перечитал.
Одна коллекция - значение поля класса, вторую устанавливаю в query при помощи setParameterList().
Попробовал сравнивать при помощи "=" (думал, по хэшу сравнит) - не получилось.
Вот та часть запроса, которую я использовал для сравнения: 
Код

AND c.investmentProfile.continents = :cContinents

В результате получаю 
Код

15:13:55,906 ERROR org.hibernate.util.JDBCExceptionReporter:78
     - ═х єърчрэю чэрўхэшх фы  ярЁрьхЄЁр 2.

Посмотрел sql hibernate'a - в строке запроса получаю
Код

 and .=?

С вопросом всё ясно - Hibernate "прячет" установленные данные. Но вот что значит абракадабра и почему в запросе просто "." ???
PM MAIL   Вверх
ShamanTrirukiy
Дата 17.4.2007, 18:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 65
Регистрация: 12.4.2006
Где: Харьков

Репутация: нет
Всего: 5



В общем, решил эту проблему следующим образом:
Добавил поле 
Код

private Map<String, Object[]> collectionValues = null;


И метод
Код

private String buildCollectionQuery(List col, String alias, String entityPath) {
    String alias_ = ":" + alias;
    if (collectionValues == null)
      collectionValues = new HashMap<String, Object[]>();
    String sql = " AND (size(" + entityPath + ") = " + col.size();
    for (int i = 0; i < col.size(); i++) {
      collectionValues.put(alias, new Object[] { alias + i, col.get(i) });
      sql += " AND " + (alias_ + i) + " IN ELEMENTS (" + entityPath + ")";
    }
    sql += ")";
    return sql;
  }

который вызывается при сборке текста запроса а так же код
Код

for (String colName : collectionValues.keySet()) {
      q.setEntity("" + collectionValues.get(colName)[0], collectionValues
          .get(colName)[1]);
    }

который вызывается при установке параметров в query.

Пример обращения к методу
Код

if (params.getClientSearch().getCountries() != null
        && !params.getClientSearch().getCountries().isEmpty()) { //params - список параметров, установленых в query
      queryText += (buildCollectionQuery(params.getClientSearch()
          .getCountries(), "cCountries", "c.investmentProfile.countries"));
    }


Как-то это не очень красиво, но лучшего ничего не придумал.

Это сообщение отредактировал(а) ShamanTrirukiy - 17.4.2007, 18:26
PM MAIL   Вверх
ShamanTrirukiy
Дата 18.4.2007, 19:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 65
Регистрация: 12.4.2006
Где: Харьков

Репутация: нет
Всего: 5



Чё-то я тут не то запостил (нечто среднее между первой и последней версией). Может кому-то понадобится, так что исправляю:
Код

private Map<String, Object> collectionValues = null;

и
Код

private String buildCollectionQuery(List col, String alias, String entityPath) {
    String alias_ = ":" + alias;
    if (collectionValues == null)
      collectionValues = new HashMap<String, Object>();
    String sql = " AND (size(" + entityPath + ") = " + col.size();
    for (int i = 0; i < col.size(); i++) {
      collectionValues.put(alias + i, col.get(i));
      sql += " AND " + (alias_ + i) + " IN ELEMENTS (" + entityPath + ")";
    }
    sql += ")";
    return sql;
  }

и
Код

for (String key : collectionValues.keySet()) {
      q.setEntity(key, collectionValues.get(key));
    }

соответственно. Так вроде как красивее.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java EE (J2EE) и Spring | Следующая тема »


 




[ Время генерации скрипта: 0.1078 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.