查看原文
其他

思考,撸一段 SQL ? 还是写一段代码?

Orson 我是程序汪 2021-09-09

点击上方“我是程序汪”,选择“设为星标

做积极的人,而不是积极废人


作者:Orson     来源:www.cnblogs.com/java-class/p/5985916.html

以下都为个人思考总结所得,只作为抛砖引玉之说,一定会有不同意见,如果你有不同看法,欢迎拍砖。

记得刚入公司带我的研发哥们能写一手漂亮的 SQL,搜索准确、执行快、效率高。

配合Web项目中的查询展示数据的需求,基本是分分钟完成任务。

那段时间基本是仰视的态度,每天都去讨教一点手写 SQL 的要点,翻看一些 SQL 优化调整的技巧。

随后经历了几个项目的打磨,不断去调整公司的框架,发现项目中大段 SQL 出现的概率越来越小。

我不得不停下脚步,开始反思和总结出现这种现象的原因。如果你手上不忙并且感兴趣,请听我慢慢道来。

下面是一个经典的系统权限数据库设计,作为例子来展开论述。

img

组织机构、用户、角色、菜单作为4个主要设计对象,添加三张两两关系映射表。

能很好的做到水平和纵向扩展,其中主要设计对象我只添加了几个需要的字段。

该设计完全可以引入到你的项目中,根据项目实际使用人群和需求添加必要字段。

然后配合 Shiro 或者 Spring -Security 能很完美的解决组织用户角色菜单的权限问题。

言归正传,项目需求中有这个一个要求,需要推送当前用户所有的菜单项,SQL写法。

select a.uuid,a.name
from menu a
left join role_menu b
on a.uuid = b.menuid
left join role_user c
on b.roleid = c.roleid
where c.userid = '用户uuid';

你需要在数据库中执行好,粘贴到你的代码中,使用数据访问对象去数据库执行该SQL获取数据。

下面看段相同逻辑的面向对象代码逻辑。

RoleUserPO roleUserPO = roleService.findUserRoleByUserId("用户ID");
if (roleUserPO == null) {
return "当前用户没有设置角色!";
}

List<RoleMenuPO> roleMenuPOs = roleService.findRoleMenusByRoleId(roleUserPO.getRoleid());
if (roleMenuPOs == null) {
return "当用户所在角色没有设置菜单!";
}

List<MenuPO> menuPOLis = new ArrayList<MenuPO>();
for (RoleMenuPO roleMenuPO : roleMenuPOs) {
menuPOLis.add(menuService.findMenuById(roleMenuPO.getMenuid()));
}
return menuPOLis;

上面这例子放在这里这样一对比是不是有感觉了,如果还不够强烈请在往下看看。

项目需求中同样也有一个这样的要求,需要罗列特定角色在特定部门下的用户,SQL 写法。

select a.*
from user a
LEFT JOIN role_user b
on a.UUID = b.userid
LEFT JOIN orga_user c
on a.uuid = c.userid
where b.ROLEID = 'c9845b33973511e6acede16e8241c0fe'
and c.ORGAID = '75284c22973211e6acede16e8241c0fe'

同样撸段相同逻辑的面向对象代码逻辑。

List<UserPO> userPO1s = roleService.findUsersByRoleId("角色ID");
if (userPO1s == null) {
return "当前角色没有添加用户!";
}

List<UserPO> userPO2s = orgaService.findUsersByOrgaId("组织机构ID");
if (userPO2s == null) {
return "当前机构没有添加用户!";
}

List<UserPO> userPOList = new ArrayList<UserPO>();
for (UserPO userPO1 : userPO1s) {
for (UserPO userPO2 : userPO2s) {
if (userPO1.getUuid().equals(userPO2.getUuid())) {
userPOList.add(userPO1);
break;
}
}
}
return userPOList;

有没有感觉出面向对象代码逻辑不仅读起来简单,而且能很清楚的提示出错的原因。

而且现在主流的数据库还是面向关系的,而编程语言已经从面向过程发展为面向对象。

也就是说两者完全不搭调,也就是现在 ORM 框架不断壮大的原因,编程中需要将数据表作为对象去对待和处理。

代码中出现大段 SQL 与面向对象的设计思路完全是背道而驰。

如果查询 SQL 出现问题,将后台打印的 SQL  粘贴到 SQL 执行工具中去执行,分析原因,两个工具切来切去,你不觉得费劲么?

这应该就是后续我接触的项目,SQL 减少的主要原因,我们喜欢在一个面向对象的频道去编程。

好了,就这样吧。以上都为个人思考总结所得,只作为抛砖引玉之说,如果你有不同意见,欢迎拍砖。



和程序汪深度沟通可以去知识星球

程序汪往期精彩文章包含答案






1.程序汪最近整理的BAT大小厂面试题2019  (面试题目录推荐)

工作中99%能用到的git命令

一个比Spring Boot快44倍的Java框架

最受欢迎的100个Java库

记住:永远不要在 MySQL 中使用 UTF-8

8种常见SQL错误用法

除了不要 SELECT * ,数据库还有哪些技巧

程序汪放水面试2年的Java女程序媛

巧用Java8中的Stream,让集合操作飞起来!

985硕士粉丝纠结去腾讯还是头条,找程序汪咨询(秋招面经技巧分享)

良心文章-SQL优化(好文章希望更多人能学到)

2.程序员接私活说好1万,但是项目做完只拿到1千

3.程序员回4线城市老家,靠接私活月入1万多已经3年了

5.目录:我把精华文章都整理出来了    (大目录列)

公众号是回复 001 或 002 一直到006 都能找到面试视频以及答案

给个[在看],是对程序汪最大的支持
: . Video Mini Program Like ,轻点两下取消赞 Wow ,轻点两下取消在看

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存