【发布时间】:2015-05-09 01:41:32
【问题描述】:
最近开始使用 Play framework 2.3.8。
但是模型的更新是我在没有工作的情况下遇到了麻烦。
顺便说一句,save 方法有效。
更新不适用于以下代码。 (不会持久化到数据库中。)
User user = User.findByEmail(email);
user.remoteAddress = remoteAddress;
user.userAgent = userAgent;
user.latitude = latitude;
user.longitude = longitude;
user.lastLoginAt = new Date();
user.update();
但是,以下代码将按预期工作。
User newUser = new User();
newUser.id = user.id;
newUser.remoteAddress = remoteAddress;
newUser.userAgent = userAgent;
newUser.latitude = latitude;
newUser.longitude = longitude;
newUser.lastLoginAt = new Date();
newUser.update();
为什么我不能更新原始实例?
用户类如下。
package models.entities;
import java.util.*;
import javax.persistence.*;
import com.avaje.ebean.annotation.*;
import play.db.ebean.*;
import play.db.ebean.Model.Finder;
import play.data.validation.Constraints.*;
import play.Logger;
import models.services.*;
/**
* @author satouf
*/
@Entity
@Table(name="user")
public class User extends Model {
@Id
public Long id;
@Column(nullable = false, columnDefinition = "varchar(32)")
public String userIdentifier;
@Column(nullable = false, columnDefinition = "varchar(255)")
public String loginId;
@Column(columnDefinition = "text")
public String loginPassword;
@Column(columnDefinition = "varchar(64)")
public String handleName;
@Email
@Column(nullable = false, columnDefinition = "varchar(255)")
public String email;
@Column(nullable = false, columnDefinition = "smallint default 0")
public short status;
@Column(columnDefinition = "varchar(64)")
public String lastRemoteAddress;
public String lastUserAgent;
public Date lastLoginAt;
public double latitude;
public double longitude;
@UpdatedTimestamp
public Date updatedAt;
@CreatedTimestamp
public Date createdAt;
public static Finder<Long, User> finder = new Finder<Long, User>(Long.class, User.class);
@Override
public String toString(){
return ("[id: " + id + ", userIdentifier: " + userIdentifier + ", loginId: " + loginId + ", handleName: "
+ handleName + ", latitude: " + latitude + ", longitude: " + longitude + "]");
}
}
【问题讨论】:
-
什么是数据库引擎?
user不是保留字吗?尝试改用@Table(name="users") -
我用的是mysql。'user'是,我觉得不是mysql中的限制字。
-
发出
user.update()函数后是否出现错误?还是只是没有持久化到数据库中? -
后者。未发生更新时出错。但它没有持久化在数据库中。
标签: java ebean playframework-2.3