我想知道我应该怎么做,因为我阅读了许多试图理解这一点的文章,包括许多 SO 问题。我读过的所有内容都不能一针见血。
我想知道当使用级联规则定义数据库以及应用程序时会发生什么,因为这将定义我是否应该采用以下方法或其他方法。
create table foo(
id int unsigned not null auto_increment,
primary key(id)
);
create table bar(
id int unsigned not null auto_increment,
foo_id int unsigned not null,
primary key(id),
foreign key(foo_id) references foo(id) on delete cascade on update cascade
)
@Entity
@Table(name = "foo")
public class Foo {
private int id;
private List<Bar> bars;
@Id
@GeneratedValue
@Column(name = "id")
public int getId() {
return id;
}
@OneToMany(mappedBy = "foo", cascade = {CascadeType.ALL})
public List<Bar> getBars() {
return bars;
}
public void setId() {
this.id = id;
}
public void setBars(List<Bar> bars) {
this.bars = bars;
}
}
@Entity
@Table(name = "bar")
public class Bar {
private int id;
private Foo foo;
@Id
@GeneratedValue
@Column(name = "id")
public int getId() {
return id;
}
@ManyToOne
@JoinColumn(name = "foo_id", nullable = false)
public getFoo() {
return foo;
}
public void setId(int id) {
this.id = id;
}
public void setFoo(Foo foo) {
this.foo = foo;
}
}
如果我现在对 Foo 对象调用删除操作(通过 EntityManagerFactory 或 SessionFactory),将发生以下哪项?
hibernate 操作会删除bar表中的所有记录
其外键是Foo的foo_id的外键,然后删除
Foo 记录。
hibernate 操作会删除所有相应的 Bar 记录,这些记录已经加载到 session 缓存中(这
可能是也可能不是实际数据库中存在的所有 bar 记录)和
然后删除 Foo 记录(数据库级联规则将删除所有剩余的 bar 记录)。
hibernate 操作将尝试
首先删除 Foo 记录,如果数据库出现故障,则执行以下操作之一
上述步骤。
发生了一些我没有考虑过的事情,如果是的话是什么?
考虑到以下两难假设,最佳方法是什么?
如果 1 为真那么它会建议:
A) 仅在数据库中定义级联规则。确保从应用程序中的对象中删除 bars,这样它们就不会与数据库分离(因为数据库将删除它们的记录),然后调用 delete foo .
或
B) 仅在应用程序中定义级联规则,因为它将彻底管理数据库完整性。
不
C) 在两者中定义级联规则,因为每个都达到了预期的结果,使另一个浪费了处理。
如果 2 为真那么它会建议:
在数据库和应用程序中定义级联规则,以便 Hibernate 可以负责管理其实体,并且数据库可以在之后进行清理,因为应用程序不能保证删除所有 bar 记录。
如果 3 为真那么它会建议:
在数据库和应用程序中定义级联规则,因为 Hibernate 似乎支持已经在数据库级别定义的级联规则。
如果 4 为真,那么它会建议:
这个问题更加重要,因为我错过了一些基本的东西!
编辑:添加我读过的文章...
数据库、应用程序或两者的冲突 View :
SO - should-i-let-jpa-or-the-database-cascade-deletions
数据库或应用程序的冲突 View :
SO - cascading-deletes-updates-using-jpa-or-inside-of-database
这篇文章阐明了 JPA 提供者实际做了什么(尽管应该注意他们使用 OpenJPA 提供者来证明他们的操作):
它指出:
The cascading of remove and persist operations applies also on those entities that have not been loaded yet. It even passes through them to other entities, potentially traversing through whole object graph.
接着说:
The cascading of refresh, merge and detach passes only through entities that are already loaded.
这意味着提议的过程 2 不正确。
最佳答案
如果您在数据库中声明级联并 hibernate ,如果数据库支持它,它将始终首先删除,并且 hibernate 调用不会真正删除任何内容,但无论如何都会运行。但是,由于您使用的是 hibernate,因此它的主要优点是可以轻松过渡到可能不支持数据库端级联功能的新数据库。因此,即使您的数据库支持级联并且下划线的 hibernate jdbc 语句当前没有做任何事情(它们将来可能会做某事),您也希望将它们留在那里
关于java - JPA Hibernate - 数据库和注释中的级联删除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22286649/
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为
查看Ruby的CSV库的文档,我非常确定这是可能且简单的。我只需要使用Ruby删除CSV文件的前三列,但我没有成功运行它。 最佳答案 csv_table=CSV.read(file_path_in,:headers=>true)csv_table.delete("header_name")csv_table.to_csv#=>ThenewCSVinstringformat检查CSV::Table文档:http://ruby-doc.org/stdlib-1.9.2/libdoc/csv/rdoc/CSV/Table.html
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer
刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr