select *
阿里开发手册中规定:【强制】在表查询中,一律不要使用 * 作为查询的字段列表,需要哪些字段必须明确写明。
原因
- 无用的列会增加数据传输的时间和网络的开销
- 对于不需要的大字段会增加额外的io操作
解释:在MySQL、InnoDB中当大字段的存储量超过728个字节的时候,数据库会将超出部分序列化到别的地方。当查询的时候进行io读取 - 不会被MySQL优化器的“覆盖索引”策略优化(业内极推荐的查询优化方式)
spring构造注入
在开发中@Autowired或者@Resource使用起来及其方便、简单。
但是每次使用是都有个小问题
直译为:不建议现场注入
原因
官方文档给的解释:
The Spring team generally advocates constructor injection as it enables one to implement application components as immutable objects and to ensure that required dependencies are not null. Furthermore constructor-injected components are always returned to client (calling) code in a fully initialized state.
翻译:
Spring团队通常提倡构造函数注入,因为它使人们能够将应用程序组件实现为不可变对象,并确保所需的依赖项不为null。此外,构造函数注入的组件总是以完全初始化的状态返回给客户机(调用)代码。
原因很明显了
- 依赖不可变
- 依赖不为空
当要实例化FooController的时候,由于自己实现了有参数的构造函数,所以不会调用默认构造函数,那么就需要Spring容器传入所需要的参数
依赖不为空(省去了我们对其检查):当要实例化FooController的时候,由于自己实现了有参数的构造函数,所以不会调用默认构造函数,那么就需要Spring容器传入所需要的参数,spring不会允许空值传入,空值就会报错。而set注入是允许赋值为null的 - 完全初始化的状态
向构造器传参之前,要确保注入的内容不为空,会调用依赖组件的构造方法完成实例化。在Java类加载实例化的过程中,构造方法是最后一步(之前如果有父类先初始化父类,然后自己的成员变量,最后才是构造方法),所以返回来的都是初始化之后的状态。
结束语
对个人碰见的疑惑进行归纳解答。-----做记录