У JPA все еще есть ссылка на удаленный объект, следовательно, генерируется исключение - PullRequest
0 голосов
/ 05 ноября 2010

Я удаляю сущность FriendWith и создаю RelationShip. Но JPA все еще думают, что FriendWith есть. Когда я внедряю приложение EE, вот что я получил в своем журнале сервера.

[#|2010-11-05T14:31:51.190-0400|INFO|glassfish3.1|javax.enterprise.system.core.classloading.com.sun.enterprise.loader|_ThreadID=17;_ThreadName=Thread-1;|com.scholar.entity.<error> actually got transformed|#]

Я знаю com.scholar.entity.<error> см. com.scholar.entity.FriendWith

java.lang.ExceptionInInitializerError
  at java.lang.Class.forName0(Native Method)
  at java.lang.Class.forName(Class.java:247)
  at org.eclipse.persistence.internal.security.PrivilegedAccessHelper.getClassForName(PrivilegedAccessHelper.java:88)
  at org.eclipse.persistence.descriptors.ClassDescriptor.convertClassNamesToClasses(ClassDescriptor.java:1230)
  at org.eclipse.persistence.sessions.Project.convertClassNamesToClasses(Project.java:362)
  at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.deploy(EntityManagerSetupImpl.java:332)
  at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.getServerSession(EntityManagerFactoryImpl.java:157)
  at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.createEntityManagerImpl(EntityManagerFactoryImpl.java:214)
  at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:202)
  at org.glassfish.persistence.jpa.PersistenceUnitLoader.doJava2DB(PersistenceUnitLoader.java:371)
  at org.glassfish.persistence.jpa.JPADeployer$2.visitPUD(JPADeployer.java:241)
  at org.glassfish.persistence.jpa.JPADeployer$PersistenceUnitDescriptorIterator.iteratePUDs(JPADeployer.java:279)
  at org.glassfish.persistence.jpa.JPADeployer.iterateInitializedPUsAtApplicationPrepare(JPADeployer.java:257)
  at org.glassfish.persistence.jpa.JPADeployer.event(JPADeployer.java:199)
  at org.glassfish.kernel.event.EventsImpl.send(EventsImpl.java:128)
  at com.sun.enterprise.v3.server.ApplicationLifecycle.deploy(ApplicationLifecycle.java:419)
  at com.sun.enterprise.v3.server.ApplicationLifecycle.deploy(ApplicationLifecycle.java:242)
  at org.glassfish.deployment.admin.DeployCommand.execute(DeployCommand.java:351)
  at com.sun.enterprise.v3.admin.CommandRunnerImpl$1.execute(CommandRunnerImpl.java:354)
  at com.sun.enterprise.v3.admin.CommandRunnerImpl.doCommand(CommandRunnerImpl.java:369)
  at com.sun.enterprise.v3.admin.CommandRunnerImpl.doCommand(CommandRunnerImpl.java:1077)
  at com.sun.enterprise.v3.admin.CommandRunnerImpl.access$1200(CommandRunnerImpl.java:95)
  at com.sun.enterprise.v3.admin.CommandRunnerImpl$ExecutionContext.execute(CommandRunnerImpl.java:1226)
  at com.sun.enterprise.v3.admin.CommandRunnerImpl$ExecutionContext.execute(CommandRunnerImpl.java:1215)
  at com.sun.enterprise.v3.admin.AdminAdapter.doCommand(AdminAdapter.java:375)
  at com.sun.enterprise.v3.admin.AdminAdapter.service(AdminAdapter.java:209)
  at com.sun.grizzly.tcp.http11.GrizzlyAdapter.service(GrizzlyAdapter.java:168)
  at com.sun.enterprise.v3.server.HK2Dispatcher.dispath(HK2Dispatcher.java:117)
  at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:234)
  at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:817)
  at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:718)
  at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:1007)
  at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:225)
  at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:137)
  at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:104)
  at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:90)
  at com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:79)
  at com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:54)
  at com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59)
  at com.sun.grizzly.ContextTask.run(ContextTask.java:71)
  at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:532)
  at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513)
  at java.lang.Thread.run(Thread.java:680)

Caused by: java.lang.RuntimeException: Uncompilable source code - class <error> is public, should be declared in a file named <error>.java
at com.scholar.entity.<error>.<clinit>(FriendWith.java:22)
... 43 more

Если вы посмотрите на нижнюю часть трассировки стека, вы увидите, что в FriendWith line 22 что-то не так. Там нет FriendWith.java. Есть ли способ это исправить. Я очищаю и собираю папку проекта, перезагружаю сервер, перезагружаю компьютер, но это не исправляет

1 Ответ

0 голосов
/ 06 ноября 2010

Даже если вы удалили FriendWith.java, возможно, вы оставили вокруг FriendWith.class, и пакет JPA обнаружил, что где-то .

Поиск в банках, войнах,уши, или что-то еще и ваша файловая система для файла класса.Если вы копируете свой собранный проект в папку «развертывания», убедитесь, что файл .class находится вне области развертывания.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...