热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

在SpringApplication中使用Thymeleaf显示多对多关系数据

我有两个实体:书和作者。这是多对多的关系。我想得到带有作者所有书籍的所有表格的

我有两个实体:书和作者。这是多对多的关系。我想得到带有作者所有书籍的所有表格的表格,并在Spring Application中使用Thymeleaf将它们显示到表格中。

这里的图书课:

@Entity
@Table(name="book",schema="booksloan")
public class Book{
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
private String title;
private String year;
@ManyToMany(fetch = FetchType.LAZY,cascade = {
CascadeType.PERSIST,CascadeType.MERGE
},mappedBy = "book")
private Set author = new HashSet<>();
public Book() {
}
// getters and setters
}

这里是作者课程:

@Entity
@Table(name="Author",schema="booksloan")
public class Author{
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id_author;
private String name;
private String surname;
@ManyToMany
@JoinTable(
name = "written",joinColumns = @JoinColumn(name = "id_author"),inverseJoinColumns = @JoinColumn(name = "id"))
private Set books = new HashSet<>();
public Author() {
}
// getters and setters
}

我不知道该书面课程是否有用

@Entity
public class Written{
private int id;
private int id_author;
public Written() {
}
// getters and setters
}

在这里BookRepository界面

@Repository
public interface BookRepository extends JpaRepository {
@Query(value = "SELECT * FROM Written s JOIN Book l on s.id = l.id JOIN Author a on a.id_author = s.id_author",nativeQuery = true)
public List findWrittenBy();
}

在AppController类中

@RequestMapping(value={"","/","/index"})
public String index(Model model) {
List listBooksTest = bookService.findWrittenBy();
model.addAttribute("listBooksTest",listBooksTest);
return "indexUser";
}
}

这里是indexUser


xmlns:th="http://www.thymeleaf.org">






Books list



























ID Book ID Author Title Year Name Author Surname Author actions
ID Book ID Author Title Year Name Author Surname Author View copy






这是我得到的错误

org.springframework.expression.spel.SpelEvaluationException: EL1008E: Property or field 'id_author' cannot be found on object of type 'net.assignment.booksLoan.model.Book' - maybe not public or not valid?

有人知道我该怎么做吗?


您知道而不是浪费时间(我们讨厌浪费时间,不是我们)弄清楚哪些查询适合实体的哪一侧,您可以将结果列合并到定制模型/类中。或以类似的方式,只需在同一控制器中合并ListList的相交行并将它们传递给视图。

理想情况下,您的查询将是

@Query(value = "w.id,w.id_author,b.id,b.title,b.year,a.id_author,a.name,a.surname
FROM Book b
INNER JOIN
Written w on b.id = w.id
INNER JOIN
Author a on w.id_author = a.id_author ",nativeQuery = true)
public List findAllIntersectedColumn ();

问题是您列表的签名是 Book ,您还希望同时获得namesurename,但Book中没有明确定义它们尽管它们通过 M-to-M 模型彼此关联,但它们仍然是一个字段。还有一个关于projection interface的主题,用于检索可以在spring的doc上阅读的相关属性的子集。


推荐阅读
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • GreenDAO快速入门
    前言之前在自己做项目的时候,用到了GreenDAO数据库,其实对于数据库辅助工具库从OrmLite,到litePal再到GreenDAO,总是在不停的切换,但是没有真正去了解他们的 ... [详细]
  • 本文讨论了微软的STL容器类是否线程安全。根据MSDN的回答,STL容器类包括vector、deque、list、queue、stack、priority_queue、valarray、map、hash_map、multimap、hash_multimap、set、hash_set、multiset、hash_multiset、basic_string和bitset。对于单个对象来说,多个线程同时读取是安全的。但如果一个线程正在写入一个对象,那么所有的读写操作都需要进行同步。 ... [详细]
  • 本文整理了Java面试中常见的问题及相关概念的解析,包括HashMap中为什么重写equals还要重写hashcode、map的分类和常见情况、final关键字的用法、Synchronized和lock的区别、volatile的介绍、Syncronized锁的作用、构造函数和构造函数重载的概念、方法覆盖和方法重载的区别、反射获取和设置对象私有字段的值的方法、通过反射创建对象的方式以及内部类的详解。 ... [详细]
  • HashMap的相关问题及其底层数据结构和操作流程
    本文介绍了关于HashMap的相关问题,包括其底层数据结构、JDK1.7和JDK1.8的差异、红黑树的使用、扩容和树化的条件、退化为链表的情况、索引的计算方法、hashcode和hash()方法的作用、数组容量的选择、Put方法的流程以及并发问题下的操作。文章还提到了扩容死链和数据错乱的问题,并探讨了key的设计要求。对于对Java面试中的HashMap问题感兴趣的读者,本文将为您提供一些有用的技术和经验。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 十大经典排序算法动图演示+Python实现
    本文介绍了十大经典排序算法的原理、演示和Python实现。排序算法分为内部排序和外部排序,常见的内部排序算法有插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。文章还解释了时间复杂度和稳定性的概念,并提供了相关的名词解释。 ... [详细]
  • 花瓣|目标值_Compose 动画边学边做夏日彩虹
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Compose动画边学边做-夏日彩虹相关的知识,希望对你有一定的参考价值。引言Comp ... [详细]
  • 颜色迁移(reinhard VS welsh)
    不要谈什么天分,运气,你需要的是一个截稿日,以及一个不交稿就能打爆你狗头的人,然后你就会被自己的才华吓到。------ ... [详细]
author-avatar
w果乐园地盘BSp
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有