这是我们的PostgreSQL源码阅读后的修改及报告。 这数据库实习(杨冬青老师的课)我和我们组的另一个人一起完成的,最终获得满分,并选为代表给下一届同学报告。 摘 要: PostgreSQL是一个优秀的开放源码数据库管理软件,阅读分析其实现代码,并在其基础上修改或扩展其功能,对于学习《数据库系统实现》课程和提高自己实践能力都有很大的帮助。 本文着力于分析PostgreSQL的查询处理的部分的流程与实现,为在PostgreSQL基础上实现查询优化的扩展功能。 关键词::PostgreSQL;查询处理;查询优化; 数据库系统实现;代码修改;课程实习 如果遇到任何问题,或者想转载,可以到我的主页留言:http://blog.sina.com.cn/gusui ,或者直接给我来邮件:ouyangj0@gmail.com 谢谢:)
2021-11-28 10:02:52 1.67MB PostgreSQL 查询优化 代码修改 报告
1
第1章 重构,第一个案例 1.1 起点 1.2 重构的第一步 1.3 分解并重组Statemen 1.4 运用多态取代与价格相关的条件逻辑 1.5 结语 第2章 重构原则 2.1 何谓重构 2.2 为何重构 2.3 何时重构 2.4 怎么对经理说 2.5 重构的难题 2.6 重构与设计 2.7 重构与性能 2.8 重构起源何处 第3章 代码的坏味道 3.1 Duplicated Code(重复的代码) 3.2 Long Method(过长函数) 3.3 Large Class(过大类) 3.4 Long Parameter List(过长参数列) 3.5 Divergent Change(发散式变化) 3.6 Shortgun Surgery(霰弹式修改) 3.7 Feature Envy(依恋情结) 3.8 Data Clumps(数据泥团) 3.9 Primitive Obsession(基本型别偏执) 3.10 Switch Statements(switch惊悚现身) 3.11 Parallel Inheritance Hierarchies(平行继承体系) 3.12 Lazy Class(冗赘类) 3.13 Speculative Generality(夸夸其谈未来性) 3.14 Temporary Field(令人迷惑的暂时值域) 3.15 Message Chai (过度耦合的消息链) 3.16 Middle Man(中间转手人) 3.17 Inappropriate Intimacy(狎昵关系) 3.18 Alternative Classes with Different Interfaces(异曲同工的类) 3.19 Incomplete Library Class(不完善的程序库类) 3.20 Data Class(纯稚的数据类) 3.21 Refused Bequest(被拒绝的遗赠) 3.22 Comments(过多的注释) 第4章 建立测试体系 4.1 自我测试码的价值 4.2 JUnit测试框架 4.3 添加更多测试 第5章 重构名录 5.1 重构的记录格式 5.2 寻找引用点 5.3 这些重构准则有多成熟 第6章 重新组织你的函数 6.1 Extract Method(提炼函数) 6.2 Inline Method(将函数内联化) 6.3 Inline Temp(将临时变量内联化) 6.4 Replace Temp With Query(以查询取代临时变量) 6.5 Introduce Explaining Variable(引入解释性变量) 6.6 Split Temporary Variable(剖解临时变量) 6.7 Remove Assignments to Paramete (移除对参数的赋值动作) 6.8 Replace Method with Method Object(以函数对象取代函数) 6.9 Substitute Algorithm(替换你的算法) 第7章 在对象之间移动特性 7.1 Move Method(搬移函数) 7.2 Move Field(搬移值域) 7.3 Extract Class(提炼类) 7.4 Inline Class(将类内联化) 7.5 Hide Delegate(隐藏「委托关系」) 7.6 Remove Middle Man(移除中间人) 7.7 Introduce Foreign Method(引入外加函数) 7.8 Introduce Local Exte ion(引入本地扩展) 第8章 重新组织你的数据 8.1 Self Encapsulate Field(自封装值域) 8.2 Replace Data Value with Object(以对象取代数据值) 8.3 Change Value to Reference(将实值对象改为引用对象) 8.4 Change Reference to Value(将引用对象改为实值对象) 8.5 Replace Array with Object(以对象取代数组) 8.6 Duplicate Observed Data(复制「被监视数据」) 8.7 Change Unidirectional Association to Bidirectional(将单向关联改为双向) 8.8 Change Bidirectional Association to Unidirectional(将双向关联改为单向) 8.9 Replace Magic Number with Symbolic Co tant (以符号常量/字面常量 取代魔法数) 8.10 Encapsulate Field(封装值域) 8.11 Enc
2021-11-25 22:10:35 31.26MB 重构 设计模式 优化代码
1
linux下多进程并发拷贝文件示例 c编写
2021-11-12 12:57:46 3KB 多进程 linux
1
遗传算法实现多目标优化,有约束条件的!用C语言实现的@
2021-11-08 21:21:53 3KB 多目标优化 遗传算法 C语言
1
88行matlab拓扑优化代码TopOpt-MMA-Python 回购在拓扑优化中的示例应用。 原始的拓扑优化代码由编写。 python代码等效于高效的88行MATLAB代码。 原始的python代码可以下载。 要将修改后的Python代码与MMA优化器一起使用,用户需要从存储库中下载文件MMA.py。 参考 Aage,N.,Johansen,VE(2013)。 165线拓扑优化代码。 从2019年11月2日检索 Svanberg,K.(nd)。 MMA和GCMMA –非线性优化的两种方法。 从2017年8月3日检索
2021-11-06 15:19:55 29KB 系统开源
1
可再生能源_FCC 该存储库包含针对可再生能源集成的灵活碳捕集问题的优化代码
2021-11-04 18:41:49 3KB Python
1
matlab多目标优化代码CPDEA 版权所有刘一平 这些是“Yiping Liu、Hisao Ishibuchi、Gary G. Yen、Yusuke Nojima 和 Naoki Masuyama,处理不平衡”中提出的不平衡距离最小化问题 (IDMP) 和使用收敛惩罚密度方法 (CPDEA) 的进化算法的代码进化多模态多目标优化决策空间中的收敛性和多样性之间,IEEE 进化计算汇刊,2020 年,24(3),第 551-565 页,“。 代码使用发表于“Ye Tian 等人,PlatEMO: A MATLAB Platform for Evolutionary Multi-Objective Optimization, IEEE Computational Intelligence Magazine, 2017, 12(4): 73-87”。 如果您有任何问题,请联系。
2021-11-04 16:24:42 8.45MB 系统开源
1
L-BFGS-B的代码,是一种基于梯度的非线性优化方法。
2021-10-15 14:22:40 260KB 非线性优化
1
matlab解决路径优化代码ConvertChanceConstraint(CCC) ConvertChanceConstraint(ccc):用于机会约束优化的Matlab工具箱 基础信息 ConvertChanceConstraint(ccc)是基于的Matlab工具箱。 使用ccc,用户可以使用YALMIP语法来表示机会受限的优化问题,然后ccc将其转换为YALMIP和兼容的求解器可以解决的格式。 可以在中找到更多详细信息。 最新版本(进行中) 开发版本( master分支) 建议的引文如果您发现ccc在您的工作中很有用,我们恳请您引用以下文章 @article{geng2019data, title={Data-driven decision making in power systems with probabilistic guarantees: Theory and applications of chance-constrained optimization}, author={Geng, Xinbo and Xie, Le}, journal={Annual Revi
2021-10-09 11:38:11 463KB 系统开源
1