- Siêu lớp và danh mục iOS/Objective-C
- object-c - -1001 lỗi khi NSURLSession vượt qua httpproxy và /etc/hosts
- java - Nhận địa chỉ url bằng lớp mạng
- ios - Âm thanh không phát trong thông báo đẩy
Tôi có hai thực thể ngủ đông Coupon và CouponHistory, với mối quan hệ một chiều giữa CouponHistory và Coupon.
@Entity
@Table(name = "validity_coupon")
phiếu giảm giá hạng công khai {
@Id
@Column(độ dài = 50, duy nhất = true, nullable = false)
mã chuỗi riêng tư;
giá trị int riêng tư;
boolean riêng được sử dụng;
...}
@Entity
@Table(name = "coupon_history")
@TableGenerator(name = "seqGen", table = "shunya_id_gen", pkColumnName = "GEN_KEY", valueColumnName = "GEN_VALUE",
pkColumnValue = "coupon_history_seq", phân bổSize = 1)
lớp công khai CouponHistory {
@Id
@GeneratedValue(strategy = GenerationType.TABLE, trình tạo = "seqGen")
id dài riêng tư;
@Temporal(TemporalType.TIMESTAMP)
riêng tư Ngày tạoNgày;
@ManyToOne(tìm nạp = FetchType.LAZY)
phiếu giảm giá riêng;
...}
Có một phương thức dịch vụ giao dịch cố gắng lưu hai thực thể trong một giao dịch. Spring được sử dụng ở đây để xử lý các giao dịch.
@Giao dịch
khoảng trống công khai createCoupon() {
Phiếu giảm giá phiếu giảm giá = Phiếu giảm giá mới();
coupon.setCode(RandomStringUtils.randomAlphanumeric(5));
phiếu giảm giá.setValids(1);
couponRepository.save(phiếu giảm giá);
CouponHistory couponHistory = new CouponHistory();
couponHistory.setCreatedOn(new Date());
couponHistory.setCoupon(phiếu giảm giá);
phiếuHistoryRepository.save(couponHistory);
}
Khi tôi gọi phương thức này, tôi nhận được ngoại lệ sau -
org.hibernate.TransientPropertyValueException: đối tượng tham chiếu một phiên bản tạm thời chưa được lưu - lưu phiên bản tạm thời trước khi xóa truy vấn: com.poc.CouponHistory.validityCoupon -> com.poc.Coupon ngoại lệ lồng nhau là java.lang.IllegalStateException: org.hibernate.TransientPropertyValueException: đối tượng tham chiếu một phiên bản tạm thời chưa được lưu - lưu phiên bản tạm thời beforeQuery xả nước: com.poc.CouponHistory.validityCoupon -> com.poc.Coupon
Tôi không hiểu tại sao chế độ ngủ đông lại nhắc tôi khi tôi lưu thực thể con trước rồi đến thực thể mẹ trong một giao dịch.
Nếu tôi thay đổi việc tạo ID của thực thể phiếu giảm giá thành tự động thì mọi thứ sẽ bắt đầu hoạt động tốt. Nhưng tôi muốn gán mã phiếu giảm giá theo cách thủ công nên tính năng tự động tạo Id không nằm trong phạm vi.
如有任何帮助,我们将不胜感激!
câu trả lời hay nhất
Vì bạn không xếp tầng các phiếu giảm giá nên bạn cần quản lý CouponHistory trước khi lưu nó, may mắn là save() sẽ trả về một thực thể bền vững được quản lý khi bạn lưu thực thể đó để bạn có thể chỉ định nó cho phiếu giảm giá
@Giao dịch
khoảng trống công khai createCoupon() {
Phiếu giảm giá phiếu giảm giá = Phiếu giảm giá mới();
coupon.setCode(RandomStringUtils.randomAlphanumeric(5));
phiếu giảm giá.setValids(1);
phiếu giảm giá = couponRepository.save(coupon);//save sẽ trả về thực thể được quản lý
CouponHistory couponHistory = new CouponHistory();
couponHistory.setCreatedOn(new Date());
couponHistory.setCoupon(phiếu giảm giá);
phiếuHistoryRepository.save(couponHistory);
}
Về java - ngoại lệ giá trị thuộc tính tạm thời: đối tượng tham chiếu một phiên bản tạm thời chưa được lưu - lưu phiên bản tạm thời trước khi xóa truy vấn, chúng tôi đã tìm thấy một câu hỏi tương tự trên Stack Overflow: https://stackoverflow.com/questions/45778937/
我想在 java 中声明一个对象,就像在 C++ 中指向指针的指针,让我给你看一个例子: //*** At the application startup //Initialize a setting
考虑这段代码, struct A {}; struct B { B(const A&) {} }; void f(B) { cout << "f()"<
我正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试过的
我目前正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试
这个问题在这里已经有了答案: Add managed DLL dependencied to unmanaged C++ project (1 个回答) 关闭 6 年前。 我有这样一个场景: 使用
这是一个常见问答的集合,这也是一个社区维基,所以每个人都被邀请参与维护它。。正则表达式正在遭受给我ZE代码类型的问题和没有解释的糟糕答案。此参考旨在提供指向质量问答的链接。。此参考适用于以下语言:PH
我正在尝试在方案中模拟堆栈。我正在使用 DrScheme 并选择语言 R5RS。我需要创建 pop、push 和 peek 的函数。但我无法弄清楚如何通过引用传递。我已经阅读了一些关于盒子的信息,但是
我陷入了这个错误。我将代码部署在生产服务器上,它在端口 80 上运行。当我尝试登录管理页面时。如图所示,它给了我 403 错误。 可能是什么原因?我的 Django 代码或 nginx 配置有问题吗?
这是一段简单的 C++ 代码: A foo(){ A a; // create a local A object return a; } void bar(const A & a_r){ }
我正在使用从 torrenteditor 获取的 php 脚本来创建 torrent 文件,但是当我使用指定的方法创建新的 torrent 文件时,torrent 文件被创建但我收到很多通知。,就像这
MySQL: REFERENCES vs FOREIGN KEY + REFERENCES 我认为 REFERENCES 是更冗长的 FOREIGN KEY REFERENCES 语法的某种速记语法。
我想使用基于另一个方法引用的方法引用。这有点难以解释,所以我给你举个例子: Person.java public class Person{ Person sibling; int a
Java/C# 语言律师喜欢说他们的语言通过值传递引用。这意味着“引用”是在调用函数时复制的对象指针。 同时,在 C++ 中(以及在 Perl 和 PHP 中更动态的形式),引用是某个其他名称(或动态
当我需要实现递归 lambda 时,通常我这样做: auto factorial = [](auto& self, int n) -> int { return n == 0 ? 1 : n
我目前正在研究 DDD ,需要一些启发。 我有两个实体 Temple TempleVariant Temple(听筒)包含基本信息(名称,描述等),并具有n个变体,它们具有技术描述(CAD绘图,尺寸,
在 Grails 中 belongsTo允许一个域类与另一个域类建立级联关系。使用belongsTo时有两种类型的关系:引用和无引用。 Reference 在拥有的对象上创建属性,而 No Refer
我正在使用 AWS 和 Django Rest Framework 开发 Web 应用程序。(Django:v1.8,DRF:v3) 我一直在为 POST 多部分表单请求获取 django.reque
我按照下面的定义公开了 WCF 端点, 当我在 .NET 3.5 中添加“服务引用”时,我们在代理中获得了以下类,这非常好: [Syst
我在玩 constexpr 引用时产生了这种感觉。但问题本身与 constexpr 无关,只是被它揭示。 我们知道有“指向const的指针”,也有“const指针”。顺便说一句,由于后者的使用比前者少
我有 2 种类型的 refences,它们中的每一种都可以正常工作。 我尝试使用每一个并在 project build 中得到相同的结果。 请向我解释 COM 引用和引用之间的区别。 谢谢你。 最佳答
Tôi là một lập trình viên xuất sắc, rất giỏi!