Недавно я начал использовать Play Framework 2.3.8.Метод обновления ebean не работает в playframework
Однако обновление модели есть у меня проблемы без работы.
Кстати, сохранить метод работает.
Обновление не работает с кодом, как показано ниже. (Это не будет сохраняться в базе данных.)
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 ")' вместо – biesior
Я использую mysql.'user ', я думаю, что это не ограниченное слово. В mysql. –
Вы получаете сообщение об ошибке после выдачи функции 'user.update()'? Или это просто не сохраняется в базе данных? – jcreason