增删改查不是万能的,但是万万不能没有增删改查——限信息管理类

简介:   感谢大家对我的支持,上一篇(【角色】——分离开代码和权限需求,即实现代码和权限需求的解耦。 )的推荐数达到了37 。这是大家对我的认同、鼓励、支持、和期望。也是我继续写下去的动力。十分感谢。这让我感到我并不孤独,并不是所有的人都不看好自然框架。

 

  感谢大家对我的支持,上一篇(【角色】——分离开代码和权限需求,即实现代码和权限需求的解耦。 )的推荐数达到了37 。这是大家对我的认同、鼓励、支持、和期望。也是我继续写下去的动力。十分感谢。这让我感到我并不孤独,并不是所有的人都不看好自然框架。为了不辜负大家的期望,我是一定会走下去的。

  同时支持我的兄弟们,我绝对不会让你们失望的! 稳定版的自然框架增在不断的完善中,争取弄个在线演示出来。

 

在信息管理的项目里,增删改查是一个很基础的功能,也是必不可少的功能之一。增删改查是很简单的,属于入门级的,一些公司在面试程序员的时候,往往也会出一些增删改查相关的题目。因为基础、简单、普遍,所以往往被忽视掉了。

 

信息管理类项目由这几个部分组成:

1、增删改查

2、报表、打印、图表

3、导入、导出

4、流程、审批

 (如有遗漏,欢迎补充)

 

这么看来得话,增删改查占据了一个项目的四分之一,不过后三者里面或多或少的都含有增删改查的部分。

按照工作量来计算的话,增删改查至少要占据50%以上的时间(编码时间、测试时间、功能调整)。尤其到了后期,功能、流程都确定下来之后,客户的大部分修改意见都是和增删改查方面的,比如加个查询条件,列表里多显示个字段,在同一个表单里面还要在看到其他的几个信息(字段)。当然这是对于企业定制开发来说的。

 

实现一个增删改查不难,难的是在众多的增删改查中找到规律、找到异同点,然后提炼、抽象。

 

如果能够把增删改查搞定了,那么就相当于搞定了一般的项目。

 

2/8原则:如果我用20%的时间搞定80%的简单的事情(增删改查),那么我就有80%的时间搞定20%复杂的业务逻辑。

 

自然框架的第一步就是搞定这些增删改查。简单的功能都搞定不了,还何谈复杂的功能?没学会走呢就想跑?那是一定会摔跟头的。所以我要一步一步的来。

 

那么自然框架要如何搞定增删改查呢?

 

 

音乐盒(八音盒)和钢琴

 

音乐盒,很古老的东东了,不知道大家有没有印象。打开音乐盒,可以听到美妙的音乐,比如致爱丽丝。在iPod、随身听出现之前是很受欢迎的。但是他有一个缺点,就是制作好了之后,只能播放一种乐曲。除非你把它拆开来,改动里面的机关。

这就像我们写的增删改查,编译之后只能做一个增删改查。比如公司信息的增删改查编译之后。就只能实现公司信息的增删改查。如果想要实现产品信息的增删改查,那么需要修改代码重新编译。当然修改了之后他就只能改产品信息,而不能改公司信息了。

 

再说钢琴。钢琴能弹奏什么乐曲呢?有什么乐谱就能弹奏什么乐曲(不考虑弹钢琴人的能力问题)。听不同的乐曲,只需要换相应的乐谱就行,不必改动钢琴。

 

自然框架里的自定义控件就好比钢琴,而元数据就是乐谱。要实现公司信息的增删改查,那么就配置一套相应的元数据;想实现产品的增删改查,那么就配置一套产品的元数据。而代码(自定义控件、页面)是不需要修改的,除非有特殊的业务需求。

 

这样,简单的增删改查就可以快速的配置出来。节省出更多的时间来解决复杂的业务逻辑。做配置信息并不需要编译,到了后期,对于客户的频繁的修改,这个优势就体现出来了。因为客户提出来的修改要求,我们可以当场解决。客户要改成什么样子的,我们立刻就改,改完了立刻确认,然后签字画押。缩短周期,不给客户喘息的机会,省着他们没完没了的改。

 

 

ps:

第一份增删改查,写了一套代码,搞定。

第二份增删改查,把上一份copy过来,改改表名、字段名,搞定。

第三份增删改查,同上。

         ……

 

         请问您一直都是这样做的吗?(包括使用代码生成器生成代码)

 

         如果是的话,请继续回答下面几个问题:

         请问您抽象了吗?

         请问这样copy代码是对的吗?

         您对这种方法满意吗?

         您有没有想过,可能有更好的方法?

 

相关文章
|
2月前
|
SQL 监控 Java
在IDEA 、springboot中使用切面aop实现日志信息的记录到数据库
这篇文章介绍了如何在IDEA和Spring Boot中使用AOP技术实现日志信息的记录到数据库的详细步骤和代码示例。
在IDEA 、springboot中使用切面aop实现日志信息的记录到数据库
|
2月前
|
SQL NoSQL 关系型数据库
实时数仓Hologres发展问题之实时数仓的类数据库化与HTAP数据库的差异如何解决
实时数仓Hologres发展问题之实时数仓的类数据库化与HTAP数据库的差异如何解决
41 2
|
20天前
|
SQL 关系型数据库 MySQL
学成在线笔记+踩坑(3)——【内容模块】课程分类查询、课程增改删、课程计划增删改查,统一异常处理+JSR303校验
课程分类查询、课程新增、统一异常处理、统一封装结果类、JSR303校验、修改课程、查询课程计划、新增/修改课程计划
学成在线笔记+踩坑(3)——【内容模块】课程分类查询、课程增改删、课程计划增删改查,统一异常处理+JSR303校验
|
6天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
45 5
|
7天前
|
SQL 关系型数据库 MySQL
ThinkPHP6 连接使用数据库,增删改查,find,select,save,insert,insertAll,insertGetId,delete,update方法的用法
本文介绍了在ThinkPHP6框架中如何连接和使用数据库进行增删改查操作。内容包括配置数据库连接信息、使用Db类进行原生MySQL查询、find方法查询单个数据、select方法查询数据集、save方法添加数据、insertAll方法批量添加数据、insertGetId方法添加数据并返回自增主键、delete方法删除数据和update方法更新数据。此外,还说明了如何通过数据库配置文件进行数据库连接信息的配置,并强调了在使用Db类时需要先将其引入。
ThinkPHP6 连接使用数据库,增删改查,find,select,save,insert,insertAll,insertGetId,delete,update方法的用法
|
2月前
|
SQL Java 数据库
jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上
该博客文章介绍了在JSP应用中使用Servlet查询SQL Server数据库的表信息,并通过JavaBean封装图书信息,将查询结果展示在Web页面上的方法。
jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上
|
2月前
|
SQL Java 数据库连接
连接数据库实现查询员工信息
该博客文章展示了如何在Java中使用JDBC连接SQL Server数据库,并执行查询操作来检索员工信息,包括加载数据库驱动、建立连接、创建SQL查询、处理结果集以及关闭数据库资源的完整示例代码。
连接数据库实现查询员工信息
|
2月前
|
SQL 数据库连接 API
ThinkPHP6实现增删改查接口
ThinkPHP6实现增删改查接口
33 1
|
2月前
|
XML 数据库 数据格式
Spring5入门到实战------14、完全注解开发形式 ----JdbcTemplate操作数据库(增删改查、批量增删改)。具体代码+讲解 【终结篇】
这篇文章是Spring5框架的实战教程的终结篇,介绍了如何使用注解而非XML配置文件来实现JdbcTemplate的数据库操作,包括增删改查和批量操作,通过创建配置类来注入数据库连接池和JdbcTemplate对象,并展示了完全注解开发形式的项目结构和代码实现。
Spring5入门到实战------14、完全注解开发形式 ----JdbcTemplate操作数据库(增删改查、批量增删改)。具体代码+讲解 【终结篇】
|
2月前
|
SQL XML Java
Spring5入门到实战------12、使用JdbcTemplate操作数据库(增删改查)。具体代码+讲解 【上篇】
这篇文章是Spring5框架的实战教程,详细讲解了如何使用JdbcTemplate进行数据库的增删改查操作,包括在项目中引入依赖、配置数据库连接池、创建实体类、定义DAO接口及其实现,并提供了具体的代码示例和测试结果,最后还提供了完整的XML配置文件和测试代码。
Spring5入门到实战------12、使用JdbcTemplate操作数据库(增删改查)。具体代码+讲解 【上篇】
下一篇
无影云桌面