gpt4 book ai didi

java - 应用进化脚本(JPA 和 Ebean 版本)时,New I/O Worker #1 中出现框架错误

转载 作者:行者123 更新时间:2023-12-02 08:19:48 27 4
gpt4 key购买 nike

我尝试在 Oracle 10g 数据库上设置计算机数据库示例,但演化脚本出现错误:创建示例的 play_evolution 表以及 CompanyComputer 表后,play 要求我制作进化脚本以将数据放入这些数据库中: enter image description here

但是当我尝试立即应用此脚本!我得到这个结果:

2012-11-26 11:33:12,324 - [INFO] - from play in play-akka.actor.default-dispatcher-1 
database [default] connected at jdbc:oracle:thin:@10.0.2.15:1521:orcl

2012-11-26 11:33:13,166 - [ERROR] - from application in New I/O worker #1


! @6celgd3g6 - Internal server error, for request [GET /] ->

play.api.db.evolutions.InvalidDatabaseRevision: Database 'default' needs evolution! [An SQL script need to be run on your database.]
at play.api.db.evolutions.EvolutionsPlugin$$anonfun$onStart$1$$anonfun$apply$1.apply$mcV$sp(Evolutions.scala:427) ~[play_2.9.1.jar:2.0.4]
at play.api.db.evolutions.EvolutionsPlugin.withLock(Evolutions.scala:448) ~[play_2.9.1.jar:2.0.4]
at play.api.db.evolutions.EvolutionsPlugin$$anonfun$onStart$1.apply(Evolutions.scala:414) ~[play_2.9.1.jar:2.0.4]
at play.api.db.evolutions.EvolutionsPlugin$$anonfun$onStart$1.apply(Evolutions.scala:412) ~[play_2.9.1.jar:2.0.4]
at scala.collection.LinearSeqOptimized$class.foreach(LinearSeqOptimized.scala:59) ~[scala-library.jar:0.11.3]
at scala.collection.immutable.List.foreach(List.scala:45) ~[scala-library.jar:0.11.3]
at play.api.db.evolutions.EvolutionsPlugin.onStart(Evolutions.scala:412) ~[play_2.9.1.jar:2.0.4]
at play.api.Play$$anonfun$start$1.apply(Play.scala:60) ~[play_2.9.1.jar:2.0.4]
at play.api.Play$$anonfun$start$1.apply(Play.scala:60) ~[play_2.9.1.jar:2.0.4]
at scala.collection.LinearSeqOptimized$class.foreach(LinearSeqOptimized.scala:59) ~[scala-library.jar:0.11.3]
at scala.collection.immutable.List.foreach(List.scala:45) ~[scala-library.jar:0.11.3]
at play.api.Play$.start(Play.scala:60) ~[play_2.9.1.jar:2.0.4]
at play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$3$$anonfun$1.apply(ApplicationProvider.scala:125) ~[play_2.9.1.jar:2.0.4]
at play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$3$$anonfun$1.apply(ApplicationProvider.scala:112) ~[play_2.9.1.jar:2.0.4]
at scala.Option.map(Option.scala:133) ~[scala-library.jar:0.11.3]
at play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$3.apply(ApplicationProvider.scala:112) ~[play_2.9.1.jar:2.0.4]
at play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$3.apply(ApplicationProvider.scala:110) ~[play_2.9.1.jar:2.0.4]
at scala.Either$RightProjection.flatMap(Either.scala:277) ~[scala-library.jar:0.11.3]
at play.core.ReloadableApplication$$anonfun$get$1.apply(ApplicationProvider.scala:110) ~[play_2.9.1.jar:2.0.4]
at play.core.ReloadableApplication$$anonfun$get$1.apply(ApplicationProvider.scala:110) ~[play_2.9.1.jar:2.0.4]
at akka.dispatch.Future$$anon$3.liftedTree1$1(Future.scala:195) ~[akka-actor.jar:2.0.2]
at akka.dispatch.Future$$anon$3.run(Future.scala:194) ~[akka-actor.jar:2.0.2]
at akka.dispatch.TaskInvocation.run(AbstractDispatcher.scala:94) ~[akka-actor.jar:2.0.2]
at akka.jsr166y.ForkJoinTask$AdaptedRunnableAction.exec(ForkJoinTask.java:1381) ~[akka-actor.jar:2.0.2]
at akka.jsr166y.ForkJoinTask.doExec(ForkJoinTask.java:259) ~[akka-actor.jar:2.0.2]
at akka.jsr166y.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:975) ~[akka-actor.jar:2.0.2]
at akka.jsr166y.ForkJoinPool.runWorker(ForkJoinPool.java:1479) ~[akka-actor.jar:2.0.2]
at akka.jsr166y.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:104) ~[akka-actor.jar:2.0.2]

并且应用程序停留在needevolve页面上,并且数据库中的表是空的,因此显然脚本失败了(我直接在SQL上尝试进入oracle 10g并且脚本正在工作)。任何人都可以帮我解决这个问题吗?

编辑1:这是我的配置文件

application.name=computer-database
application.secret="E27D^[_<Lpt0vjad]de;3/i;tx3gpRmG4Byof/3nahO/dIo9gbsMWut1w3xg[>9W"

db.default.url="jdbc:oracle:thin:@10.0.2.15:1521:orcl"
db.default.driver=oracle.jdbc.driver.OracleDriver
db.default.user=play
db.default.password=play

ebean.default="models.*"

"assets.cache./public/stylesheets/bootstrap.min.css"="max-age=3600"

logger=ERROR

logger.play=INFO

logger.application=DEBUG

编辑 2: 我已尝试使用示例的 JPA 版本:我收到类似的错误:相同的屏幕(数据库“默认”需要进化!),当我单击立即应用此脚本!时,我在日志文件中得到完全相同的堆栈错误

编辑3:当我清理数据库时,应用程序要求我制作第一个演化脚本(同时创建表和数据的结构),所以我接受应用它:他在我的数据库上创建了表,但他没有插入数据并打印我被阻止的第二个屏幕......一开始,当应用程序尝试创建 play_evolution 表时,我收到错误。经过一番谷歌搜索后,我发现由于字段类型错误,显然 play_evolution 的代码无法与 Oracle 一起使用......所以我手动创建了它

最佳答案

看来你的配置可能是错误的,你的样本说:

db.default.pass=play

什么时候应该是:

db.default.password=play

请参阅configuration文档。

此外,请尝试完全删除数据库,以防万一。

编辑评论:

由于某种原因,您的数据库似乎进入了不稳定的位置(进化方面),但日志没有帮助。您运行的是 Play 2.0.4(最新版本)吗?

鉴于这是一个示例项目,我将通过解决方法来解决此问题:

  • 通过在 application.conf 中取消注释 evolutionplugin=disabled 来禁用演化
  • 在数据库上手动运行脚本

在此阶段,数据库将拥有您需要的数据。如果某些连接/数据类型问题是错误的根源,您将在运行应用程序时在日志中看到它,否则一切都应该正常。

您还应该在 Lighthouse 上提票关于这个问题,因为这似乎是一个严重的问题。

关于java - 应用进化脚本(JPA 和 Ebean 版本)时,New I/O Worker #1 中出现框架错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13549761/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com