Homocentric框架其实是一个意外产物,在公司做项目时,苦于数据库的繁琐,需要对代码进行一层层的封装,遂产生了冲动,不如自己写一个框架吧,于是说做就做,由于学过JavaEE的三大框架,对其中的Hibernate的原理有一定的了解,因此写起来并不是十分的吃力,断断续续的过了三个月,Homocentric的第一个版本出来了,不消说,用起来确实方便多了,闲话少说,开始正题。
Homocentric在使用方法上与Hibernate几乎一致(因为本人也是模仿它做的),对外提供一个接口负责执行被持久化对象的CRUD操作——Sessoin,Session共有提供了十个方法,分别是:
public List get(Object obj) throws JavaBeanException;
public Object get(Class<?> clazz, Integer id);
public List getPaging(Class<?> clazz, int start, int count);
public boolean save(Object obj) throws JavaBeanException;
public boolean update(Object obj) throws JavaBeanException;
public boolean delete(Object obj) throws JavaBeanException;
public int getCount(Class<?> clazz);
public List get(String sql, String[] selectionArgs);
public void exec(String sql);
public void closeDB();
这十个方法在此不做过多的介绍了,相信看到方法的名和参数就应该知道它的作用。
其中的某些方法的参数obj是JavaBean,JavaBean需要继承Holder,目前Holder类没有任何可用的方法,备以后版本扩展使用,如果JavaBean没有继承Holder而使用Session,则会抛出JavaBeanException异常。
Session是受保护的类,通过SeesionFactory类可以得到,如下:
Session session = SessionFactory.getSession(context);
其中Context是Android的上下文对象。
介绍完两个关键类,下面需要说下Homocentric的配置文件:homo.cfg.xml。
配置文件需要定义APP所需要的数据库及JavaBean所对应的数据库表,具体格式示例如下:
<?xml version="1.0" encoding="UTF-8"?>
<library name="shop" version="1">
<table name="user">
<property name="name" type="VARCHAR" length="50" />
<property name="psd" type="VARCHAR" length="30" />
</table>
</library>
library标签定义数据库,其中name是数据库名,version是数据库版本,如果版本大于当前的数据库版本,则删除原来数据库重新创建。
table标签定义数据库表,其中name是表名。
property标签定义表的字段属性,其中name是字段名,type是字段类型,length是字段长度,如果其值为-1,则表示无长度要求。
作为第一个版本,目前没有特别的复杂的处理,比如外键等。
下面使用一个简单的例子,来介绍Homocentric的使用。
public class User extend Holder {
private String name;
private String psd;
public User(){}
public void setName(String name) {
this.name = name;
}
public ...
}
定义好User后,相应的需要修改配置文件,为了避免重复,直接就使用上面的配置文件例子,将这些准备好后,可以编写UserDao了。
public class UserDao {
protected Session session;
protected Class clazz;
public UserDao(){
clazz = User.class;
session = SessionFactory.getSession(context);
}
public User getAll() {
try {
return session.get("FROM " + clazz.getName(), null);
} catch (SQLSyntaxException e) {
e.printStackTrace();
}
return null;
}
public boolean save(User user) {
try {
return session.save(user);
} catch (JavaBeanException e) {
e.printStackTrace();
}
return false;
}
public ...
}
UserDao具体实现了User在数据库的CRUD的操作。
Homocentric框架的一些基本功能差不多就是这些了,于是精力有限,一些关于数据库的更高级的功能没有加入,比如外键关联,JavaBean中的某个属性不是基本数据类型等,关于这些将会在下一个版本中发布。
这里附上Homocentric的开发Jar包,供有需求的人使用。
Homocentric的技术交流群:195735749,关于Homocentric的源码及设计将在群里发布。
申明:转载请注明出处,谢谢。
分享到:
相关推荐
项目资源包含:可运行源码+数据集+文档 python + numpy, pandas, matplotlib, pyecharts, wordcloud 适用人群:学习不同技术领域的小白或进阶学习者;可作为课程设计、大作业、工程实训或初期项目立项。 数据来源:数据集taxis.csv从网络下载 数据清洗:异常值与缺失值的处理:有一些数据distance(乘车距离)为零而且上下车地点为空,还有些一些数据的payment(支付方式)为空。 数据预处理:将列名更改成中文 标准化与归一化: 数据分析: 数据可视化:
TypeScript 入门教程
人脸识别项目实战
本资源汇总了 历届全国电子设计竞赛(电赛)真题+模拟题,涵盖 电路设计、嵌入式系统、信号处理、自动控制等核心考点,并提供详细解析及综合测评,帮助参赛者高效备赛、查漏补缺、提升实战能力。 适用人群: 适合 准备参加电子设计竞赛的大学生、电赛爱好者、电子信息类相关专业的学生,以及希望提高电子设计和电路分析能力的工程师。 能学到什么: 电赛考察重点:熟悉往届竞赛的命题方向及考核重点。 电路设计与仿真:提升模拟电路、数字电路、单片机等核心技能。 问题分析与解决能力:通过综合测评找到薄弱点并针对性提升。 实战经验:掌握竞赛策略,提高应试效率和设计能力。 阅读建议: 建议先 通读真题,了解题型与解题思路,然后 结合模拟题实战演练,查找不足并通过测评强化练习,逐步提升竞赛能力。
2024人工智能如何塑造未来产业:AI对各行业组织带来的的变革研究研究报告.pdf
人脸识别项目源码实战
给大家分享一套课程——Vulkan原理与实战课程
c语言学习
海豚鲸鱼数据集 5435张图 正确识别率可达92.6% 可识别:海豚 虎鲸 蜥蜴 海豹 鲨鱼 龟 支持yolov8格式标注
答谢中书书教学设计.docx
人脸识别项目源码实战
c语言学习
人脸识别项目源码实战
人脸识别项目实战
本美发门店管理系统有管理员和用户两个角色。用户功能有项目预定管理,产品购买管理,会员充值管理,余额查询管理。管理员功能有个人中心,用户管理,美容项目管理,项目类型管理,项目预定管理,产品库存管理,产品购买管理,产品入库管理,会员卡管理,会员充值管理,余额查询管理,产品类型管理,系统管理等。因而具有一定的实用性。 本站是一个B/S模式系统,采用SSM框架,MYSQL数据库设计开发,充分保证系统的稳定性。系统具有界面清晰、操作简单,功能齐全的特点,使得美发门店管理系统管理工作系统化、规范化。本系统的使用使管理人员从繁重的工作中解脱出来,实现无纸化办公,能够有效的提高美发门店管理系统管理效率。 关键词:美发门店管理系统;SSM框架;MYSQL数据库;Spring Boot 1系统概述 1 1.1 研究背景 1 1.2研究目的 1 1.3系统设计思想 1 2相关技术 2 2.1 MYSQL数据库 2 2.2 B/S结构 3 2.3 Spring Boot框架简介 4 3系统分析 4 3.1可行性分析 4 3.1.1技术可行性 4 3.1.2经济可行性 5 3.1.3操作可行性 5 3.2系
内容概要:本文档介绍了基于SSA-CNN-GRU麻雀算法优化卷积门控循环单元数据分类预测的详细项目实例,重点讲述了该项目的背景、目标、挑战与解决方案、技术特点、应用领域等方面的内容。文档详细记录了从项目启动、数据预处理、算法设计(SSA优化CNN-GRU模型)、构建与评估模型到实现美观的GUI界面整个过程,并讨论了防止过拟合的技术如正则化、早停和超参数优化。另外还涵盖了项目扩展的可能性、部署和应用策略、需要注意的地方以及未来改进的方向。全文强调了模型的泛化能力和计算效率,展示了该混合算法模型在实际应用中的优越性能。 适合人群:具备一定的Python编程经验及机器学习基础知识的研究人员和技术人员;对深度学习、智能优化算法及实际应用感兴趣的学者和从业者;寻求提升数据分析和预测准确性的金融分析师、数据科学家等相关专业人士。 使用场景及目标:本文档非常适合用作学习和参考资料,以掌握如何将SSA、CNN与GRU三种先进技术结合起来进行复杂的分类和预测问题求解。具体应用场景包括但不限于以下几个方面:金融领域——股票价格预测;医疗保健领域——辅助诊断;工业制造——预防性维护;智能家居——个性化服务;以及其他涉及到时序数据分析和多模态数据处理的场合。文档既包含了理论知识又提供了完整的源代码示例,可以帮助读者理解算法原理并通过实践中加深对其的认识。 其他说明:该项目不仅仅是关于算法的设计实现,更是有关于系统的整体架构规划以及工程上的考量,比如环境准备(确保环境洁净、必要包的安装等)、数据准备、GPU配置支持等等。同时文中给出了详细的代码片段,方便开发者理解和复现实验成果。值得注意的是,虽然文中提供了一套通用解决方案,但在真实场景下还需要针对性的调整参数或修改网络结构来达到最好的性能效果。此外,对于追求更高的预测精度或解决更大规模的问题,作者建议进一步探索深度强化学习等高级技术和多任务学习策略,并且考虑使用增量学习让模型能够适应新数据而不必重新训练整个模型。最后提到安全性和隐私保护也是项目实施过程中的重要因素,要妥善保管用户的敏感信息并且做到合法合规地收集和使用数据。
人脸识别项目实战
人脸识别项目实战
水下垃圾检测数据集,基于voc和yolo标注的两种格式,共23,056个文件,已经划分了训练集和验证集、测试集。并且提供了真实水下的视频数据,可以用作视频推理
(参考GUI)MATLAB车辆检测.zip