欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring和Hibernate的整合操作示例

 更新時間:2020年01月18日 12:28:04   作者:cakincqm  
這篇文章主要介紹了Spring和Hibernate的整合操作,結(jié)合實(shí)例形式詳細(xì)分析了Spring和Hibernate的整合具體步驟、實(shí)現(xiàn)方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了Spring和Hibernate的整合操作。分享給大家供大家參考,具體如下:

一 web配置

<?xml version="1.0" encoding="GBK"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns="http://xmlns.jcp.org/xml/ns/javaee"
  xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
  http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
  version="3.1">
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener
    </listener-class>
  </listener>
  <filter>
    <filter-name>struts2</filter-name>
    <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>struts2</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
</web-app>

二 applicationContext.xml

<?xml version="1.0" encoding="GBK"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns="http://www.springframework.org/schema/beans"
  xmlns:p="http://www.springframework.org/schema/p"
  xmlns:tx="http://www.springframework.org/schema/tx"
  xmlns:aop="http://www.springframework.org/schema/aop"
  xsi:schemaLocation="http://www.springframework.org/schema/beans
  http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
  http://www.springframework.org/schema/tx
  http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
  http://www.springframework.org/schema/aop
  http://www.springframework.org/schema/aop/spring-aop-4.0.xsd">
  <!-- 定義數(shù)據(jù)源Bean,使用C3P0數(shù)據(jù)源實(shí)現(xiàn),并注入數(shù)據(jù)源的必要信息 -->
  <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
    destroy-method="close"
    p:driverClass="com.mysql.jdbc.Driver"
    p:jdbcUrl="jdbc:mysql://localhost/spring"
    p:user="root"
    p:password="32147"
    p:maxPoolSize="40"
    p:minPoolSize="2"
    p:initialPoolSize="2"
    p:maxIdleTime="30"/>
  <!-- 定義Hibernate的SessionFactory,SessionFactory需要依賴數(shù)據(jù)源,注入dataSource -->
  <bean id="sessionFactory"
    class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"
    p:dataSource-ref="dataSource">
    <!-- mappingResources用來列出全部映射文件 -->
    <property name="annotatedClasses">
      <list>
        <!-- 以下用來列出所有的PO類-->
        <value>org.crazyit.booksys.domain.Book</value>
      </list>
    </property>
    <!-- 定義Hibernate SessionFactory的屬性 -->
    <property name="hibernateProperties">
      <props>
        <!-- 指定Hibernate的連接方言 -->
        <prop key="hibernate.dialect">
          org.hibernate.dialect.MySQL5InnoDBDialect</prop>
        <!--是否根據(jù)Hiberante映射創(chuàng)建數(shù)據(jù)表 -->
        <prop key="hibernate.hbm2ddl.auto">update</prop>
        <prop key="hibernate.show_sql">true</prop>
        <prop key="hibernate.format_sql">true</prop>
      </props>
    </property>
  </bean>
  <!-- 定義Service組件,并將DAO組件注入Service組件 -->
  <bean id="bookService" class="org.crazyit.booksys.service.impl.BookServiceImpl"
    p:bookDao-ref="bookDao"/>
  <!-- 定義DAO組件,并將SessionFactory注入DAO組件 -->
  <bean id="bookDao" class="org.crazyit.booksys.dao.impl.BookDaoHibernate4"
    p:sessionFactory-ref="sessionFactory"/>
  <!-- 配置Hibernate的局部事務(wù)管理器,使用HibernateTransactionManager類 -->
  <!-- 該類是PlatformTransactionManager接口針對采用Hibernate的特定實(shí)現(xiàn)類 -->
  <!-- 配置HibernateTransactionManager需依賴注入SessionFactory -->
  <bean id="transactionManager"
    class="org.springframework.orm.hibernate4.HibernateTransactionManager"
    p:sessionFactory-ref="sessionFactory"/>
<!-- 配置事務(wù)增強(qiáng)處理Bean,指定事務(wù)管理器 -->
<tx:advice id="txAdvice"
  transaction-manager="transactionManager">
  <!-- 用于配置詳細(xì)的事務(wù)定義 -->
  <tx:attributes>
    <!-- 所有以'get'開頭的方法是read-only的 -->
    <tx:method name="get*" read-only="true"/>
    <!-- 其他方法使用默認(rèn)的事務(wù)設(shè)置,指定超時時長為5秒 -->
    <tx:method name="*" isolation="DEFAULT"
      propagation="REQUIRED" timeout="5"/>
  </tx:attributes>
</tx:advice>
<!-- AOP配置的元素 -->
<aop:config>
  <!-- 配置一個切入點(diǎn) -->
  <aop:pointcut id="myPointcut" expression="bean(bookService)"/>
  <!-- 指定在myPointcut切入點(diǎn)應(yīng)用txAdvice事務(wù)增強(qiáng)處理 -->
  <aop:advisor advice-ref="txAdvice"
    pointcut-ref="myPointcut"/>
</aop:config>
</beans>

三 Struts配置

<?xml version="1.0" encoding="GBK"?>
<!-- 指定Struts 2配置文件的DTD信息 -->
<!DOCTYPE struts PUBLIC
  "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
  "http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
  <!-- 配置了系列常量 -->
  <constant name="struts.i18n.encoding" value="GBK"/>
  <constant name="struts.enable.DynamicMethodInvocation" value="false" />
  <constant name="struts.devMode" value="true"/>
  <package name="lee" extends="struts-default">
    <action name="addBook" class="org.crazyit.booksys.action.BookAction"
      method="add">
      <!-- 添加圖書成功,列出所有圖書 -->
      <result type="chain">listBooks</result>
      <!-- 添加圖書失敗,跳轉(zhuǎn)到添加圖書的表單頁 -->
      <result name="error">/WEB-INF/content/bookForm.jsp</result>
    </action>
    <action name="listBooks" class="org.crazyit.booksys.action.BookAction"
      method="list">
      <result>/WEB-INF/content/listBooks.jsp</result>
    </action>
    <action name="deleteBook" class="org.crazyit.booksys.action.BookAction"
      method="delete">
      <result type="chain">listBooks</result>
    </action>
    <!-- 讓用戶直接訪問該應(yīng)用時列出所有視圖頁面 -->
    <action name="*">
      <result>/WEB-INF/content/{1}.jsp</result>
    </action>
  </package>
</struts>

四 視圖

1 bookForm.jsp

<%@ page contentType="text/html; charset=GBK" language="java" errorPage="" %>
<%@taglib prefix="s" uri="/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>添加圖書</title>
</head>
<body>
<h3>添加圖書</h3>
<s:form action="addBook">
  <s:textfield name="book.name" label="書名"/>
  <s:textfield name="book.price" label="價格"/>
  <s:textfield name="book.author" label="作者"/>
  <tr align="center">
    <td colspan="2">
    <s:submit value="添加" theme="simple"/>
    <s:reset value="重設(shè)" theme="simple"/>
    </td>
  </tr>
</s:form>
</body>
</html>

2 listBooks.jsp

<%@ page contentType="text/html; charset=GBK" language="java" errorPage="" %>
<%@taglib prefix="s" uri="/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>全部圖書</title>
</head>
<body>
<h3>全部圖書</h3>
<table width="640" border="1">
  <s:iterator value="books" var="b">
    <tr>
      <td><s:property value="name"/></td>
      <td><s:property value="price"/></td>
      <td><s:property value="author"/></td>
      <td><a href="${pageContext.request.contextPath}/deleteBook?id=${b.id}" rel="external nofollow" >刪除</a></td>
    </tr>
  </s:iterator>
</table>
</body>
</html>

五 domain

package org.crazyit.booksys.domain;
import javax.persistence.*;
@Entity
@Table(name="book_inf")
public class Book
{
  @Id @Column(name="book_id")
  @GeneratedValue(strategy=GenerationType.IDENTITY)
  private Integer id;
  @Column(name="book_name")
  private String name;
  private double price;
  private String author;
  public Integer getId()
  {
    return id;
  }
  public void setId(Integer id)
  {
    this.id = id;
  }
  public String getName()
  {
    return name;
  }
  public void setName(String name)
  {
    this.name = name;
  }
  public double getPrice()
  {
    return price;
  }
  public void setPrice(double price)
  {
    this.price = price;
  }
  public String getAuthor()
  {
    return author;
  }
  public void setAuthor(String author)
  {
    this.author = author;
  }
}

六 action

package org.crazyit.booksys.action;
import java.util.List;
import org.crazyit.booksys.domain.Book;
import org.crazyit.booksys.service.BookService;
import com.opensymphony.xwork2.ActionSupport;
public class BookAction extends ActionSupport
{
  private BookService bookService;
  // 依賴注入BookService組件必須的setter方法。
  // 該方法的方法名要與BookService的配置id對應(yīng)
  public void setBookService(BookService bookService)
  {
    this.bookService = bookService;
  }
  private Book book;
  private List<Book> books;
  private int id;
  public Book getBook()
  {
    return book;
  }
  public void setBook(Book book)
  {
    this.book = book;
  }
  public List<Book> getBooks()
  {
    return books;
  }
  public void setBooks(List<Book> books)
  {
    this.books = books;
  }
  public int getId()
  {
    return id;
  }
  public void setId(int id)
  {
    this.id = id;
  }
  // 處理添加圖書的add()方法
  public String add()
  {
    // 調(diào)用業(yè)務(wù)邏輯組件的addBook()方法來處理用戶請求
    int result = bookService.addBook(book);
    if(result > 0)
    {
      addActionMessage("恭喜您,圖書添加成功!");
      return SUCCESS;
    }
    addActionError("圖書添加失敗,請重新輸入!");
    return ERROR;
  }
  public String list()
  {
    setBooks(bookService.getAllBooks());
    return SUCCESS;
  }
  public String delete()
  {
    bookService.deleteBook(id);
    return SUCCESS;
  }
}

七 service

1 BookService.java

package org.crazyit.booksys.service;
import java.util.List;
import org.crazyit.booksys.domain.Book;
public interface BookService
{
  // 添加圖書
  int addBook(Book book);
  List<Book> getAllBooks();
  void deleteBook(int id);
}

2 BookServiceImpl.java

package org.crazyit.booksys.service.impl;
import java.util.List;
import org.crazyit.booksys.dao.BookDao;
import org.crazyit.booksys.domain.Book;
import org.crazyit.booksys.service.BookService;
public class BookServiceImpl implements BookService
{
  private BookDao bookDao;
  public void setBookDao(BookDao bookDao)
  {
    this.bookDao = bookDao;
  }
  @Override
  public int addBook(Book book)
  {
    return (Integer) bookDao.save(book);
  }
  @Override
  public List<Book> getAllBooks()
  {
    return bookDao.findAll(Book.class);
  }
  @Override
  public void deleteBook(int id)
  {
    bookDao.delete(Book.class, id);
  }
}

八 dao

BaseDao.java

package org.crazyit.common.dao;
import java.util.List;
import java.io.Serializable;
public interface BaseDao<T>
{
  // 根據(jù)ID加載實(shí)體
  T get(Class<T> entityClazz , Serializable id);
  // 保存實(shí)體
  Serializable save(T entity);
  // 更新實(shí)體
  void update(T entity);
  // 刪除實(shí)體
  void delete(T entity);
  // 根據(jù)ID刪除實(shí)體
  void delete(Class<T> entityClazz , Serializable id);
  // 獲取所有實(shí)體
  List<T> findAll(Class<T> entityClazz);
  // 獲取實(shí)體總數(shù)
  long findCount(Class<T> entityClazz);
}

BaseDaoHibernate3.java

package org.crazyit.common.dao.impl;
import java.io.Serializable;
import java.util.List;
import org.crazyit.common.dao.BaseDao;
import org.hibernate.*;
import org.springframework.orm.hibernate4.support.HibernateDaoSupport;
import org.springframework.orm.hibernate4.HibernateCallback;
public class BaseDaoHibernate3<T> extends HibernateDaoSupport
  implements BaseDao<T>
{
  // 根據(jù)ID加載實(shí)體
  public T get(Class<T> entityClazz, Serializable id)
  {
    return getHibernateTemplate().get(entityClazz, id);
  }
  // 保存實(shí)體
  public Serializable save(T entity)
  {
    return getHibernateTemplate().save(entity);
  }
  // 更新實(shí)體
  public void update(T entity)
  {
    getHibernateTemplate().saveOrUpdate(entity);
  }
  // 刪除實(shí)體
  public void delete(T entity)
  {
    getHibernateTemplate().delete(entity);
  }
  // 根據(jù)ID刪除實(shí)體
  public void delete(Class<T> entityClazz, Serializable id)
  {
    delete(get(entityClazz , id));
  }
  @Override
  @SuppressWarnings("unchecked")
  public List<T> findAll(Class<T> entityClazz)
  {
    return (List<T>)getHibernateTemplate().find("select en from "
      + entityClazz.getSimpleName() + " en");
  }
  @Override
  @SuppressWarnings("unchecked")
  public long findCount(Class<T> entityClazz)
  {
    List<Long> list = (List<Long>)getHibernateTemplate().find(
      "select count(*) from " + entityClazz.getSimpleName() + " en");
    return list.get(0);
  }
  /**
   * 使用hql 語句進(jìn)行分頁查詢操作
   * @param hql 需要查詢的hql語句
   * @param pageNo 查詢第pageNo頁的記錄
   * @param pageSize 每頁需要顯示的記錄數(shù)
   * @return 當(dāng)前頁的所有記錄
   */
  @SuppressWarnings("unchecked")
  protected List<T> findByPage(final String hql,
    final int pageNo, final int pageSize)
  {
    // 通過一個HibernateCallback對象來執(zhí)行查詢
    List<T> list = getHibernateTemplate()
      .execute(new HibernateCallback<List<T>>()
    {
      // 實(shí)現(xiàn)HibernateCallback接口必須實(shí)現(xiàn)的方法
      public List<T> doInHibernate(Session session)
      {
        // 執(zhí)行Hibernate分頁查詢
        List<T> result = session.createQuery(hql)
          .setFirstResult((pageNo - 1) * pageSize)
          .setMaxResults(pageSize)
          .list();
        return result;
      }
    });
    return list;
  }
  /**
   * 使用hql 語句進(jìn)行分頁查詢操作
   * @param hql 需要查詢的hql語句
   * @param pageNo 查詢第pageNo頁的記錄
   * @param pageSize 每頁需要顯示的記錄數(shù)
   * @param params 如果hql帶占位符參數(shù),params用于傳入占位符參數(shù)
   * @return 當(dāng)前頁的所有記錄
   */
  @SuppressWarnings("unchecked")
  protected List<T> findByPage(final String hql , final int pageNo,
    final int pageSize , final Object... params)
  {
    // 通過一個HibernateCallback對象來執(zhí)行查詢
    List<T> list = getHibernateTemplate()
      .execute(new HibernateCallback<List<T>>()
    {
      // 實(shí)現(xiàn)HibernateCallback接口必須實(shí)現(xiàn)的方法
      public List<T> doInHibernate(Session session)
      {
        // 執(zhí)行Hibernate分頁查詢
        Query query = session.createQuery(hql);
        // 為包含占位符的HQL語句設(shè)置參數(shù)
        for(int i = 0 , len = params.length ; i < len ; i++)
        {
          query.setParameter(i + "" , params[i]);
        }
        List<T> result = query.setFirstResult((pageNo - 1) * pageSize)
          .setMaxResults(pageSize)
          .list();
        return result;
      }
    });
    return list;
  }
}

BaseDaoHibernate4.java

package org.crazyit.common.dao.impl;
import org.hibernate.*;
import java.util.List;
import java.io.Serializable;
import org.crazyit.common.dao.*;
public class BaseDaoHibernate4<T> implements BaseDao<T>
{
  // DAO組件進(jìn)行持久化操作底層依賴的SessionFactory組件
  private SessionFactory sessionFactory;
  // 依賴注入SessionFactory所需的setter方法
  public void setSessionFactory(SessionFactory sessionFactory)
  {
    this.sessionFactory = sessionFactory;
  }
  public SessionFactory getSessionFactory()
  {
    return this.sessionFactory;
  }
  // 根據(jù)ID加載實(shí)體
  @SuppressWarnings("unchecked")
  public T get(Class<T> entityClazz , Serializable id)
  {
    return (T)getSessionFactory().getCurrentSession()
      .get(entityClazz , id);
  }
  // 保存實(shí)體
  public Serializable save(T entity)
  {
    return getSessionFactory().getCurrentSession()
      .save(entity);
  }
  // 更新實(shí)體
  public void update(T entity)
  {
    getSessionFactory().getCurrentSession().saveOrUpdate(entity);
  }
  // 刪除實(shí)體
  public void delete(T entity)
  {
    getSessionFactory().getCurrentSession().delete(entity);
  }
  // 根據(jù)ID刪除實(shí)體
  public void delete(Class<T> entityClazz , Serializable id)
  {
    getSessionFactory().getCurrentSession()
      .createQuery("delete " + entityClazz.getSimpleName()
        + " en where en.id = ?0")
      .setParameter("0" , id)
      .executeUpdate();
  }
  // 獲取所有實(shí)體
  public List<T> findAll(Class<T> entityClazz)
  {
    return find("select en from "
      + entityClazz.getSimpleName() + " en");
  }
  // 獲取實(shí)體總數(shù)
  public long findCount(Class<T> entityClazz)
  {
    List<?> l = find("select count(*) from "
      + entityClazz.getSimpleName());
    // 返回查詢得到的實(shí)體總數(shù)
    if (l != null && l.size() == 1 )
    {
      return (Long)l.get(0);
    }
    return 0;
  }
  // 根據(jù)HQL語句查詢實(shí)體
  @SuppressWarnings("unchecked")
  protected List<T> find(String hql)
  {
    return (List<T>)getSessionFactory().getCurrentSession()
      .createQuery(hql)
      .list();
  }
  // 根據(jù)帶占位符參數(shù)HQL語句查詢實(shí)體
  @SuppressWarnings("unchecked")
  protected List<T> find(String hql , Object... params)
  {
    // 創(chuàng)建查詢
    Query query = getSessionFactory().getCurrentSession()
      .createQuery(hql);
    // 為包含占位符的HQL語句設(shè)置參數(shù)
    for(int i = 0 , len = params.length ; i < len ; i++)
    {
      query.setParameter(i + "" , params[i]);
    }
    return (List<T>)query.list();
  }
  /**
   * 使用hql 語句進(jìn)行分頁查詢操作
   * @param hql 需要查詢的hql語句
   * @param pageNo 查詢第pageNo頁的記錄
   * @param pageSize 每頁需要顯示的記錄數(shù)
   * @return 當(dāng)前頁的所有記錄
   */
  @SuppressWarnings("unchecked")
  protected List<T> findByPage(String hql,
     int pageNo, int pageSize)
  {
    // 創(chuàng)建查詢
    return getSessionFactory().getCurrentSession()
      .createQuery(hql)
      // 執(zhí)行分頁
      .setFirstResult((pageNo - 1) * pageSize)
      .setMaxResults(pageSize)
      .list();
  }
  /**
   * 使用hql 語句進(jìn)行分頁查詢操作
   * @param hql 需要查詢的hql語句
   * @param params 如果hql帶占位符參數(shù),params用于傳入占位符參數(shù)
   * @param pageNo 查詢第pageNo頁的記錄
   * @param pageSize 每頁需要顯示的記錄數(shù)
   * @return 當(dāng)前頁的所有記錄
   */
  @SuppressWarnings("unchecked")
  protected List<T> findByPage(String hql , int pageNo, int pageSize
    , Object... params)
  {
    // 創(chuàng)建查詢
    Query query = getSessionFactory().getCurrentSession()
      .createQuery(hql);
    // 為包含占位符的HQL語句設(shè)置參數(shù)
    for(int i = 0 , len = params.length ; i < len ; i++)
    {
      query.setParameter(i + "" , params[i]);
    }
    // 執(zhí)行分頁,并返回查詢結(jié)果
    return query.setFirstResult((pageNo - 1) * pageSize)
      .setMaxResults(pageSize)
      .list();
  }
}

BookDao.java

package org.crazyit.booksys.dao;
import java.util.List;
import org.crazyit.booksys.domain.Book;
import org.crazyit.common.dao.BaseDao;
public interface BookDao extends BaseDao<Book>
{
}

BookDaoHibernate4.java

package org.crazyit.booksys.dao.impl;
import java.util.List;
import org.crazyit.booksys.dao.BookDao;
import org.crazyit.booksys.domain.Book;
import org.crazyit.common.dao.impl.BaseDaoHibernate3;
import org.crazyit.common.dao.impl.BaseDaoHibernate4;
public class BookDaoHibernate4 extends BaseDaoHibernate4<Book>
  implements BookDao
{
}

九 測試

 

更多關(guān)于java相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Spring框架入門與進(jìn)階教程》、《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總

希望本文所述對大家java程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • 輕松掌握J(rèn)ava代理模式

    輕松掌握J(rèn)ava代理模式

    這篇文章主要幫助大家輕松掌握J(rèn)ava代理模式,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • Eclipse配置SVN的幾種方法及使用詳情

    Eclipse配置SVN的幾種方法及使用詳情

    這篇文章主要介紹了Eclipse配置SVN的幾種方法及使用詳情,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • Java Iterator迭代器_動力節(jié)點(diǎn)Java學(xué)院整理

    Java Iterator迭代器_動力節(jié)點(diǎn)Java學(xué)院整理

    迭代器是一種模式,它可以使得對于序列類型的數(shù)據(jù)結(jié)構(gòu)的遍歷行為與被遍歷的對象分離,接下來通過本文給大家分享Java Iterator迭代器_動力節(jié)點(diǎn)Java學(xué)院整理,需要的朋友參考下吧
    2017-05-05
  • mybatis?查詢返回Map<String,Object>類型

    mybatis?查詢返回Map<String,Object>類型

    本文主要介紹了mybatis?查詢返回Map<String,Object>類型,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • redis客戶端Jedis使用小結(jié)

    redis客戶端Jedis使用小結(jié)

    Jedis是Redis的一款Java語言的開源客戶端連接工具,本文主要介紹了redis客戶端Jedis使用,具有一定的參考價值,感興趣的可以了解一下
    2023-11-11
  • Java生成一定規(guī)則遞增編號的示例代碼

    Java生成一定規(guī)則遞增編號的示例代碼

    項(xiàng)目需求中有時需要生成一定規(guī)則遞增編號,本文主要介紹了Java生成一定規(guī)則遞增編的示例代碼,具有一定的參考價值,感興趣的可以了解一下
    2023-08-08
  • springboot中bean的加載順序問題

    springboot中bean的加載順序問題

    這篇文章主要介紹了springboot中bean的加載順序問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • java線程池詳解及代碼介紹

    java線程池詳解及代碼介紹

    這篇文章主要介紹了java中線程池的示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-08-08
  • 詳解Java中Collection集合的常用方法

    詳解Java中Collection集合的常用方法

    本篇文章給大家?guī)淼膬?nèi)容是關(guān)于Java中Collection集合的常用方法詳解,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。下面我們就來學(xué)習(xí)一下吧
    2021-11-11
  • JavaWeb文件上傳下載功能示例解析

    JavaWeb文件上傳下載功能示例解析

    這篇文章主要介紹了JavaWeb中的文件上傳和下載功能的實(shí)現(xiàn),文件上傳和下載功能是非常常用的功能,需要的朋友可以參考下
    2016-06-06

最新評論