例如登录时获取登录人的权限菜单,方法一:得到用户之后,去查用户角色关系表,再查角色表,再用角色去查角色权限关系表,最后查出菜单或者按钮。每次查询都是单表查询,多次查询,逻辑都在JAVA代码中实现。方法二,在SQL中,通过表的关联关系,执行一个方法,就查出登录人所具有的菜单权限。两种做法都能达到目的,但是问题来了,这两种那种更好?哪种更值得推荐?或者什么情况下使用方法一,什么情况下采用方法二?
我的领导要求使用方法一,理由:SQL是数据库的,数据库只管存储,不用将逻辑写在SQL中(所以也不让写存储过程)。逻辑写在JAVA代码中,每个表的查询都是单表查,对开发人员的SQL要求不高,因为SQL和JAVA都是高手的开发人员不好找……各位大牛怎么看待这样的问题?欢迎大家说说自己的看法
在系统开发中,关于三表查询和多表查询,哪个比较好?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
7条回答 默认 最新
- 十八年后又是一条好汉 2017-02-24 16:52关注
明显方法二。
写关联查询是开发的基本功,也不需要多高。网上资源也丰富,不懂搜一下试一试就搞定了。
如果用Hibernate之类的框架则更简单。
只要项目组里面有一个比较熟悉DB的写一套出来,新人依葫芦画瓢就行了。
除非有性能问题,再想办法优化查询。用方法一好像是对开发没什么信心,但也不见得效率高,如果开发真的完全新手,说不定连接池都不用,每次查表都新建一个DB连接...
解决 无用评论 打赏 举报
悬赏问题
- ¥15 乘性高斯噪声在深度学习网络中的应用
- ¥15 运筹学排序问题中的在线排序
- ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
- ¥30 求一段fortran代码用IVF编译运行的结果
- ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
- ¥15 C++ 头文件/宏冲突问题解决
- ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
- ¥50 安卓adb backup备份子用户应用数据失败
- ¥20 有人能用聚类分析帮我分析一下文本内容嘛
- ¥30 python代码,帮调试,帮帮忙吧