5

我正在试用 Play 框架并使用 2.2.0 版本和 Java 版本。

我想使用 MySQL 作为数据库,我已经按照网站上的说明进行操作。我能够运行进化脚本,但我无法将任何内容保存到数据库中。在数据库中创建的表。我[PersistenceException: java.sql.SQLException: Connection is closed!]在尝试调用我的控制器中的 Ebean.save() 方法时得到了。

我所做的是:

  1. 设置 build.sbt 并添加插件

    libraryDependencies ++= Seq(
        javaJdbc,
        javaEbean,
        cache,
        "mysql" % "mysql-connector-java" % "5.1.18"
    )
    
  2. 设置 conf/application.conf

    db.default.driver=com.mysql.jdbc.Driver
    db.default.url="jdbc:mysql://localhost:3306/TLC?characterEncoding=UTF-8"
    db.default.user=root
    db.default.pass=secret
    
  3. Ebean 服务器

    ebean.default="models.*"
    
  4. 创建了控制器类包控制器;

    import com.avaje.ebean.Ebean;
    import play.*;
    import play.data.Form;
    import play.mvc.*;
    import models.Bar;
    import views.html.*;
    
    public class Application extends Controller {
    
        public static Result index() {
            return ok(index.render("Your new application is ready."));
        }
    
        public static Result addBar() {
            Bar bar = Form.form(Bar.class).bindFromRequest().get();
            bar.save();
            return redirect(routes.Application.index());
        }
    }
    
  5. 创建了一个表格

    <form action="@routes.Application.addBar()" method="post">
        <input name="name"/>
        <input type="submit"/>
    </form>
    
  6. 添加了路线

    POST    /bars                       controllers.Application.addBar()
    
  7. 当然是模型本身。封装模型;

    import play.db.ebean.Model;
    
    import javax.persistence.Entity;
    import javax.persistence.Id;
    
    @Entity
    public class Bar extends Model {
        @Id
        public String id;
        public String name;
    
    }
    
  8. 当然,在 mysql 中创建数据库本身。

我错过了什么?我已经做了 4 个小时了,仍然不知道出了什么问题。如果我在内存数据库中使用 h2,它工作得很好。请帮我。

谢谢!

4

4 回答 4

2

我有类似的问题,我找到了解决方案。

罪魁祸首是您的实体的id财产。Bar您已将 定义id为字符串,并且在保存Bar. 如果是Long,则 id 值会自动生成,但对于 String 您需要显式设置它。

所以,

Bar bar = Form.form(Bar.class).bindFromRequest().get();
bar.id = UUID.randomUUID().toString();
bar.save();

应该解决这个问题。希望这可以帮助。

于 2014-02-23T06:11:01.793 回答
0

有时它可能是插入期间跳过的“非空”列。在我的情况下,我添加了一个带有“not null”的“int”类型的新列,并忘记为它们插入值。希望它可以帮助一些人。

于 2015-02-03T09:28:09.197 回答
0

您可能会尝试的一件事是升级 mysql 连接器。您使用的那个有点旧(2011 年 4 月发布)

“mysql”%“mysql-connector-java”%“5.1.26”

如果这没有帮助,那么我会尝试确保凭据 + 连接 URL 是正确的。

于 2013-10-26T22:05:18.327 回答
0

我遇到了同样的问题(在带有 MySQL 的 Mac OS X 上),但我没有使用 String ID

 User {
     @Id
     public long id;
     public String fullName;    
 }

当我尝试时:

Ebean.save(user) 

我有:

[PersistenceException:java.sql.SQLException:连接已关闭!]

使用自动增量策略并更新 mysql 连接器对我没有帮助。

问题是尝试在字段中编写 unicode,因为没有 Unicode 一切正常。经过仔细检查,发现 MySQL 数据库是在没有 utf8_general_ci 的情况下创建的,但是在现有数据库上使用 ALTER 添加此属性不起作用。

使用默认排序规则 utf8_general_ci创建一个新数据库,对我有用。

于 2014-08-01T00:50:54.357 回答