点击上方 好好学java ,选择 星标 公众号

重磅资讯、干货,第一时间送达
今日推荐:2020 年最棒的 9 个 Java 框架,哪个最香?个人原创+1博客:点击前往,查看更多
作者:Orson
链接:cnblogs.com/java-class/p/5985916.html

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

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

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

随着积累和实践,SQL 水平提高的很快,同时也写了很多。

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

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

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

组织机构、用户、角色、菜单作为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 减少的主要原因,我们喜欢在一个面向对象的频道去编程。

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

撸一段 SQL ? 还是撸一段代码?相关推荐

  1. java.sql.SQLException: ORA-01691: Lob 段 SONARQUBE2.SYS_LOB0000119128C00008$$ 无法通过 128 (在表空间 USERS 中

    文章目录 一.场景浮现 1. 问题详情 2. 问题描述 3. 问题原因 二.解决方案 2.1. 查看表空间的名字及文件在哪 2.2. 查询表空间使用情况 2.3. 解决方法 一.场景浮现 1. 问题详 ...

  2. 非常实用的,使用SQL查询连续号码段。(做计费系统或SP的兄弟经常会用到)...

    非常实用的,使用SQL查询连续号码段.(做计费系统或SP的兄弟经常会用到) 数据库中如何使用SQL查询连续号码段 在[Database吧]上有一则非常巧妙的SQL技巧,学习一下,记录在这里. 最初的问 ...

  3. mybatisplus page排序_PostgreSQL使用WITH xxx AS()查询,使用Page中的OrderItem排序,会把WITH xxx AS()这段SQL忽略导致报错...

    当前使用版本(必填,否则不予处理) 3.2.0 该问题是如何引起的?(确定最新版也有问题再提!!!) 目前更新到3.3.2版本问题一样存在 PostgreSQL使用WITH xxx AS()查询,使用 ...

  4. sql统计各分数段人数示例

    经常需要进行数据统计分析,可以结合sql语句中的sum记和.case分类来实现分类统计. 例如统计各分数段人数.90-100分数段内的标记为A,80-89分数段内的标记为B,70-79分数段内的标记为 ...

  5. mysql语句中in的个数没有限制,但是整段sql语句的长度有限制(客户端发送)

    我们看到一些文章,问题描述:mysql语句中in的个数到底有没有限制,答案是有的,限制个数为1000. 而且看到网友发的截图超过1000确实报错了,我亲测试了下发现,并没有报错. 结论: Oracle ...

  6. oracle号码段拆开,学习-SQL查询连续号码段的巧妙解法

    学习-SQL查询连续号码段的巧妙解法 在ITPUB上有一则非常巧妙的SQL技巧,学习一下,记录在这里. 最初的问题是这样的:我有一个表结构, fphm,kshm 2014,00000001 2014, ...

  7. 5段SQL可以测试出你对SQL性能优化知识了解多少

    数据库是很强大的,它可以实现超预期的执行性能.但是很多人很容易写出不能发挥最高效算法的SQL查询语句,因而也容易产生无法预期的性能结果. 下面UncleToo为大家整理出5段SQL,都是大家平时经常写 ...

  8. 通过SQL一键解析表字段血缘关系

    可以根据sql文件中的sql快速解析出表字段到字段的血缘关系,支持mysql.oracle.hive.impala.greenplum等数据库sql语法解析,可以在sql文件中放如多段sql解析,也可 ...

  9. mysql 查询多个号段_SQL查询连续号码段实现实例

    下文将教您在数据库中如何使用SQL查询连续号码段的方法,供您参考,如果您对SQL查询方面感兴趣的话,不妨一看,对您会有所帮助. 有一个表结构, fphm,kshm 2014,00000001 2014 ...

最新文章

  1. C/C++指向指针的指针
  2. 高可用的Spring FTP上传下载工具类(已解决上传过程常见问题)
  3. 超越“机器人三定律” 人工智能期待新伦理
  4. 华为鲲鹏高校行长沙启航,助力基础研究成果转化
  5. solr5的基本操作
  6. docker 部署 nginx+php+mysql
  7. DDoS高防服务如何选择?
  8. [云炬创业基础笔记]第二章创业者测试23
  9. Spring Boot 内置Tomcat——集成JSP解决方案
  10. 第一周:深度学习引言(Introduction to Deep Learning)
  11. 2007-2019中国城市竞争力排行榜Top10,你的家乡上榜了嘛?
  12. 可怕!微软AI:一张面部照片一段音频,完美生成头像演讲视频
  13. 网传字节跳动实习生删除GB以下所有机器学习模型,差点没上头条......
  14. 【学习笔记】【OC语言】继承
  15. oracle 表列统计信息,Oracle中收集表与列统计信息
  16. RocksDB调优指南
  17. 安装纯净版windows系统,win10企业版LTSC
  18. 如何控制局域网网速_图文版[许迎果讲科普] 常见的影响网速的因素
  19. C语言那些事之脉冲丢包率检测
  20. 补交20145226蓝墨云班课 -- Arrays和String单元测试

热门文章

  1. Robot Framework 自动化框架 - 定制自己的library
  2. com.microsoft.sqlserver.jdbc.SQLServerException: 索引 1 超出范围
  3. ESP32 OTA 策略的优点与可能的问题
  4. oracle服务器环境建立,oracle 透明网关环境的建立
  5. C++ Primer 5th笔记(chap 15 OOP)派生类的拷贝控制成员
  6. C++ Primer 5th笔记(8)chapter8 类:IO库-string流
  7. 思考并实现以下程序功能:实现一个抢红包的程序 java
  8. [密码学] 复杂性理论基础
  9. 解决Ubuntu终端编辑时上下左右变成ABCD问题
  10. Linux网络配置与命令