View Javadoc
1   /*
2    *    Copyright 2009-2023 the original author or authors.
3    *
4    *    Licensed under the Apache License, Version 2.0 (the "License");
5    *    you may not use this file except in compliance with the License.
6    *    You may obtain a copy of the License at
7    *
8    *       https://www.apache.org/licenses/LICENSE-2.0
9    *
10   *    Unless required by applicable law or agreed to in writing, software
11   *    distributed under the License is distributed on an "AS IS" BASIS,
12   *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   *    See the License for the specific language governing permissions and
14   *    limitations under the License.
15   */
16  package org.apache.ibatis.submitted.manyanno;
17  
18  import java.util.List;
19  
20  import org.apache.ibatis.annotations.Arg;
21  import org.apache.ibatis.annotations.ConstructorArgs;
22  import org.apache.ibatis.annotations.Many;
23  import org.apache.ibatis.annotations.Result;
24  import org.apache.ibatis.annotations.Results;
25  import org.apache.ibatis.annotations.Select;
26  
27  public interface PostMapper {
28  
29    @Select("select * from post where author_id = #{id} order by id")
30    // @formatter:off
31    @Results(value = {
32        @Result(property = "id", column = "id"),
33        @Result(property = "subject", column = "subject"),
34        @Result(property = "body", column = "body"),
35        @Result(property = "tags", javaType = List.class, column = "id", many = @Many(select = "getTagsForPost"))
36      })
37    // @formatter:on
38    List<AnnoPost> getPosts(int authorId);
39  
40    @Select("select t.id, t.name from tag t inner join post_tag pt on pt.tag_id = t.id where pt.post_id = #{postId} order by id")
41    // @formatter:off
42    @ConstructorArgs(value = {
43        @Arg(column = "id", javaType = int.class),
44        @Arg(column = "name", javaType = String.class)
45      })
46    // @formatter:on
47    List<AnnoPostTag> getTagsForPost(int postId);
48  
49  }