Хобрук: Ваш путь к мастерству в программировании

Не удается создать запрос для типа «x.y.z.package», который не настроен и не имеет настроенных подтипов.

Пытаюсь настроить HibernateSearch для интеграции ElasticSearch. У меня есть таблица Product в моей базе данных оракула. Из этой таблицы я пытаюсь выполнить поиск по названию продукта.

Для этого я пытаюсь интегрировать HibernateSearch (ElasticSearch) вместе с базой данных оракула.

Я получаю следующую ошибку от HibernateSearch:

Я использую базу данных Oracle и добавил необходимые зависимости в свой файл pom.xml.

Введите ключ поиска (для выхода введите «X»)

JT3312
Exception in thread "main" org.hibernate.search.exception.SearchException: HSEARCH000331: Can't build query for type 'com.test.webservice.model.Product' which is neither configured nor has any configured sub-types.
at org.hibernate.search.query.dsl.impl.ConnectedQueryContextBuilder$HSearchEntityContext.<init>(ConnectedQueryContextBuilder.java:60)
at org.hibernate.search.query.dsl.impl.ConnectedQueryContextBuilder.forEntity(ConnectedQueryContextBuilder.java:42)
at com.test.webservice.elasticsearch.App.search(App.java:74)
at com.test.webservice.elasticsearch.App.main(App.java:153)

Использую все последние зависимости.

hibernate-search-orm ->5.9.1.Final
hibernate-core ->5.2.16.Final`
ojdbc14 -> 10.2.0.4.0

App.java

public class App 
{

    private static void doIndex() throws InterruptedException {
        Session session = HibernateUtil.getSession();

        FullTextSession fullTextSession = Search.getFullTextSession(session);
        fullTextSession.createIndexer().startAndWait();   

        fullTextSession.close();
    }

    private static List<Product> search(String queryString) {
        Session session = HibernateUtil.getSession();
        FullTextSession fullTextSession = Search.getFullTextSession(session);

        QueryBuilder queryBuilder = fullTextSession.getSearchFactory().buildQueryBuilder().forEntity(Product.class).get();
        org.apache.lucene.search.Query luceneQuery = queryBuilder.keyword().onFields("name").matching(queryString).createQuery();

        // wrap Lucene query in a javax.persistence.Query
        org.hibernate.Query fullTextQuery = fullTextSession.createFullTextQuery(luceneQuery, Product.class);

        List<Product> productList = fullTextQuery.list();

        fullTextSession.close();

        return productList;
    }

    private static void displayContactTableData() {
        Session session = null;
        PropertiesFile propertiesFile= PropertiesFile.getInstance();
        String driverClass = propertiesFile.extractPropertiesFile().getProperty("hibernate.connection.driver_class");
        String connectionURL = propertiesFile.extractPropertiesFile().getProperty("hibernate.connection.url");
        String userName = propertiesFile.extractPropertiesFile().getProperty("hibernate.connection.username");
        String password = propertiesFile.extractPropertiesFile().getProperty("hibernate.connection.password");
        String dialect = propertiesFile.extractPropertiesFile().getProperty("hibernate.dialect");
        String showSQL = propertiesFile.extractPropertiesFile().getProperty("hibernate.show_sql");

        try {
            //session = HibernateUtil.getSession();

            // Fetching saved data
            String hql = "from Product"; 
            @SuppressWarnings("unchecked")

             Configuration cfg=new Configuration()
            .setProperty("hibernate.connection.driver_class", driverClass)
            .setProperty("hibernate.connection.url", connectionURL)
            .setProperty("hibernate.connection.username", userName)
            .setProperty("hibernate.connection.password", password)
            .setProperty("hibernate.dialect", dialect)
            .setProperty("hibernate.show_sql", showSQL)
            .addAnnotatedClass(com.test.webservice.model.Product.class);

             SessionFactory factory=cfg.buildSessionFactory();  
             session=factory.openSession();  
             Transaction t=session.beginTransaction(); 

            List<Product> productList = session.createQuery(hql).list();

            for (Product product : productList) {
                System.out.println("Product Name --->"+product.getName());
            }

        } catch(HibernateException exception){
             System.out.println("Problem creating session factory");
             exception.printStackTrace();
        }finally{
            if(session != null) {
                session.close();
            }
        }
    }

    public static void main(String[] args) throws InterruptedException {
        System.out.println("\n\n******Data stored in Contact table******\n");
        displayContactTableData();

        // Create an initial Lucene index for the data already present in the database
        doIndex();   // Error occuring on this line

        Scanner scanner = new Scanner(System.in);
        String consoleInput = null;

        while (true) {
            // Prompt the user to enter query string
            System.out.println("\n\nEnter search key (To exit type 'X')");      
            System.out.println();
            consoleInput = scanner.nextLine();

            if("X".equalsIgnoreCase(consoleInput)) {
                System.out.println("End");
                System.exit(0);
            }   

            List<Product> result = search(consoleInput);            
            System.out.println("\n\n>>>>>>Record found for '" + consoleInput + "'");

            for (Product product : result) {
                System.out.println(product);
            }               
        }           
    }
}

hibernate.cfg.xml

<hibernate-configuration>
    <session-factory>

        <property name="hibernate.connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
        <property name="hibernate.connection.url">jdbc:oracle:thin:@localhost:1521:xe</property>
        <property name="hibernate.connection.username">vb</property>
        <property name="hibernate.connection.password">123456</property>
        <property name="hibernate.dialect">org.hibernate.dialect.OracleDialect</property>
        <property name="show_sql">false</property>
        <property name="format_sql">true</property>

        <property name="hibernate.hbm2ddl.auto">update</property>

        <property name="hibernate.search.default.directory_provider">filesystem</property>
        <property name="hibernate.search.default.indexBase">C:\lucene\indexes</property>

        <mapping class="com.test.webservice.model.Product" />

    </session-factory>
</hibernate-configuration>

Продукт.java

@Entity
@Indexed
@Table(name = "PRODUCT")
public class Product {

    @Field(index = Index.YES, analyze = Analyze.YES, store = Store.NO)
    private String name;

    @Id
    @GeneratedValue
    private long id;


    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }


    public void setId(long id) {
        this.id = id;
    }

    @Id
    public long getId() {
        return id;
    }

}

Ответы:


1

Как я отвечал на ваш другой вопрос, проблема, скорее всего, заключается в том, как вы загружаете Hibernate в HibernateUtil. Очень вероятно, что вы забыли звонок addAnnotatedClass.

Спросите себя, почему вы должны были прокомментировать эту строку в displayContactTableData:

        //session = HibernateUtil.getSession();

Очевидно, что с вашим HibernateUtil что-то не так, так что исправьте это вместо того, чтобы избегать его в одних местах и ​​нет в других.

02.05.2018
Новые материалы

Почему шаблоны проектирования и почему нет?
Сложность — мать всех проблем в программировании. Программное обеспечение должно быть разработано с точки зрения того, кто его поддерживает, а не того, кто его пишет, потому что программное..

Создание дизайна обуви с помощью машинного обучения
Обувь. Что подождать? Я думал, что речь пойдет о машинном обучении! Ну это так. Если бы вы пошли на Amazon, сколько обуви вы бы нашли? Наверное, много, не так ли? Но много ли в них..

GraalVM в 2022 году: итоги года
2022 год был очень продуктивным для проекта и сообщества GraalVM. Вместе мы разработали множество новых функций, выпустили GraalVM для последних версий Java и новых платформ и увидели несколько..

Быстрая разработка: волшебный мир больших языковых моделей
РУКОВОДСТВО Быстрая разработка: волшебный мир больших языковых моделей Подход, основанный на данных, для получения наилучшего ответа Искусство и наука Можно ли совместить машинное..

Ускоренный курс по Node Redis
Сегодня мы будем учиться использовать Redis в Node.js, однако я не собираюсь вываливать сюда всю документацию и утомлять вас до смерти. Это руководство для начинающих? — спросите вы. Ну..

Обзор Python для науки о данных и машинного обучения
Python стал наиболее предпочтительным языком программирования среди разработчиков, которые в основном занимаются наукой о данных и машинным обучением. Интуитивно понятные и уникальные функции..

Принудительный сброс состояния компонента React с помощью ключевого свойства
Принудительный сброс состояния компонента React с помощью ключевого свойства Знаете ли вы, что вы можете использовать опору key для принудительного сброса состояния компонента? В..