持久化类的要求

1,需要提供一个无参数的构造器,该构造器可以不用public访问控制符,因为Hibernate是使用Constructor.newInstance()来创建的持久化实例,只要提供了无参数的构造器就好了。通常为了方便Hibernate在运行时生成代理,一般构造器的访问控制修饰符至少是包可见的

2.提供一个标识属性,通常是映射数据库表的主键字段。实际上也可以不是必须要设置标识属性,只是设置了标识属性之后Hibernate的许多功能都可以用

3.为持久化类的每个成员变量提供setter和getter方法

4.使用非fianl类:如果持久化类没有实现任何接口,那么Hibernate默认使用Javassist生成代理,该代理对象是持久化类的子类的实例。如果使用了final类的话就无法生成Javassist代理,将无法进行性能优化

5.重写equals()和hashCode()方法:用于需要把持久化类的实例放入Set中的情况,实现这两个方法最显而易见的方式就是比较两个对象标识属性的值。只不过这样有一个漏洞:对采用自动生成标识值的对象不能使用这种方法,因为Hibernate只会为那些持久化对象指定标识值,而新创建的实例将不会有任何标识值。(采用自动生成标识值的对象的标识值是在save()之后指定主键值的)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于Python对象的持久化存储,有多种技术可以实现,包括pickle模块、shelve模块、JSON、XML、ORM框架等。在下面,我将逐一介绍这些技术的特点和使用方法。 1. pickle模块 pickle是Python内置的模块之一,可以将Python对象转换成二进制形式并进行存储。它支持绝大多数Python对象的序列化,包括列表、元组、字典、、闭包等,因此非常灵活方便。pickle的用法也很简单,我们只需要使用dump()函数将对象序列化后存储到文件中,或者使用load()函数从文件中读取并反序列化。 2. shelve模块 shelve是pickle的衍生模块,它将序列化后的对象以似字典的形式存储,并可以像字典一样进行访问和修改。shelve的优点是在存储大量对象时,可以大幅降低内存占用,因为只有访问到某个键值时才会将其反序列化到内存中。使用shelve模块也非常简单,我们只需要打开一个db文件(似于关系数据库的数据库文件),然后把对象写入其中即可。 3. JSON JSON是一种轻量级数据交换格式,它使用文本形式表示数据,可以轻松地在不同语言和平台之间传递和解析。Python提供了一个json模块,可以将Python对象转换成JSON字符串,并进行存储。反序列化也非常方便,只需要将JSON字符串解析成Python对象即可。 4. XML XML是一种标记语言,与JSON似,可以用于数据交换。Python也提供了一个xml模块,可以将Python对象转换成XML格式并进行存储。反序列化也非常容易,只需要使用ElementTree对象解析XML文件即可。 5. ORM框架 ORM(Object-Relational Mapping)是一种通过使用和对象来操作关系数据库的技术。ORM框架可以将Python对象和数据库表中的数据对象进行映射,使得我们可以用Python对象来操作数据库,而不需要编写SQL语句。Python有多个ORM框架可供选择,比如Django的ORM、SQLAlchemy等。 以上就是一些常见的Python对象持久化存储技术介绍,每种技术都有其适用场景和优劣势,我们可以根据具体的需求选择合适的技术。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值