- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
对于具有外键约束的 CF ORM 组件,正确的语法/解决方法/黑客是什么?
<小时/>将变量存储为整数应该是一个简单的编程问题,对吗?在该语言的文档中找到相应的函数(如果您无法从圆顶中记忆起它),其中会显示 returns: int (owtte) 并使用它。
ColdFusion 不支持。
你们中的一些人可能已经知道 ColdFusion 的 various issues with integers但目前导致我快速脱发的是 ColdFusion 有时会将你的“整数”存储为字符串、 double 字符串或长字符串。现在,对于大多数用例来说,这不是一个破坏功能的问题,并且经常被忽视/忽略/未被发现。就我而言,异常(exception)是 ORM 发挥作用时。当然,正如任何明智的开发人员所做的那样,我认识到这可能是由于某个地方的用户错误造成的。
<小时/>每当 CF 尝试与 DB 交互时,就会出现此问题。如果有一个字段是外键并且类型为“整数”,则 CF 会抛出 Hibernate 异常并显示以下消息:
java.lang.Integer
就是这样。有帮助,对吧?我发现这个“错误消息”明确是您传递到该字段的变量类型,因此如果您错误地将 double 值传递到该字段,错误消息将显示为 java.lang.Double
.
现在,这似乎与字段本身无关,而更多地与相关组件有关 - 这只发生在具有外键约束将其链接到其他地方的整数字段的字段上。
我想要做的事情的基本示例:
模板.cfc
component persistent="true" table="template"{
property name="id" type="numeric" sqltype="integer" column="templateID" fieldtype="id" generator="identity";
property name="userID" type="numeric" sqltype="integer" fkcolumn="userID" fieldtype="many-to-one" cfc="User";
property name="lastModified" type="date" sqltype="timestamp" column="lastModified";
}
User.cfc
component persistent="true" table="user"{
property name="id" type="numeric" sqltype="integer" column="userID" fieldtype="id" generator="identity";
property name="username" type="string" sqltype="nvarchar" column="username";
property name="password" type="string" sqltype="nvarchar" column="password";
}
刷新已更新 template.userID
的 ORM 时会出现问题。
ormtype
属性添加到身份字段(如果不起作用,则添加外键字段)sqltype
属性(我现在相信 is only for table creation 我们永远不需要它,因为数据库已经就位)NumberFormat( var )
- 文档说它返回“格式化的数字值”,实际上返回一个 java.lang.String
LSParseNumber( var )
- 返回 double 值Int( var )
- 这个很棒:文档说它返回一个整数,作为字符串。实际上返回一个java.lang.Double
Val( var )
- 返回 double 值javaCast( 'int', var )
- 返回一个整数,这会引发相同的错误elementtype
属性(两端)validate
属性放宽为“数字”我怀疑这可能与 Hibernate 和 CF 的组合有关,而不仅仅是 CF,尽管它有令人想起 javascript 的怪癖,但我仍然喜欢它。
<小时/>最佳答案
传递实体,而不是 ID。CF ORM 中引用持久实体 Foo 的外键属性的类型为 Foo 而不是 int。
过了这么久,Adobe 让我绕过了几个人,直到我找到了一位知道自己在说什么的工程师。事实证明,问题并不在于 ORM 引擎(Hibernate)无法将整数识别为整数,而是如果您有一个引用另一个持久实体的外键,那么您必须传递该实体而不是 ID。
首先,我从问题中删除了 type
和 sqltype
值,因为前者可以通过 CF 检查数据库来检索(在我的例子中这是很好的) ,但您可能必须显式设置它,特别是当您在 Application.cfc 中关闭 useDBforMapping
时。
其次,我已将 Template 组件中的 userID
属性重命名为 user
,因为它可能会帮助那些不能立即理解我上面所说的内容的人传递实体'以更好地可视化它。
模板.cfc
component persistent="true" table="template"{
property name="id" column="templateID" fieldtype="id" generator="identity";
property name="user" fkcolumn="userID" fieldtype="many-to-one" cfc="User";
property name="lastModified" column="lastModified";
}
User.cfc
component persistent="true" table="user"{
property name="id" column="userID" fieldtype="id" generator="identity";
property name="username" column="username";
property name="password" column="password";
}
因此,假设您知道与此模板关联的用户的 ID(例如,他们可能是创建者)。您需要做的是,不要将 ID 传递给 user
属性,而是创建一个 User 组件,然后传递那个。
index.cfm
userID = 4; // Example user ID, which we got from somewhere earlier in the code
templateID = 20; // Example template ID, which we got from somewhere earlier in the code
// Create template entity (loading by primary key)
template = EntityLoadByPK( 'Template', templateID );
// To set the user in the Template entity, we must pass a User entity
user = EntityLoadByPK( 'User', userID );
// Only then can we successfully update the template's foreign key property
template.setUser( user );
EntitySave( template );
// Line below is not usually needed, but it forces DB interaction so it's
// useful in the context of this example
ORMFlush();
希望这对遇到同样困惑的其他人有所帮助。
JC
关于java - 如何使用 ColdFusion ORM 存储整数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45800432/
请提及(大)ORM 和微 ORM 之间的区别。与大型 ORM 相比,微型 ORM 有何优势?例如。 Entity Framework ORM 和 dapper micro ORM 之间的区别。 最佳答
我有一个名为 User 的模型。我可以从 User 模型扩展另一个模型 Admin/mod 吗?我找到了续集文档,但我没有找到 最佳答案 是的,查看 Associations documentatio
你对数据访问层有什么建议?使用 Entity Framework 和 Hibernate OR 代码生成器(如 Subsonic、.netTiers、T4 等)等 ORM? 最佳答案 对我来说,这很简
我编写了一个代码生成器,它为给定的 SQL Server/CE 数据库生成 POCO 和存储库。没什么花哨的,只有使用经典 ADO.Net 的简单 CRUD 程序。我的问题是,为什么我应该使用像 L2
我扩展了Android.Application类,以便保持状态(将应用程序用作单例)。 但是,我现在想使用Sugar ORM库简化我的数据库访问,但是Sugar文档(http://satyan.git
我正在阅读 OOP 设计模式和框架设计,发现自己对术语 ORM 和持久性框架之间的区别有点不确定。 ORM 是 PF 的一种吗?您可以期待两者有哪些不同的功能? 最佳答案 我将 ORM 定义为将任何数
在 Jboss EAP 7.0 中加载 orm 文件时,我遇到了以下问题,但它在 Weblogic 中工作。 原因:org.hibernate.boot.MappingException:无法解析显式
我一直在研究 Massive ORM。不要忘记,只是看,我还没有做任何编码。 我对保存交易数据的可能性感兴趣。我已经看到可以在一个事务中在同一个表中保存 20 行。但是当我想在单个交易中保存一个订单并
好的。我刚刚开始在我的 Coldfusion 应用程序中使用 ORM。到现在为止一切都很顺利。我遇到了这个障碍。我有这两张表: 这是我用来将数据加载到页面中的代码。 if 的第二部分是默认加载,第一部
我有可以分配许多类别的帖子。所以它是一个多对多的关系。 我想计算每个类别中有多少帖子(符合特定标准),然后对结果进行排序。 我有: Select ( Select count(post.id)
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 8年前关闭。 Improve t
我正在评估如何使用后端的分布式键/值存储来实现某些东西。我希望在支持对象模型的键/值之上有一个层,该对象模型类似于我从对象关系映射器中获得的模型。 任何人都可以指出其他人这样做的任何例子吗?我主要是在
我正在使用 kohana ORM 以便从数据库中获取一些结果。我的问题是:即使我查阅了文档,我也找不到只选择我感兴趣的列的方法。更明确地说,我有: $sale_stock = Model::facto
在 ORM 之前,如果我想显示规范化表的组合输出,我只需执行快速 CFQUERY,将表连接到我想要的字段并显示输出。我只是无法使用 ORM 来解决它。 例如这两个表: customers (id,
异步 ORM 的真正含义是什么?它与常规 ORM 的行为有何不同? 它可以用在什么地方? 最佳答案 这意味着对它的调用会立即返回(不会阻塞)。您会在稍后的某个时间点获得结果,很可能是由于回调触发。
虽然代码优先非常适合部署和开发,但我看不出如何在投入生产后以代码优先的方式插入对域模型所做的更改。 我如何处理我们在生产过程中积累的数据? 我是否应该手动将数据从 A 版架构迁移到 B 版架构?我是否
像学说(事件记录)和Xyster(数据映射器),有什么区别? 最佳答案 不同之处在于域对象与数据访问层的分离程度。使用 ActiveRecord,它是一个对象,这使它变得非常简单。特别是如果您的类一对
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我在 ColdFusion 中有一个持久实体,我需要更新一个属性 property name="createdDateTime" ormtype="date"; 到 property name="cr
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我是一名优秀的程序员,十分优秀!