作者回复: 原来这也可以,学习了。
作者回复: 的确很多公司都选择了MyBatis,对SQL的掌控度更好一些。但JPA(也就是Hibernate)在一些简单的场景里会更方便,写复杂了各种优化也不容易,比如开二级缓存什么的。MyBatis配合一些工具用起来也挺高效的,这个看公司的大环境吧,建议一个系统里不要混用两种,否则维护起来比较麻烦。
作者回复: 这里的集合Hibernate给我们做了个LazyLoading的优化,在使用时才会去加载,没有事务时findByCustomerOrderById操作后连接就还回去了,Session也关了,后面访问items时自然就没有Session报错了。加了事务,连接在我提交或者回滚前都会持有,Session也在,自然就不会报错了。也可以设置@ManyToMany的fetch,默认是LAZY。
作者回复: 这里我定义了一些公共的方法,抽象出来就不用再每个子的接口里重复定义了,然后尤其要注意我加了@NoRepositoryBean,免得它也被声明成Repository
作者回复: 一个Order里有多个Coffee,同样一个Coffee也能出现在多个Order里。订单A里有摩卡和美式,订单B里有摩卡和意式,不知道是不是能解释清楚我选择ManyToMany的理由呢。
作者回复: 感觉你还是没理解这里lazy loading的是order.items,这是个集合,order.id是直接就加载上来的,所以只取id的getJoinedOrderId是不会有问题的,而访问items就会报错。
作者回复: Spring对你的方法调用做了拦截,Hack了你的调用,做了动态的实现。至于基本的方法,那个是CrudRepository实现的。
作者回复: 可以用findByXxxIsNotNull
作者回复: 我们在后面那个视频里就讲到了它的实现,可以往后再看看哈。
作者回复: 这里真的没想太多,随手写的,就一个元素么,就用singletonList()了。如果要说有区别,singletonList()返回的是SingletonList<E>,里面真的只能放一个元素;Arrays.asList(T...a)返回的是ArrayList<T>。