- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
见下文。
type User struct {
Id int64 `db:"id" json:"id"`
Name string `db:"name" json:"name"`
DateCreate int64 `db:"date_create"`
DateUpdate int64 `db:"date_update"`
}
func (u *User) PreInsert(s gorp.SqlExecutor) error {
u.DateCreate = time.Now().UnixNano()
u.DateUpdate = u.DateCreate
return nil
}
func (u *User) PreUpdate(s gorp.SqlExecutor) error {
u.DateUpdate = time.Now().UnixNano()
return nil
}
我执行了 INSERT。
user := model.User{
Name: "John",
}
err := dbMap.Insert(&user)
插入的结果。没问题
1,John,1444918337049394761,1444918337049394761
继续,我执行了UPDATE。
user := model.User{
Id: 1,
Name: "John",
}
_, err := dbMap.Update(&user)
更新结果
1,John,0,1444918337049394900
DateCreate 列已更新。
当然,我的期望值是
1,John,1444918337049394761,1444918337049394900
最佳答案
那是因为在初始化您的 user
结构时,您没有明确设置 user.DateCreate
,这实际上将其设置为 0。
gorp 无法猜测您要更新或不更新哪些字段,因此它会更新所有字段。
做自己想做的事,必须取舍
select
查询。struct
类型。这看起来很乱,我不建议这样做。关于gorp PreUpdate 方法更新非自愿列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33152031/
我有两个具有一对多关系的实体。父可以有多个子实体实例。我向父级添加了一个字段,用于存储子级修改的日期 (childrenLastModifiedDate)。为了保持这一点,我添加了方法: @PrePe
我们有以下 PreUpdate 事件监听器: public bool OnPreUpdate(PreUpdateEvent @event) { BaseBO e
我有一个具有最后修改属性的实体: @Temporal(TemporalType.TIMESTAMP) private Date lastModified; @PreUpdate @PrePersist
我已将以下类定义为默认实体监听器,因此每次调用 persist() 或 merge() 方法时,都会自动执行此代码: public class StringProcessorListener {
我有两个具有一对多关系的实体。Parent 可以有多个 Child 实体实例。我向父项添加了一个字段,用于存储子项修改的日期 (childrenLastModifiedDate)。为了保持这一点,我添
我有以下类(class): @MappedSuperclass public abstract class MappedModel { @Id @GeneratedValue(
见下文。 type User struct { Id int64 `db:"id" json:"id"` Name string `db:"name" json:"
我是 Symfony2 的新手,我想知道 prePersist 和 preUpdate 事件有什么区别。看起来 prePersist 在我“保留”记录之前被“触发”,但是 preUpdate 什么时候
我有一个使用 lombok 的 Spring 项目和一个这样定义的 JPA 带注释的类: @EqualsAndHashCode @AllArgsConstructor @NoArgsConstruct
我有一个实体的 preUpdate 监听器,我可以在其中进行一些计算、设置值等。 在该监听器中,我想删除一些其他相关实体,但这似乎不会被实体管理器刷新。我怎样才能实现这一目标? 最佳答案 根据教义2
这个问题已经有答案了: JPA EventListener method not called on change to many-to-many collection? (2 个回答) 已关闭 4
每当我尝试在实体上使用 @PreUpdate 注释时,都会收到 stackoverflow 异常,该实体使用嵌入式可审计实体和 @EntityListeners。 在我的实体中,我尝试通过服务获取用户
有人可以向我解释以下行为的原因吗? EntityA 首先被创建,然后使用 em.persist(..) 方法持久化。 @PrePersist 回调在事务结束前执行。它工作正常。 在新事务中 Entit
这个问题在这里已经有了答案: JPA EventListener method not called on change to many-to-many collection? (2 个答案) 关闭
文档说: Changes to fields of the passed entities are not recognized by the flush operation anymore, use
假设以下代码片段使用 @PrePersist 和 @PreUpdate 注释和 Joined-type 继承: @Entity @Inheritance(strategy=InheritanceTyp
当用户加入组时,我正在尝试执行某些操作。我正在尝试使用 preUpdate 事件,然后检查相应的关系是否已更改。不幸的是,在我的组中,“用户”关系从来不在变更集中,在我的用户中,用户组也从来不在变更集
我的 parent 和 child 之间有一对多的关系。下面是关系的代码片段。 @Entity @Table(name = "Parent") public class Parent{ @On
我在使用 @PreUpdate 和 @PrePersist 填写审核字段时遇到问题。例如,当我想更新客户端实体时,字段updatedBy和updatedAt仍然是null;尽管当我调试时,执行了用@P
我一直在研究实体、oneToMany 关系,问题是每当我使用它时: //Parent class @OneToMany(cascade = {CascadeType.PERSIST, Casca
我是一名优秀的程序员,十分优秀!