当我们用HQL进行子查询的时候,如select * from Tree where pid in (select id from Tree,此时HIBERANTE就会报错,说什么*号错误之类的。但如果将*改为Tree类里的所有子段时就不会有问题了。就会像平时一样第一行数据返回一个Object[],然后你再根据Tree类里字段对Object[]数组里的值进行转换。这样一来比较麻烦。今天发现如果我SQL来查有一个方法可以返回一个对象的。
Configuration config = new Configuration().configure();
SessionFactory sf = config.buildSessionFactory();
Session session = sf.openSession();
Transaction ts = session.beginTransaction();
Query query = session.createSQLQuery("select * from Tree t where pid in (select id from Tree) ").addEntity(Tree.class); //返回对象
List list = query.list();
此时在遍历list时就可以(Tree)list.get[i];将每一行的内容变换为一个对象了。
另还可以返回一个Map对象,也就是说在在list里包含多个Map,代码如下
Query query = session.createSQLQuery("select id,name from Tree t where pid in (select id from Tree) ").setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); //返回一个map,KEY:为DB中名称一致(大小写一致)遍历list时就可以
Map map = (Map)list.get[i];
map.get("id");map.get("name");来取值。按你的SQL语句select后的字段名来作为map的Key,但这个key必须与数据库中的字段名一模一样。
还可以用作函数方面的。如
Query query = session.createSQLQuery("select sum(id) SUMID from Tree t where pid in (select id from Tree)
.addScalar("SUMID",Hibernate.INTEGER) //转换类型,按DB中的type转
.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); //返回一个map,KEY:为DB中名称一致(大小写一致)
直接就map.get("SUMID")可以取值了
还有一点就是这个方法在Hibernate3.2版本上才能正常运行。
分享到:
相关推荐
标题中的“bianxingjingang.rar_OLDMETAL.J_TRANSFORMERS_opengl_opengl_deform”暗示了这是一个关于OpenGL编程的项目,具体是实现了一个变形金刚模型在3D空间中的动态旋转和形变效果。这个项目可能使用了OldMetal.J...
.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); ``` 在上面的代码中,我们使用 setResultTransformer() 方法将查询结果转换为 Map 对象,每个 Map 对象的 KEY 是数据库中的字段名,VALUE 是该字段的值...
标题"SCT.zip_TRANSFORMERS_sct_zip"涉及到的主题是超导变压器(Super Conducting Transformers, SCT),这是一种使用超导材料作为绕组的电力变压器。超导材料具有极低的电阻,几乎为零,这使得在传输电流时几乎没有...
在Python编程环境中,我们经常遇到导入模块时遇到错误,如"No module named ‘transformers.models.auto.tokenization-auto‘"。这个错误表明系统无法找到名为`transformers.models.auto.tokenization-auto`的模块,...
Load flow studies determine if system voltages remain within specified limits under normal or emergency operating conditions, and whether equipment such as transformers and conductors are overloaded....
5. **bert-base-srl-2020.09.03.tar**: 这是另一个提及的文件,可能是一个基于BERT(Bidirectional Encoder Representations from Transformers)的语义角色标注(SRL)模型。BERT是Google开发的深度学习模型,用于...
标题中的“fff.zip_TRANSFORMERS_matlab solid_solid state”表明这是一个关于固体变压器(Solid State Transformers, SSTs)的资料集合,特别提到了MATLAB可能在其中的应用。MATLAB是一种广泛用于数学计算、数据...
from fast_transformers.attention import MultiheadAttention class TransformerModel(nn.Module): def __init__(self, d_model, num_heads): super(TransformerModel, self).__init__() self.attn = ...
"TRANSFORMERS_三相变压器_变压器启动_电"进一步明确了我们将深入研究三相变压器在电动机启动过程中的作用。 在电机系统中,三相异步电机是最常见的类型,广泛应用于工业生产中。这种电机以其结构简单、运行可靠和...
https://huggingface.co/transformers/custom_datasets.html#seq-imdb 用到的数据
Electronic switch-mode DC to DC converters convert one DC voltage level to another, by storing the input energy temporarily and then releasing that energy to the output at a different voltage....
变压器matlab仿真,用于实现基本的变压器操作和应用
query.unwrap(SQLQuery.class).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); List rows = query.getResultList(); for (Object obj : rows) { Map row = (Map) obj; System.out.println("id = " +...
from fast_transformers . builders import TransformerEncoderBuilder # Create the builder for our transformers builder = TransformerEncoderBuilder . from_kwargs ( n_layers = 8 , n_heads = 8 , que
Hidden Markov Model)、CRF(Conditional Random Field)等统计模型,或者采用基于深度学习的方法,如LSTM(Long Short-Term Memory)和BERT(Bidirectional Encoder Representations from Transformers)等。...
在自然语言处理领域,BERT(Bidirectional Encoder Representations from Transformers)模型是Google在2018年提出的一种预训练语言模型,它在多项NLP任务上取得了显著的性能提升。本文将围绕PyTorch中的预训练BERT...
资源分类:Python库 所属语言:Python 资源全名:pytorch-fast-transformers-0.3.0.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059
资源分类:Python库 所属语言:Python 资源全名:transformers-4.1.0.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059
标题中的"PyPI 官网下载 | sentence-transformers-0.4.1.1.tar.gz"指的是Python的包管理器PyPI(Python Package Index)上发布的sentence-transformers库的一个特定版本,0.4.1.1。PyPI是Python开发者发布和分享自己...
The IEEE 30-bus modified test system contains 49 buses, 32 transmission lines, 24 transformers and 10 generators. It has 19 constant impedance loads totaling 6097.1 MW and 1408.9 MVAr. All the ...