- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
首先,我昨天尝试问过类似的问题 ( NHibernate many-to-many relationship question: can select, can't update ),但经过一个晚上的调试后,希望我能以更好(对吗?)的方式重新表述问题。如果我做错了什么 - 请告诉 - 我会删除帖子。
下面是描述,然后是一个真正的问题:
给定 USER
、ROLE
和 USER_ROLE
表,其中保留用户、角色和多对多单向关系。目前,用户 有一组角色,仅此而已:
用户:
<class name="User" lazy="false" table="Users">
<id name="Id" type="int">
<generator class="native"/>
</id>
<version name="m_lastChanged" access="field" column="LastChanged" generated="never" type="int"/>
<property name="Name" />
<bag name="RoleList" table="User_Role" lazy="false" collection-type="Roles">
<key column="UserId" foreign-key="Id"/>
<many-to-many class="Role" column="RoleId"/>
</bag>
</class>
角色(目前角色非常少):
<class name="Role" lazy="false" table="Roles">
<id name="Id" type="int">
<generator class="native"/>
</id>
<version name="m_lastChanged" access="field" column="LastChanged" generated="never" type="int"/>
<property name="Name" />
<property name="Description" />
</class>
角色表:
CREATE TABLE [Roles] (
[Id] INTEGER NOT NULL PRIMARY KEY,
[Name] text NOT NULL,
[LastChanged] INT NOT NULL DEFAULT(0)
);
CREATE UNIQUE INDEX uidxUserName ON Roles (Name COLLATE NOCASE);
用户表:
CREATE TABLE [Users] (
[Id] INTEGER NOT NULL PRIMARY KEY,
[Name] text NOT NULL,
[LastChanged] INT NOT NULL DEFAULT(0)
);
CREATE UNIQUE INDEX uidxRoleName ON Users (Name COLLATE NOCASE);
USER_ROLE 表:
CREATE TABLE [User_Role] (
[UserId] INTEGER NOT NULL,
[RoleId] INTEGER NOT NULL,
[LastChanged] INT NOT NULL DEFAULT(0),
PRIMARY KEY (UserId, RoleId),
FOREIGN KEY (UserId) REFERENCES Users(Id),
FOREIGN KEY (RoleId) REFERENCES Roles(Id)
);
当 User 被获取时(我正在跟踪 SQL 查询)——它的关系和角色也被获取:
SELECT
rolelist0_.UserId as UserId1_,
rolelist0_.RoleId as RoleId1_,
role1_.Id as Id2_0_,
role1_.LastChanged as LastChan2_2_0_,
role1_.Name as Name2_0_,
role1_.Description as Descript4_2_0_
FROM
User_Role rolelist0_
left outer join
Roles role1_
on rolelist0_.RoleId=role1_.Id
WHERE
rolelist0_.UserId=@p0;
@p0 = 2
SELECT
user0_.Id as Id3_0_,
user0_.LastChanged as LastChan2_3_0_,
user0_.Name as Name3_0_,
user0_.Password as Password3_0_,
user0_.FullName as FullName3_0_,
user0_.EMail as EMail3_0_,
user0_.PhoneNumber as PhoneNum7_3_0_,
user0_.Description as Descript8_3_0_
FROM
Users user0_
WHERE
user0_.Id=@p0;
@p0 = 2
问题来了:当我尝试保存 User 时,NHibernate 在调试器的深处检查 LastUpdated 值 < em>Role 对象并抛出 NHibernate.TransientObjectException(对象引用未保存的 transient 实例 - 在刷新前保存 transient 实例),告诉我需要先保存角色。虽然该角色仍未修改。
我尝试在用户上应用“save-update”和“all”以及其他类型的级联(没有变化在获取时),但在保存 User 时,它首先尝试保存 Role 并且我得到一个异常,即违反了角色唯一性约束。
那么,如果合适的话,你能指出我在这里遗漏了什么吗?
更新:不小心按以下方式修改了Role
映射(添加了unsaved-value="undefined"
):
<version name="m_lastChanged" access="field" column="LastChanged" unsaved-value="undefined" generated="never" type="int"/>
查询似乎没问题。 这是正确/最佳的解决方案吗?
最佳答案
因此,长话短说(感谢 Ayende)版本字段 LastUpdated
应该初始化为 1
,而不是 0
。然后,这一切都交织成一首可爱的交响乐。
令人难以置信的是,一个位可以承载多少差异:)
关于c# - 级联还是不级联? ("object references an unsaved transient instance"错误),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3266014/
我遵循了一本名为“Sitepoint Full Stack Javascript with MEAN”的书中的教程,我刚刚完成了第 6 章,应该已经创建了一个带有“数据库”的“服务器”。数据库只不过是
在 Jquery 中,我创建两个数组,一个嵌入另一个数组,就像这样...... arrayOne = [{name:'a',value:1}, {name:'b',value:2}] var arra
这个问题在这里已经有了答案: What is the explanation for these bizarre JavaScript behaviours mentioned in the 'Wa
我被放在别人的代码上,有一个类用作其他组件的基础。当我尝试 ng serve --aot(或 build --prod)时,我得到以下信息。 @Component({ ...,
我正在测试一些代码,并使用数据创建了一个 json 文件。 问题是我在警报中收到“[object Object],[object Object]”。没有数据。 我做错了什么? 这是代码:
我想打印 [object Object],[object Object] 以明智地 "[[{ 'x': '1', 'y': '0' }, { 'x': '2', 'y': '1' }]]"; 在 ja
我有一个功能 View ,我正在尝试以特殊格式的方式输出。但我无法让列表功能正常工作。 我得到的唯一返回是[object Object][object Object] [object Object]
在使用优秀的 Sim.js 和 Three.js 库处理 WebGL 项目时,我偶然发现了下一个问题: 一路走来,它使用了 THREE.Ray 的下一个构造函数: var ray = new THRE
我正在使用 Material UI 进行多重选择。这是我的代码。 {listStates.map(col => (
我的代码使用ajax: $("#keyword").keyup(function() { var keyword = $("#keyword").val(); if (keyword.
我遇到了下一个错误,无法理解如何解决它。 Can't resolve all parameters for AuthenticationService: ([object Object], ?, [o
我正在尝试创建一个显示动态复选框的表单,至少应选中其中一个才能继续。我还需要获取一组选中的复选框。 这是组件的代码: import { Component, OnInit } from '@angul
我正在开发 NodeJs 应用程序,它是博客应用程序。我使用了快速验证器,我尝试在 UI 端使用快速闪存消息将帖子保存在数据库中之前使用闪存消息验证数据,我成功地将数据保存在数据库中,但在提交表单后消
我知道有些人问了同样的问题并得到了解答。我已经查看了所有这些,但仍然无法解决我的问题。我有一个 jquery snipet,它将值发送到处理程序,处理程序处理来自 JS 的值并将数据作为 JSON 数
我继承了一个非常草率的项目,我的任务是解释为什么它不好。我注意到他们在整个代码中都进行了这样的比较 (IQueryable).FirstOrDefault(x => x.Facility == fac
我只是在删除数组中的对象时偶然发现了这一点。 代码如下: friends = []; friends.push( { a: 'Nexus', b: 'Muffi
这两个代码片段有什么区别: object = nil; [object release] 对比 [object release]; object = nil; 哪个是最佳实践? 最佳答案 object
我应该为其他人将从中继承的第一个父对象传递哪个参数,哪个参数更有效 Object.create(Object.prototype) Object.create(Object) Object.creat
我在不同的对象上安排不同的选择器 [self performSelector:@selector(doSmth) withObject:objectA afterDelay:1]; [self per
NSLog(@"%p", &object); 和 NSLog(@"%p", object); 有什么区别? 两者似乎都打印出一个内存地址,但我不确定哪个是对象的实际内存地址。 最佳答案 这就是我喜欢的
我是一名优秀的程序员,十分优秀!