hql多表查询转换问题,小弟受教了

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hql多表查询转换问题,小弟受教了相关的知识,希望对你有一定的参考价值。

1 person表:
字段1:ID //用户ID,主键
字段2:personName //用户名
字段3:personPwd //密码
字段4:permissionID //权限ID 外键权限表ID

2 permission表:
字段1:ID //权限ID,主键
字段2:permissionName //权限名
----------------------------------------------------------------------------------------------------------------------------------------
hibernate反向生成完成之后,hql查询用户名为‘张三’的权限,

String hql=" from Person r left join Permission t on r.permissionID = t.permissionID and r.personName=‘张三’;

请教1:这个sql咋写。。我这写的不对。 hibernate生成实体类之后 person表里是permission对象,那我hql咋写。。 r.permissionID = t.permissionID 这个r里没有permissionID。。。
----------------------------------------------------------------------------------------------------------------------------------------
请教2:getHibernateTemplate().findByExample(obj); 这个对象不支持主外键。。。让人白高兴了, 有什么替代吗?
hibernate反向生成之后
person实体:
private Integer ID;
private String personName;
private String personPwd;
private Permission permission;

Permission实体:
private Integer ID;
private String permissionName;
private Set person= new HashSet(0);

请教 我要查询 用户名,密码,权限名 ,HQL怎么写 。。。

用户和权限是多对多关联映射吧(说是多对一也认了,这里以多对多举例),你设置好关联映射后,直接from Person 就可以直接查询用于信息得到该用户的所有权限信息了,不需要添加其他条件,因为你的用户类已经关联了权限类了

多对多关联映射只提示几点吧,
1是 在Person类设置 Set permissons = new HashSet(); seter/geter 方法
Permission 类里设置 Set persons = new HashSet(); seter/geter 方法

2 两个持久化类的映射文件中设置<many-to-many>标签

Person映射文件中: <!--sc中间表不需要自己创建 -->
<set name="permissons" table="sc" inverse="true">
<key column="personID" />
<many-to-many class="Permission" column="permissionID" />
</set>
Permission :
<set name="persons" table="sc" inverse="true">
<key column="permissionID" />
<many-to-many class="Person " column=personID" />
</set>

然后就可以啦,三个关联映射也是必须学会的啊(这是使用了多对多双向关联映射,还有一对多的,一对第一的) 是Hibernate比较重要的知识点哦追问

查询personNmme,personPwd,PermissionName
我要加入 条件 PermissionName=管理员 ,hql 怎么写。

追答

在用户和权限多对一的情况下:
From Person p where p.permission. permissionName = '管理员'

参考技术A 查询,返回map记录的方法

select new map(<字段列表>) from............. where ............ order by ...........

大厂Android岗面试,居然还问这些问题!受教了!

前言

去年底就开始看,android的好机会确实不太多,但也还好,3年+的android开发经历还是有一些面试机会的,不过确实不像几年前门槛那么低了,总的体会就是小的创业公司比较注重你的项目经历是否和自己的贴合,直接能过来独当一面。大厂除了看中项目经历外,还比较注重你知识面的广度,是广度、深度和解决方案等多方面的考察,平时够工作要好好积累临时刷题只聊点皮毛估计是过不了关的。

下面就总结一些遇到的题目,各种风格的都有。这里先列举问题。

面试真题

又坐标杭州,各厂名字字母表示,自己猜。本题目整理不保证你会遇到相同的问题,根据岗位和面试官本身情况,问题可能差别很大,比如有做中间件的同学被问到热修复的细节等等。总体说来阿里的面试是很正规的,从android基础到一定程度的理解总结性问题,然后回到java基础及原理,主要着重问简历上的,或从简历出发发散问题,问题会由表及里逐渐深入,很考察对你负责的项目的理解和其中用到知识原理。因为是凭着记忆后记的,以下问题不分先后。这里按岗位来分类,能有个渐进的感觉。

TB:电面一

  1. dp是什么,sp呢,有什么区别
  2. 自定义View,ViewGroup注意那些回调?
  3. 界面卡顿的原因以及解决方法
  4. android中的存储类型
  5. service用过么,基本调用方法
  6. Handler机制
  7. LinearLayout、FrameLayout、RelativeLayout性能对比,为什么
  8. Activity的生命周期,finish调用后其他生命周期还会走么?
  9. FW层熟悉么,源码看过么
  10. GC回收机制熟悉么,分代算法知道么
  11. Java的类类加载原理
  12. 内存泄漏如何排查,MAT分析方法以及原理,各种泄漏的原因是什么比如
  13. Handler为什么会泄漏
  14. gradle熟悉么,自动打包知道么
  15. 介绍下先的app架构和通信
  16. 自己负责过哪些模块,跟同事相比自己的优势是什么
  17. 遇到过什么印象深刻的问题,怎么解决的

##现场面试:三场
First:

  1. 最近都做了哪些工作?
  2. 遇到了什么印象深刻的问题。A:会顺着你介绍的项目问下具体实现。
  3. 推送消息有富文本么?
  4. 热修复了解么,用的什么?
  5. apk包大小有限制么?怎么减少包大小?
  6. 工作中有没有用过或者写过什么工具?脚本,插件等等
  7. 比如:多人协同开发可能对一些相同资源都各自放了一份,有没有方法自动检测这种重复之类的
  8. 写过native的底层代码么
  9. view的绘制熟悉么,介绍下
  10. gc相关的算法
  11. anr是因为什么产生的,怎么排查
  12. 界面上的话,有什么优化措施么?比如列表展示之类的,平时遇到过内存问题吗,怎么优化的?
  13. 平时用过哪些设计模式?

Second:

  1. 介绍下最近一年主要做了什么工作
  2. 会对简历上突出的技能进行详情的询问:比如:音频合成的具体步骤,以及遇到的一些问题和细节处理。 会根据面试发散一些问题,问到,seek方法播放到末尾后重新播放会有一些卡顿的不流畅问题,怎么避免,从交互设计或者技术角度。(个人表示没怎么关注这种)。
  3. 项目团队多少人,怎么分配工作
  4. 线程之间怎么通信的?
  5. app的架构是怎么样的,并且为什么这样,有什么优缺点?
  6. 算法熟悉么?给了一个二叉排序树,出了一个给定节点找到它的下一个元素(指的是大小顺序的下一个)的算法题。
  7. 为什么找工作,自己的优势是什么

Third:

  1. 技术问题不再局限于简历,可能根据简历和回答情况渐进并扩散。
  2. 感觉各个技术面试官之前并没有沟通,可能会问到类似的问题
  3. 介绍下自己主要负责的工作
  4. Activity的生命周期有哪些,知道onRestart么,介绍下
  5. savedInstanceState知道么,干什么用的,什么时候有值,什么时候为空,平时是怎么用的
  6. View绘制熟悉么,介绍下,能说下是实现原理么?
  7. 平时用过什么开发工具,分析工具?
  8. ANR是怎么回事?怎么查?Service会引起ANR么?
  9. Activity的启动模式有哪些?栈里是A-B-C,先想直接到A,BC都清理掉,有几种方法可以做到?这几种方法产生的结果是有几个A的实例?
  10. 有什么工具可以看到Activity栈信息么?多个栈话,有方法分别得到各个栈的Activity列表么
    都熟悉哪些命令?知道怎么用命令启动一个Activity么?
  11. SharedPrefrences的apply和commit有什么区别
  12. java里带$的函数见过么,是什么意思
  13. MD5是加密方法么,Base64呢
  14. 有博客和github,主要是写的什么?有哪些关注
  15. android 8.0 有哪些新特性
  16. 差不多就这些吧。。最后每个面试官都会让你问他问题。

某公司

  1. glide缓存策略?同一个图片跟size有关么
  2. android中的动画有哪些
  3. View事件传递机制
  4. 界面卡顿怎么排查和优化?
  5. Fragment的replace和end??的区别?
  6. MVP,MVVM,MVC解释和实践
  7. 项目之外的,对技术的见解,拓展知识

二面:

  1. 微信跳一跳外挂怎么实现,检测怎么做的?
  2. 一张纯色背景下怎么有效检测各个矩形?
  3. 对接的so算法了解么,有接触过相关的库么?
  4. 三个算法题选一个并写出测试用例:打印n-m之间所有的素数;计算n-m之间1出现的次数;指定数字序列的排序;
  5. android api层的源码熟悉哪些?解释一下
  6. ACTION_CANCEL什么时候触发,触摸button然后滑动到外部抬起会触发点击事件吗,在+ + 滑动回去抬起会么
  7. 怎么处理嵌套View的滑动冲突问题
  8. 热修复相关的原理,框架熟悉么
  9. gradle打包流程熟悉么
  10. 任意提问环节:其实可以问之前面试中遇到的问题:比如,多模块开发的时候不同的负责人可能会引入重复资源,相同的字符串,相同的icon等但是文件名并不一样,怎样去重?

NetBase:

  • Canvas的底层机制,绘制框架,硬件加速是什么原理,canvas lock的缓冲区是怎么回事
  • surfaceview, suface,surfacetexure等相关的,以及底层原理
  • android文件存储,各版本存储位置的权限控制的演进,外部存储,内部存储
  • 上层业务activity和fragment的遇到什么坑??页面展示上的一些坑和优化经验
  • 网络请求的开源框架:OKHttp介绍,写过拦截器么

Netbase:AI

  • 数据层有统一的管理么,数据缓存是怎么做的,http请求等有提供统一管理么?
  • 有用什么模式么,逻辑什么的都在Activity层?怎么分离的
  • 如果用了一些解耦的策略,怎么管理生命周期的?
  • 有什么提高编译速度的方法?
  • 对应用里的线程有做统一管理么?
  • jni的算法提供都是主线程的?是不是想问服务类的啊
  • 边沿检测用的啥?深度学习相关的有了解么?
  • 上线后的app性能分析检测有做么

YZ

  • 进程间通信方式?Binder的构成有几部分?
  • HttpClient和HttpConnection的区别
  • View的事件传递机制
  • MVC,MVP,MVVM分别是什么?
  • Android中常用的设计模式,说三个比较高级的?
  • 内存优化,OOM的原因和排查方法
  • 想改变listview的高度,怎么做
  • Https是怎么回事?
  • 除了日常开发,其他有做过什么工作?比如持续化集成,自动化测试等等

DD

  • ActivityA跳转ActivityB然后B按back返回A,各自的生命周期顺序,A与B均不透明。
  • Synchronize关键字后面跟类或者对象有什么不同。
  • 单例的DCL方式下,那个单例的私有变量要不要加volatile关键字,这个关键字有什么用
  • JVM的引用树,什么变量能作为GCRoot?GC垃圾回收的几种方法
  • ThreadLocal是什么?Looper中的消息死循环为什么没有ANR?
  • Android中main方法入口在哪里
  • jdk1.5?SparseArray和ArrayMap各自的数据结构,前者的查找是怎么实现的,与HashMap的区别
  • Runnable与Callable、Future、FutureTask的区别,AsyncTask用到哪个?- AsyncTask是顺序执行么,for循环中执行200次new AsyncTask并execute,会有异常吗
  • IntentService生命周期是怎样的,使用场合等
  • RecyclerView和ListView有什么区别?局部刷新?前者使用时多重type场景下怎么避免滑动卡顿。懒加载怎么实现,怎么优化滑动体验。
  • SQLite的数据库升级用过么
  • 开放问题:如果提高启动速度,设计一个延迟加载框架或者sdk的方法和注意的问题。
  • Scroller有什么方法,怎么使用的。
  • 分享下项目中遇到的问题
  • webwiew了解?怎么实现和javascript的通信?相互双方的通信。@JavascriptInterface在?版本有bug,除了这个还有其他调用android方法的方案吗?
  • ReactiveNative了解多少
  • JNI和NDK熟悉么?Java和C方法之前的相互调用怎么做?

几点建议

1、简历要如实写,相关的知识点一定要烂熟于心。
2、基础扎实,android和java相关的知识树网上有很多资料,看过但让你讲出来未必能说的好。
3、提前总结,你还擅长什么其他技术?这种开放问题要看知识面了。
4、学会提问,你有什么问题要问我吗?这种礼貌性问题也是一个了解对方的好机会。
5、良好的心里素质,无论遇到什么情况,面试官迟到、面试官态度冰冷说话不客气、质疑你的回答等等各种问题都不要慌也不要排斥,一定要沉住气,耐心积极的思考并回答对方的提问。
6、推荐几本书,也是好几次面试后发现里面涵盖了大部分答案。《Android开发艺术探索》《Android源码设计模式-解析与实战》《Android进阶之光》《深入理解Java虚拟机》《Android音视频开发》《Android进阶解密》多看几遍。
大厂的面试流程比较长,面试是一场全面大考验,如果想换个工作,最好提前充分准备。

最后

小编在网上收集了一些 Android 开发相关的学习文档、面试题、Android 核心笔记等等文档,希望能帮助到大家学习提升,如有需要参考的可以直接去我 CodeChina地址:https://codechina.csdn.net/u012165769/Android-T3 访问查阅。

以上是关于hql多表查询转换问题,小弟受教了的主要内容,如果未能解决你的问题,请参考以下文章

HQL多表查询

HQL多表查询 ---- Hibernate之查询语句

什么决定了多表查询的锁定顺序?

HQL多表查询

hql 多表查询

HibernateHibernate的多表查询