- 浏览: 154463 次
- 性别:
- 来自: 布尼塔尼亚
文章分类
最新评论
-
aa87963014:
iTarget 写道弄清楚“事务”和“事物”打错字, 统一为事 ...
现在的数据库系统是否还需要事务? -
iTarget:
弄清楚“事务”和“事物”
现在的数据库系统是否还需要事务? -
aa87963014:
ipconfig1 写道 我现在也遇到这样的问题,当缓存的数据 ...
spring cache 拓展 -
aa87963014:
xcw931924821 写道楼主现在实现了吗?可以查看我的 ...
spring cache 拓展 -
xcw931924821:
楼主现在实现了吗?
spring cache 拓展
最后一个功能动态update完成,freyja还需要稳定性测试,并且检查疏漏的地方。
我对freyja的这套想法还是很满意的,cache就是几个map。不需要序列化。
执行update方法的时候维护缓存。
如何在当前方法里面知道是否开启了事物?如何知道几个方法是否在同一个事物里面?
我没有找到相关的API方法,但是根据同一个事物会共用一个连接来判断是否在同一个事物里面。
然后根据“事物缓存”来比较update了哪些字段。"List<String> updateColumn = MethodUtil.beanMapping(oldValue, value);"
由此就可以动态update,而不需要每次update的时候update整条记录。也许这样能提升update性能。
但是动态update由可以提高维护缓存的效率。因为如果一次update整个记录和update单个字段是不同的。
代码现在很乱,乱得我自己焦头烂额的。还希望有达人能帮忙重构一次。
----
整个程序是这样的,初始化的时候会扫描bean。把一些映射信息存到BeanInfoCache的map里面。
get(T)就是直接使用jdbctemplate的query
save(T)也是直接使用jdbctemplate的update
update(T) 就是用上面说的动态update 然后拼接sql,动态还是很有必要的,上面说明了。
executeUpdate(HQL)首先直接发送sql update数据库。然后处理缓存:
分为2类,一类是可以直接在内存中查找出来的。还有一类是没办法查出来的,这部分通过发送sql得到 ID然后得到结果集。
查出来了内存中需要更新的实体之后,通过
"private <T> void update(T t, BeanInfo<?> bi, Update update, Object[] args)"方法在内存中通过表达式、反射更新实体。
每个实体更新之后还需要更新查询缓存:
"private <T> void updateQueryCache(BeanInfo<?> bi, T t, boolean remove,List<String> columns)"
更新查询缓存的逻辑还算简单,上一篇应该大致上讲过了。只不过加了动态update,可以缩小更新范围。
放入查询缓存这块:"public List find(Integer first, Integer max, String hql, int type,Object... args)"
这个方法也是find主方法。
HQL分为支持查询缓存和不支持查询缓存2部分。判断支持的条件在解析HQL的时候已经知道了。
然后支持查询缓存的这部分还分为查询全部和查询部分。
区别在于查询部分在查询全部的基础上还需要处理一次:
"list = SqlParser.parser(list, sis, hm.bi, hm.rowMapperType)"
这样得到最终需要的查询结果。
QuertyResult
public List list;
public List result;
result才是实际的结果集。
list为该结果集涉及到的数据库记录。这个用于维护缓存的时候进行逻辑判断。
放入查询缓存这部分还需要改,但是还没想到更好的方法。
事物这块直接把spring的copy过来,在commit的地方加了释放“事物缓存”。
虽然到处都用到了反射,但是这个不觉得是问题。不知道还有哪些漏掉的东西。
本想看看hibernate是怎么实现动态update,但是在hibernate的源码里面迷失了。看到saveOrUpdate监听器这块就跟丢了
还希望有人能帮帮忙,谢谢!
下面有测试用项目,里面包含需要的代码。lib包就在前面几篇有放出下载。
- freyjatest.zip (192 KB)
- 描述: 最新test代码。
- 下载次数: 10
评论
而是查询结果集中没有元素。这个一般框架都应该是这样处理的。当然,我也有想过像hibernate一样返回空。把freyjaJdbctemplate单独分离开来。怎么封装freyjaJdbctemplate 就不需要我来关心。
水平有限,还请多交流下哈!
另外,你的 FreyjaJdbcAccessor 对staic HashMap的 sessionCache put,get操作真的是线程安全吗?
HashMap不是线程安全的,代码改动了不少。我放个最新的出来。
无聊,头痛医头,脚痛医脚
FreyjaJdbcAccessor 里的 static List EMPTY_LIST 看起来好像很不错,在FreyjaJdbcTemplate 中查询为空的时候,将EMPTY_LIST 返出去,但你是否保证外部的调用者对 这个EMPTY_LIST的引用不进行add操作,一旦做了,那下一个调用者就吃药了,因为这时这个EMPTY_LIST 里就多了一个元素了.结果与预期不符.
这个东西就代码质量而言还是玩具,就使用场景而言,lz还是没有没有正面回答.没有使用用途的产品是没有什么意义的,就像有光照才能发光的手电筒,没有使用价值
饿,EMPTY_LIST 我是抄袭hibernate/hibernatetemplate的。一个orm框架能有什么适用场景?非分布式结构应该都没问题(分布式环境下会有什么问题我现在也不太了解)
目前用在GAME服务端。
另外,你的 FreyjaJdbcAccessor 对staic HashMap的 sessionCache put,get操作真的是线程安全吗?
HashMap不是线程安全的,代码改动了不少。我放个最新的出来。
无聊,头痛医头,脚痛医脚
FreyjaJdbcAccessor 里的 static List EMPTY_LIST 看起来好像很不错,在FreyjaJdbcTemplate 中查询为空的时候,将EMPTY_LIST 返出去,但你是否保证外部的调用者对 这个EMPTY_LIST的引用不进行add操作,一旦做了,那下一个调用者就吃药了,因为这时这个EMPTY_LIST 里就多了一个元素了.结果与预期不符.
这个东西就代码质量而言还是玩具,就使用场景而言,lz还是没有没有正面回答.没有使用用途的产品是没有什么意义的,就像有光照才能发光的手电筒,没有使用价值
另外,你的 FreyjaJdbcAccessor 对staic HashMap的 sessionCache put,get操作真的是线程安全吗?
HashMap不是线程安全的,代码改动了不少。我放个最新的出来。
另外,你的 FreyjaJdbcAccessor 对staic HashMap的 sessionCache put,get操作真的是线程安全吗?
开始不支持事务是因为 本身如果去掉事务的支持对程序的并发性能是有巨大的提升的。
再则每次都去取》序列化》存》序列化,在你不需要分布式的情况下本身是无谓的操作。
freyja里面支持原生sql的。
如:select uid from User
select user_id from t_user
这个表达的意思是一样的所以都支持。直接写sql
线程安全应该没问题,没有共享变量。其他的还在改,
事情有点多所以测试还不够完善,但是这个毕竟不成问题。再说我也没指望一出来就能让别人替换掉hibernate之类的orm框架。
谢谢你的支持。
作为一个有生命力的工具或者框架,它最起码符合下面的条件:
1.便于开发,hibernate和ibaits都提供个相关的配置工具或者自动生成的dao层.减轻的开发者的负担.
2.便于调试,方便的知道结果,hibernate提供了hql调试工具,ibatis的sql可以直接在sql的ide上调试
3.符合实际使用环境的场景需要.
4.相当的单元测试及代码覆盖率
你的东东为了片面的增强缓存性能,而放弃了分布式,数据更新的原子性。它的使用场景是什么哪?大型的系统用的是分布式缓存解决数据同步更新问题。小型系统好像也没有场景需要所谓的再次查询的高速缓存。
请搞清楚自己的东东的使用场景再动手设计。
另外,你是否忘了jvm的内存也是有限的,一个hashmap会不会放的东西太多而是jvm out of memory哪? 你也是否忘了实际使用时,你是处在多线程环境下(不要认为在web工程中看不到threads 就认为它不是多线程调用的),线程安全在哪里?单元测试代码在哪里,覆盖率多少?。。。。
好好看看其他比较流行的框架的代码,它们都会面临不少工程上的问题,而不是纯粹的算法问题。为了纯粹的高性能,我一般都使用内存数据库,然后由内存数据库与主库同步,而无需代码干预。
发表评论
-
freyja框架 github地址
2015-03-27 12:05 1241可以查看我的 freyja框架 https://gi ... -
freyja将重新把重心放在orm、sharding、cache上
2012-05-05 23:04 1599freyja将把重心放在 1、更完善的orm 2、应用层屏 ... -
freyja 可能会加入分库、分表功能
2012-02-19 17:50 2264水平分库、分表一直都没去考虑。 如果要去实现那么大致的想法是 ... -
freyja更新
2012-02-12 14:38 1039因为工作的关系好就没更新了。现在的版本越来越稳定了。 ... -
freyja最重要的一个功能完成
2011-12-18 18:26 983freyja作为一个orm框架,除了结果集映射之外。另外一个核 ... -
freyja 将引入另外一项功能大幅提高服务器性能
2011-12-15 15:50 1095附件已经更新了最新的src,test项目和lib 还是一样前面 ... -
freyja 将引入“分组”概念进一步提高维护缓存时的效率
2011-12-10 11:00 897目前的freyja在维护缓存的时候是将表分为多个字段,每个字段 ... -
如何最大化利用缓存
2011-11-29 16:31 2201在查询缓存里面,我这 ... -
Freyja的查询缓存功能详解
2011-11-26 15:32 1163freyja作为项目中取代hibernate的ORM框架很符合 ... -
freyja 功能基本完毕
2011-11-23 11:52 1013freyja 的功能基本完毕。后续只会改进这些功能的性能和bu ... -
FreyjaJdbcTemplate目前的几个问题
2011-11-17 17:35 1013freyja发布了预览版:FreyjaJdbcTemplate ... -
FreyjaJdbcTemplate预览版
2011-11-17 17:06 1168简介: FreyjaJdbcTemplat ... -
准备决定不再支持hql特性
2011-11-12 20:25 1052又测试过一段时间发现save和hibernate的性能相当。s ... -
FreyjaJdbcTemplate 缓存失败了
2011-11-11 19:29 1294事情不能总是一帆风顺 ... -
FreyjaJdbcTemplate 开发进度
2011-11-10 17:04 928Freyja核心:HQLParser + Cache ... -
FreyjaJdbcTemplate特性三:JdbcTemplate
2011-11-10 16:22 1231这个算不上什么特性。每个用过spring jdbcTempla ... -
FreyjaJdbcTemplate特性二:cache
2011-11-10 16:01 1176在使用hibernate开发过程 ... -
FreyjaJdbcTemplate特性一:HQL
2011-11-10 14:56 1577freyja2大特点:hql+cache freyja ... -
FreyjaJdbcTemplate的开发前言
2011-11-10 14:28 1478一直以来只用过hibernate作为数据层,hibernate ...
相关推荐
"信息化系统集成项目竣工报告" 本报告详细记录了信息化系统集成项目的竣工情况,包括工程概况、设备安装、调试情况、工程进度等方面的信息。 项目概况 本项目的名称为信息化系统建设,开工日期为年月,竣工日期为...
综上所述,建筑工程施工合同中关于开工日期、完工日期和竣工日期的约定是至关重要的,合同双方必须明确各自的责任和义务,避免因日期约定不明或不合理导致纠纷。在签署合同时,承包商应充分了解和评估可能的风险,...
【人民防空工程竣工验收指引】是针对城市中建设的人防工程在完工后进行的一项关键程序,确保工程符合国家和地方的规范及标准。这一过程旨在保障人防工程的质量,满足战时和平时的功能需求,同时也是对建设单位施工...
信息化系统集成项目竣工报告的内容主要包括:工程报告文档、工程名称、开工日期、竣工日期、工程负责人、档案编制人、设备到货证明、安装设备清单、调试进度、工程竣工报告日期、单位签章等内容。 三、 设备安装和...
竣工结算书的法定代表人是编制竣工结算书的最后确认人。他们需要对竣工结算书的编制结果负责,并签章确认竣工结算书的合法性和准确性。在本例中,法定代表人为薛锋。 弱电专业竣工结算书模版.pdf资源提供了竣工结算...
- **单位工程/专业工程竣工验收**:针对独立签订施工合同的项目,承包人可单独申请验收,发包人根据合同约定内容组织验收。 - **分阶段验收**:大型、复杂项目中,按施工进度进行分阶段验收,符合国际惯例,有利于...
《给排水工程竣工验收报告与完工报告》是工程项目中至关重要的文档,主要目的是对已完成的给排水工程进行全面、系统的质量评估,确保工程达到设计要求和国家规定的标准。这份报告通常由建设单位、监理单位、设计单位...
1. 当施工图没有变动时,由负责竣工图编制的单位在设计文件的基础上直接加盖竣工图章,该图即被视为竣工图。这确保了竣工图与实际工程的一致性。 2. 对于发生一般性变更的图纸,如果这些变更满足杠改或划改的要求,...
1. **交工与验收主体**:施工项目的竣工验收,交工主体为承包人,验收主体是发包人。 2. **竣工验收条件**:工程必须满足交付竣工验收的特定条件,包括但不限于工程质量、技术资料和竣工图等。 3. **验收程序**:...
工程项目竣工验收讲义.ppt 本讲义主要讲解了工程项目竣工验收的概念、阶段划分、验收工程范围、基本条件、依据和程序等方面的知识点。 一、竣工验收概念 竣工验收是由项目验收主体及交工主体等组成的验收机构,以...
【人民防空工程竣工验收备案】是指在城市建设中,对于与民用建筑同步配套修建的防空地下室在完工后,需要按照国家法律法规进行的一项重要程序。这一过程确保了人民防空工程的质量和功能,以满足战时和平时的双重需求...
### 山东省人民防空工程竣工验收备案流程与要求 #### 一、概述 山东省人民防空工程竣工验收备案是确保人防工程质量与安全的重要环节。本文将基于“山东省人民防空工程竣工验收备案表”中的信息,详细介绍人防工程...
《上海建设工程竣工验收备案质量终身责任人登记表》是上海市对建设工程质量管理的一项重要制度,旨在确保工程质量,维护公共安全。此登记表明确了在工程项目的各个环节中,各参与方的责任人及其承担的质量终身责任。...
《建设工程竣工验收的法律适用》主要探讨了在建设工程领域中,竣工验收的民事法律意义与行政程序的区别,以及实际竣工日期在法律上的重要性。在民事法律层面,竣工验收是承发包双方对合同履行的认可,涉及到工程质量...
【中山市人民防空工程竣工验收指引】主要涵盖了人防工程竣工验收的标准、程序以及所需提交的表格和资料。以下是对这些知识点的详细说明: 一、验收执行标准和依据: 1. 《中山市人民防空工程竣工验收管理暂行规定》...
施工周期的延长,自然会对竣工数据产生一定的影响,其中一个重要表现就是竣工面积与新开工面积及销售面积在总量和走势上出现了背离,从而使得竣工数据作为行业参考指标的意义有所下降。 进一步探究竣工数据与相关...
工程竣工验收是指在建筑工程、土木工程或信息系统工程项目完工后,由发包方组织竣工验收,确保工程项目按照合同要求、技术标准和设计规范完成,并达到预定的使用功能和质量要求。这一过程通常涉及多个环节,包括但不...
广西壮族自治区建设项目竣工验收(试行)管理办法 本资源摘要信息将对《广西壮族自治区建设项目竣工验收(试行)管理办法》进行详细的解读和分析,以便更好地了解该文件中所涉及的知识点。 一、总则 《广西壮族...