数据库学习笔记_5_ER模型详解_weak entity set

weak entity set,要了解这个的概念我们就得回到之前的redundant,假设我们在esA和esB里都有同样的一个字段,而这个字段作为链接两个ES的线索本身不得不重复,同时我们已经有了一个链接ESA和ESB的RS,这样两个字段里的同一个字段没有必要,我们当然可以把RS给删掉,但是删掉以后就变得不好了(我也不知道为什么会不好,事实上我们在mysql的联系中似乎都是这么做的)。

  还有一个替换手段是将ESB中的相同字段给删掉然后让ESB变成一个weak entity set 同时让ESA成为一个strong entity set。

  对于每个WES来说,其必须与一个SES相连,此时对于WES来说,它是existence dependent on the SES,and the SES owns the WES, the relationship between two set is called identifying relationship,且对于每个WES来说,其owner有且只有一个.

  wes对于ses来说是many2one, 同时其关系不存在describe attibute,因为任何的DA都可以被加入到WES的属性中去。

  对于WES来说,虽然其本身因为主键组件缺失的原因已经不再是绝对不存在重复项了,但是对于存在于SES中的每一个实体所链接的WES中的实体来说,标志独一性的属性集还是有必要的,所以就有了discriminator这个类似于primary key的东西。

  一个WES除了和SES链接以外还有其他的用处,比如说to be the owner of other WES or participate to other SES等等。

转载于:https://www.cnblogs.com/stultus/p/6735031.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 C++ 中,shared_ptr 常常被用来管理动态分配的资源。然而,当多个 shared_ptr 相互引用时,就会出现循环引用的问题,导致内存泄漏。为了解决这个问题,C++11 引入了 weak_ptr。 weak_ptr 是 shared_ptr 的一种扩展,它可以指向一个由 shared_ptr 管理的对象,但并不拥有该对象的所有权。weak_ptr 可以被用来解决 shared_ptr 循环引用的问题。 当一个对象被多个 shared_ptr 共享时,每一个 shared_ptr 都会增加该对象的引用计数。如果其中一个 shared_ptr 被销毁时,该对象的引用计数会减少。但如果多个 shared_ptr 相互引用,就会导致循环引用的问题。例如: ```c++ class B; class A { public: std::shared_ptr<B> b_ptr; }; class B { public: std::shared_ptr<A> a_ptr; }; int main() { std::shared_ptr<A> a(new A); std::shared_ptr<B> b(new B); a->b_ptr = b; b->a_ptr = a; return 0; } ``` 在上面的代码中,A 和 B 互相引用,它们的引用计数永远不会为 0,导致内存泄漏。为了解决这个问题,我们可以将其中一个 shared_ptr 改为 weak_ptr。例如: ```c++ class B; class A { public: std::weak_ptr<B> b_ptr; }; class B { public: std::shared_ptr<A> a_ptr; }; int main() { std::shared_ptr<A> a(new A); std::shared_ptr<B> b(new B); a->b_ptr = b; b->a_ptr = a; return 0; } ``` 在这个例子中,A 持有一个指向 B 的 weak_ptr,而 B 持有一个指向 A 的 shared_ptr。这样,当 A 或 B 中的任意一个 shared_ptr 被销毁时,它们所指向的对象的引用计数都会减少,从而解决了循环引用的问题。 需要注意的是,当通过 weak_ptr 访问对象时,需要先将 weak_ptr 转换为 shared_ptr,否则无法访问对象。假设上面的例子中,我们需要访问 B 对象,可以这样做: ```c++ std::shared_ptr<B> b_ptr = a->b_ptr.lock(); if (b_ptr) { // 访问 B 对象的成员 } ``` 在上面的代码中,我们使用 lock() 方法将 weak_ptr 转换为 shared_ptr,如果转换成功,就可以访问 B 对象的成员了。 总之,weak_ptr 是 shared_ptr 的一种扩展,可以用来解决 shared_ptr 循环引用的问题。通过将其中一个 shared_ptr 改为 weak_ptr,可以防止循环引用导致的内存泄漏。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值