2013-03-25 3 views
-3

Я встречая следующее сообщение об ошибке при попытке выполнить простой запрос HQL (от Famille) из HQL Editor (зимуют Tools) в Eclipse (Juno):Невозможно выполнить простой HQL запрос из Hibernate Tools

org.hibernate.exception.SQLGrammarException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '.famille famille0_' at line 1 

здесь подробная ошибка:

org.hibernate.exception.SQLGrammarException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '.famille famille0_' at line 1 
at org.hibernate.exception.internal.SQLStateConverter.convert(SQLStateConverter.java:100) 
at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:125) 
at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:110) 
at org.hibernate.engine.jdbc.internal.proxy.AbstractStatementProxyHandler.continueInvocation(AbstractStatementProxyHandler.java:129) 
at org.hibernate.engine.jdbc.internal.proxy.AbstractProxyHandler.invoke(AbstractProxyHandler.java:81) 
at $Proxy29.executeQuery(Unknown Source) 
at org.hibernate.loader.Loader.getResultSet(Loader.java:1978) 
at org.hibernate.loader.Loader.doQuery(Loader.java:829) 
at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:289) 
at org.hibernate.loader.Loader.doList(Loader.java:2463) 
at org.hibernate.loader.Loader.doList(Loader.java:2449) 
at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2279) 
at org.hibernate.loader.Loader.list(Loader.java:2274) 
at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:470) 
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:355) 
at org.hibernate.engine.query.spi.HQLQueryPlan.performList(HQLQueryPlan.java:196) 
at org.hibernate.internal.SessionImpl.list(SessionImpl.java:1115) 
at org.hibernate.internal.QueryImpl.list(QueryImpl.java:101) 
at org.jboss.tools.hibernate4_0.HQLQueryPage.getList(HQLQueryPage.java:58) 
at org.hibernate.eclipse.console.views.QueryPageViewer$ContentProviderImpl.getElements(QueryPageViewer.java:120) 
at org.eclipse.jface.viewers.StructuredViewer.getRawChildren(StructuredViewer.java:1010) 
at org.eclipse.jface.viewers.ColumnViewer.getRawChildren(ColumnViewer.java:703) 
at org.eclipse.jface.viewers.AbstractTableViewer.getRawChildren(AbstractTableViewer.java:1087) 
at org.eclipse.jface.viewers.StructuredViewer.getFilteredChildren(StructuredViewer.java:917) 
at org.eclipse.jface.viewers.StructuredViewer.getSortedChildren(StructuredViewer.java:1067) 
at org.eclipse.jface.viewers.AbstractTableViewer.internalRefreshAll(AbstractTableViewer.java:701) 
at org.eclipse.jface.viewers.AbstractTableViewer.internalRefresh(AbstractTableViewer.java:649) 
at org.eclipse.jface.viewers.AbstractTableViewer.internalRefresh(AbstractTableViewer.java:636) 
at org.eclipse.jface.viewers.AbstractTableViewer$2.run(AbstractTableViewer.java:592) 
at org.eclipse.jface.viewers.StructuredViewer.preservingSelection(StructuredViewer.java:1443) 
at org.eclipse.jface.viewers.StructuredViewer.preservingSelection(StructuredViewer.java:1404) 
at org.eclipse.jface.viewers.AbstractTableViewer.inputChanged(AbstractTableViewer.java:590) 
at org.eclipse.jface.viewers.ContentViewer.setInput(ContentViewer.java:280) 
at org.eclipse.jface.viewers.StructuredViewer.setInput(StructuredViewer.java:1690) 
at org.hibernate.eclipse.console.views.QueryPageViewer.createTable(QueryPageViewer.java:225) 
at org.hibernate.eclipse.console.views.QueryPageViewer.createControl(QueryPageViewer.java:203) 
at org.hibernate.eclipse.console.views.QueryPageViewer.<init>(QueryPageViewer.java:160) 
at org.hibernate.eclipse.console.views.QueryPageTabView.rebuild(QueryPageTabView.java:109) 
at org.hibernate.eclipse.console.views.QueryPageTabView$1.contentsChanged(QueryPageTabView.java:75) 
at org.hibernate.eclipse.console.views.QueryPageTabView$1.intervalAdded(QueryPageTabView.java:85) 
at javax.swing.AbstractListModel.fireIntervalAdded(Unknown Source) 
at org.hibernate.console.QueryPageModel.add(QueryPageModel.java:67) 
at org.hibernate.console.KnownConfigurations$1.queryPageCreated(KnownConfigurations.java:88) 
at org.hibernate.console.ConsoleConfiguration.fireQueryPageCreated(ConsoleConfiguration.java:332) 
at org.hibernate.console.ConsoleConfiguration.executeHQLQuery(ConsoleConfiguration.java:301) 
at org.hibernate.eclipse.hqleditor.HQLEditor.executeQuery(HQLEditor.java:447) 
at org.hibernate.eclipse.console.actions.ExecuteQueryAction.execute(ExecuteQueryAction.java:88) 
at org.hibernate.eclipse.console.actions.ExecuteQueryAction.run(ExecuteQueryAction.java:56) 
at org.eclipse.jface.action.Action.runWithEvent(Action.java:498) 
at org.hibernate.eclipse.console.actions.ExecuteQueryAction.runWithEvent(ExecuteQueryAction.java:60) 
at org.eclipse.jface.action.ActionContributionItem.handleWidgetSelection(ActionContributionItem.java:584) 
at org.eclipse.jface.action.ActionContributionItem.access$2(ActionContributionItem.java:501) 
at org.eclipse.jface.action.ActionContributionItem$6.handleEvent(ActionContributionItem.java:452) 
at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84) 
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1053) 
at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:4169) 
at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3758) 
at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine$9.run(PartRenderingEngine.java:1053) 
at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332) 
at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.run(PartRenderingEngine.java:942) 
at org.eclipse.e4.ui.internal.workbench.E4Workbench.createAndRunUI(E4Workbench.java:86) 
at org.eclipse.ui.internal.Workbench$5.run(Workbench.java:588) 
at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332) 
at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:543) 
at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149) 
at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:124) 
at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196) 
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110) 
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79) 
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:353) 
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:180) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
at java.lang.reflect.Method.invoke(Unknown Source) 
at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:629) 
at org.eclipse.equinox.launcher.Main.basicRun(Main.java:584) 
at org.eclipse.equinox.launcher.Main.run(Main.java:1438) 
at org.eclipse.equinox.launcher.Main.main(Main.java:1414) 

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '.famille famille0_' at line 1 
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) 
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) 
at java.lang.reflect.Constructor.newInstance(Unknown Source) 
at com.mysql.jdbc.Util.handleNewInstance(Util.java:411) 
at com.mysql.jdbc.Util.getInstance(Util.java:386) 
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1052) 
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3597) 
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3529) 
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1990) 
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2151) 
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2625) 
at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2119) 
at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:2281) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
at java.lang.reflect.Method.invoke(Unknown Source) 
at org.hibernate.engine.jdbc.internal.proxy.AbstractStatementProxyHandler.continueInvocation(AbstractStatementProxyHandler.java:122) 
... 75 more 

EDIT:

Famille.hbm.xml

<?xml version="1.0"?> 
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> 
<!-- Generated 25 mars 2013 11:54:17 by Hibernate Tools 4.0.0 --> 
<hibernate-mapping> 
<class name="beans.Famille" table="famille" catalog="bd"> 
    <id name="familleId" type="java.lang.Integer"> 
     <column name="familleID" /> 
     <generator class="identity" /> 
    </id> 
    <property name="libelle" type="string"> 
     <column name="libelle" not-null="true" unique="true" /> 
    </property> 
    <set name="articles" table="article" inverse="true" lazy="true" fetch="select"> 
     <key> 
      <column name="familleID" /> 
     </key> 
     <one-to-many class="beans.Article" /> 
    </set> 
</class> 
</hibernate-mapping> 

сгенерированный SQL-запрос:

0: beans.Famille 
----------------- 
select 
    famille0_.familleID as familleID103_, 
    famille0_.libelle as libelle103_ 
from 
    bd.bd.famille famille0_ 

Я использую Hibernate 4 с (InnoDB) диалекта MySQL 5,

пожалуйста, что мне не хватает?

+0

Где находится запрос? – Alex

+0

Вы можете отредактировать в соответствующих сопоставлениях объектов и запросе HQL, который вы пытаетесь выполнить? –

+0

привет, честно говоря, ваш вопрос плох, хотя многие ребята хотят помочь вам, но вы ничего нам не сказали. – OQJF

ответ

0

Когда я сгенерировал код домена и файлы hbm из моей базы данных с помощью Hibernate Tools, свойство каталога было установлено для всех моих файлов сопоставления, поэтому, когда я выполняю запрос, сгенерированный SQL ищет bd.bd.table вместо bd.table.

Так что я удалил каталог свойство из всех моих отображения файлов

<hibernate-mapping> 
<class name="beans.Famille" table="famille"> 
//... 
</class> 
</hibernate-mapping> 

и теперь сгенерированный код выглядит следующим образом:

HQL:

from Famille 

SQL:

select 
    famille0_.familleID as familleID128_, 
    famille0_.libelle as libelle128_ 
from 
    bd.famille famille0_ 
0

Если запрос является просто from Town, и вы получаете это исключение, это означает, что сопоставление вашего объекта не соответствует именам столбцов в вашей базе данных.

Мы могли бы помочь только в том случае, если вы предоставили нам код объекта и его сопоставление, определение таблицы базы данных и сгенерированный SQL-запрос.

+0

Я сделал обратную разработку с помощью Hibernate Tools (версия 4) с MySQL5 (innodb) как Dialect, и я только что проверил свой файл hbm и соответствующую таблицу, они выглядят хорошо – Hidalgo

+0

доступ к столбцу .famille в сообщении об ошибке. В вашем картографировании нет столбца famille. Почему бы вам не сделать то, что вас спрашивают, хотите ли вы помочь? Показать код объекта, его сопоставление и сгенерированный SQL-запрос. –

+0

Я только что добавил код Entity и файл сопоставления – Hidalgo

 Смежные вопросы

  • Нет связанных вопросов^_^