惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
H
Hacker News: Front Page
P
Palo Alto Networks Blog
T
ThreatConnect
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
T
True Tiger Recordings
P
Privacy & Cybersecurity Law Blog
B
Blog
IT之家
IT之家
Last Week in AI
Last Week in AI
F
Full Disclosure
Hacker News: Ask HN
Hacker News: Ask HN
C
Comments on: Blog
Microsoft Azure Blog
Microsoft Azure Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Security Blog
Microsoft Security Blog
博客园 - 【当耐特】
N
News and Events Feed by Topic
NISL@THU
NISL@THU
腾讯CDC
雷峰网
雷峰网
Security Latest
Security Latest
李成银的技术随笔
M
Microsoft Research Blog - Microsoft Research
L
LangChain Blog
L
Lohrmann on Cybersecurity
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
C
Check Point Blog
Y
Y Combinator Blog
Recent Announcements
Recent Announcements
博客园 - Franky
N
News | PayPal Newsroom
V
V2EX
A
About on SuperTechFans
The Register - Security
The Register - Security
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google Online Security Blog
Google Online Security Blog
MyScale Blog
MyScale Blog
Cisco Talos Blog
Cisco Talos Blog
Vercel News
Vercel News
WordPress大学
WordPress大学
C
Cyber Attacks, Cyber Crime and Cyber Security
The Hacker News
The Hacker News
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
爱范儿
爱范儿
A
Arctic Wolf
L
LINUX DO - 最新话题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More

博客园 - Vincent

reCaptcha 在UpdatePanel 和 ModalPopup中的使用 - Vincent Invalid character in a Base-64 string System.ArgumentOutOfRangeException at System.Web.HttpCachePolicy.UtcSetLastModified (DateTime utcDate) Fabulous Adventures In Coding Microsoft will end OEM and shrink-wrapped sales of Windows XP on June 30, 2008 - Vincent My AutoCompleteExtender Windows Live Writer GRI-MindHarbor软件公司 写给yzx110的一个实例,仅作参考! 很久没有写blog了. Base64 MD5加密 信用卡是超前消费的一种手段 vs.net2003无法打开*.xsd文件的解决方法 针对MS Project 2003 的开发 Test Your Knowledge of Microsoft Visual Studio .NET - Vincent page event Microsoft Office InfoPath 2003 Toolkit for Visual Studio .NET 在Code-Behind中操作WebUserControl - Vincent
单表继承 (Single Table Inheritance)
Vincent · 2005-12-25 · via 博客园 - Vincent

概念   将类的继承层次表示为一个单表,表中的各列代表不同类中的所有域.
     说白了就是把含有继承关系的类的内容都保存到一个表中.当然为了区分类的层次,不至于找儿子却找到爹的尴尬局面,要增加一个字段来保存这个层次.
运行机制 
     在这个继承映射方案中,我们使用一个表包含某个继承层次中所有类的所有数据.每个类负责把与之相关的数据保存在表的一行中.数据库中其他不相关的列留空.
     在往内存中加载一个对象的时候,必须知道实例化哪个类来创建这个对象.为此,数据表中有一个域用来指示应该使用哪个类.它可能是类的名字也可能是一个代码域.
     加载数据的时候首先读代码,看看需要实例化哪个类.保存数据的时候代码需要由层次关系中的超类写出.
优点
    1.在数据库中只需要关注一个表.
    2.获取数据时不必进行连接操作.
    3.任何对继承层次的重构都不需要修改数据库.
缺点
    1.对那些使用数据库表的用户见到列的值时有时无会感到困惑.毕竟DBA可是不看我们写的Code的.而且现在企业强调的是系统的整合,Data往往不是只为你的Application存在的.
    2.只被某些子类使用的列会带来数据空间的浪费.当然这也要分什么样的数据库产品了,Oracle对这方面处理的就比较好.
    3.因为都存在一个表中,所以数据量会变的很大,有许多索引并被频繁上锁,从而导致访问该表时效率低下.