一对多关系映射应用之二

2024-08-31 13:18

本文主要是介绍一对多关系映射应用之二,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

正向的一对多关系,一般只应用在下拉列表中,通过关联来动态生成多级的下拉列表。

后台完成查询全部省份的方法,在页面上加入超连接。

       <center>

           <a href="province!list.action">显示一对多列表</a>

       </center>


在Action中完成查询和传递数据的操作。

public class ProvinceAction extends ActionSupport {

 

    private List<Province> allProvince;

 

    public String list() throws Exception {

       allProvince = ServiceFactory.getIProvinceServiceInstance().list();

 

       return "list";

    }

 

    <package name="root" namespace="/" extends="struts-default">

       <action name="province" class="org.liky.otm.action.ProvinceAction">

           <result name="list">/pages/province/province_list.jsp</result>

       </action>

    </package>


测试时,会提示懒汉式加载异常,因为在页面上才查询城市信息。

为了解决这个问题,可以使用以下两种方法:

1)  不关闭连接(不推荐)

2)  不使用懒汉式,需要在映射文件中修改。

<set name="cities" lazy="false" inverse="true">       

同时,测试时还会发现,顺序会随机改变,这就需要也修改映射文件,设置关联对象的排序顺序。

<set name="cities" lazy="false" order-by="id desc" inverse="true">       

省份选项还可以改为以下形式

           <select>

              <c:forEach var="p" items="${allProvince}">

                  <optgroup label="${p.title }"></optgroup>

                  <c:forEach var="c" items="${p.cities}">

                     <option value="${c.id }"> |- ${c.title }</option>

                  </c:forEach>

               </c:forEach>

           </select>


如果是反向多对一的功能,在所有的添加,修改和查询操作中,都会有区别。

这里新建立一张 新闻类型表,同时,在新闻表中加入一个 所属分类的字段。

这样,新闻和新闻类型之间存在一对多关系。

新闻类型是一,新闻是多。

建表语句:

CREATE TABLE news_type (
       tid              number(8)           primary key ,
       tname            varchar2(50)        not null
);

INSERT INTO news_type VALUES (1,'军事');
INSERT INTO news_type VALUES (2,'政治­');
INSERT INTO news_type VALUES (3,'艺术');
INSERT INTO news_type VALUES (4,'文学');
INSERT INTO news_type VALUES (5,'体育');

DROP TABLE news ;

CREATE TABLE news (
       id              number(8)            primary key ,
       title           varchar2(50)         not null,
       content         varchar2(500)        not null,
       pub_date        date                 not null,
       type_id         number(8)            not null,
       foreign key (type_id) references news_type (tid) on delete cascade
);

COMMIT;

根据表,生成映射,替换原有的News信息





下面完成多对一部分的修改:

 

添加功能:

由于需要选择所在分类,因此要先编写一个查询全部分类的功能。

    public List<NewsType> insertPre() throws Exception {

       List<NewsType> allType = null;

       try {

           allType = DAOFactory.getINewsTypeDAOInstance().findAll();

       } catch (Exception e) {

           e.printStackTrace();

           throw e;

       } finally {

           HibernateSessionFactory.closeSession();

       }

       return allType;

    }

这里要注意,由于编写的功能是:新闻管理,因此所有的Service操作都应该写到NewsService中,并没有规定必须在NewsService调用NewsDAO,NewsTypeService里调用NewsTypeDAO,Service与DAO并不是绑定到一起的。

 

修改超连接。

<a href="news!insertPre.action">添加新闻</a>

<br />       

在Action中添加一个insertPre的操作方法:

    // 所有新闻分类的信息

    private List<NewsType> allType;

 

    public String insertPre() throws Exception {

       allType = ServiceFactory.getINewsServiceInstance().insertPre();

      

       return "insert";

    }

<result name="insert">/pages/news/news_insert.jsp</result>    

修改insert.jsp,加入一个下拉列表选择分类。

           <form action="news!insert.action" method="post">

              新闻标题:<input type="text" name="news.title" /> <br/>

              新闻内容:<input type="text" name="news.content" /> <br/>

              新闻发布日期:<input type="text" name="news.pubDate" /> <br/>

              新闻分类:<select name="news.newsType.tid">

                  <option value="0">-请选择分类-</option>

                  <c:forEach var="t" items="${allType}">

                     <option value="${t.tid }">${t.tname }</option>

                  </c:forEach>

              </select>

              <br/>

              <input type="submit" value="添加"/>

           </form>

注意:下拉列表的 name 对应 news中的newsType里的tid。

 

列表显示时,也可以显示出新闻对应的分类信息。

                     <td>

                         ${news.newsType.tname }

                     </td>

测试时也会提示懒汉式异常,也需要修改配置文件,这次修改的是News.hbm.xml

        <many-to-one name="newsType" lazy="false" class="org.liky.pojo.NewsType" fetch="select">

            <column name="TYPE_ID" precision="8" scale="0" not-null="true" />

        </many-to-one>

修改功能中,由于也要显示下拉列表,因此在Service里需要查询两部分内容:新闻的信息,所有新闻分类信息。

    public Map<String, Object> updatePre(int id) throws Exception {

       Map<String, Object> map = new HashMap<String, Object>();

       try {

           map.put("news", DAOFactory.getINewsDAOInstance().findById(id));

           map.put("allType", DAOFactory.getINewsTypeDAOInstance().findAll());

       } catch (Exception e) {

           e.printStackTrace();

           throw e;

       } finally {

           HibernateSessionFactory.closeSession();

       }

       return map;

    }

因此Service中需要实现一个修改前的预处理操作。

修改Action中的操作

    public String updatePre() throws Exception {

       Map<String, Object> map = ServiceFactory.getINewsServiceInstance()

              .updatePre(news.getId());

       news = (News) map.get("news");

       allType = (List<NewsType>) map.get("allType");

 

       return "update";

    }

修改页面

           <form action="news!update.action" method="post">

              新闻标题:<input type="text" name="news.title" value="${news.title }"/> <br/>

              新闻内容:<input type="text" name="news.content" value="${news.content }"/> <br/>

              新闻发布日期:<input type="text" name="news.pubDate" value="${news.pubDate }"/> <br/>

              新闻分类: <select name="news.newsType.tid">

                  <option value="0">-请选择分类-</option>

                  <c:forEach var="t" items="${allType}">

                     <option value="${t.tid}" ${t.tid==news.newsType.tid?"selected":"" }>${t.tname }</option>

                  </c:forEach>

              </select>

              <br/>

              <input type="hidden" name="news.id" value="${news.id }"/>

              <input type="submit" value="修改"/>

           </form>





































这篇关于一对多关系映射应用之二的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1124014

相关文章

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Tomcat版本与Java版本的关系及说明

《Tomcat版本与Java版本的关系及说明》:本文主要介绍Tomcat版本与Java版本的关系及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Tomcat版本与Java版本的关系Tomcat历史版本对应的Java版本Tomcat支持哪些版本的pythonJ

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

Java中&和&&以及|和||的区别、应用场景和代码示例

《Java中&和&&以及|和||的区别、应用场景和代码示例》:本文主要介绍Java中的逻辑运算符&、&&、|和||的区别,包括它们在布尔和整数类型上的应用,文中通过代码介绍的非常详细,需要的朋友可... 目录前言1. & 和 &&代码示例2. | 和 ||代码示例3. 为什么要使用 & 和 | 而不是总是使

Python循环缓冲区的应用详解

《Python循环缓冲区的应用详解》循环缓冲区是一个线性缓冲区,逻辑上被视为一个循环的结构,本文主要为大家介绍了Python中循环缓冲区的相关应用,有兴趣的小伙伴可以了解一下... 目录什么是循环缓冲区循环缓冲区的结构python中的循环缓冲区实现运行循环缓冲区循环缓冲区的优势应用案例Python中的实现库

SpringBoot整合MybatisPlus的基本应用指南

《SpringBoot整合MybatisPlus的基本应用指南》MyBatis-Plus,简称MP,是一个MyBatis的增强工具,在MyBatis的基础上只做增强不做改变,下面小编就来和大家介绍一下... 目录一、MyBATisPlus简介二、SpringBoot整合MybatisPlus1、创建数据库和

python中time模块的常用方法及应用详解

《python中time模块的常用方法及应用详解》在Python开发中,时间处理是绕不开的刚需场景,从性能计时到定时任务,从日志记录到数据同步,时间模块始终是开发者最得力的工具之一,本文将通过真实案例... 目录一、时间基石:time.time()典型场景:程序性能分析进阶技巧:结合上下文管理器实现自动计时

Java逻辑运算符之&&、|| 与&、 |的区别及应用

《Java逻辑运算符之&&、||与&、|的区别及应用》:本文主要介绍Java逻辑运算符之&&、||与&、|的区别及应用的相关资料,分别是&&、||与&、|,并探讨了它们在不同应用场景中... 目录前言一、基本概念与运算符介绍二、短路与与非短路与:&& 与 & 的区别1. &&:短路与(AND)2. &:非短