IDEA+maven+SpringBoot+JPA+Thymeleaf Crud 및 페이지 나 누 기
13443 단어 IDEAmavenSpringBootJPAThymeleaf
1.windows 7 기업 판
2、IDEA 14
3、JDK 1.8
4、Maven 3.5.2
5、MariaDB
6、SQLYog
2.Maven 설정:
Maven 디 렉 터 리 에 있 는 conf 디 렉 터 리 에 있 는 settings.xml 는 다음 과 같은 내용 을 추가 합 니 다.
1.아 리 운 의 창 고 를 사용 하면 홈 페이지 방문 속도 보다 훨씬 빠 릅 니 다.
<mirror>
<id>nexus-aliyun</id>
<mirrorOf>central</mirrorOf>
<name>Nexus aliyun</name>
<url>http://maven.aliyun.com/nexus/content/groups/public</url>
</mirror>
2.전역 JDK 설정
<!-- jdk ,settings.xml -->
<profile>
<id>jdk18</id>
<activation>
<activeByDefault>true</activeByDefault>
<jdk>1.8</jdk>
</activation>
<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>
</properties>
</profile>
3.IDEA 기본 설정:1.Maven 설정:Maven 디 렉 터 리 를 선택 하고 파일 과 로 컬 창 고 를 설정 합 니 다.
2.문자 인 코딩 설정
4.IDEA 를 사용 하여 Maven 프로젝트 를 만 듭 니 다.
Enable Auto-import 를 선택 하 십시오.만 든 프로젝트 디 렉 터 리 는 다음 과 같 습 니 다.
5.SpringBoot 와 JPA 를 결합 한 빠 른 개발 체험
1、pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cn.temptation</groupId>
<artifactId>studySpringBoot</artifactId>
<version>1.0-SNAPSHOT</version>
<!-- spring boot -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.0.RELEASE</version>
</parent>
<dependencies>
<!-- web -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- thymeleaf -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<!-- mysql-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.21</version>
</dependency>
<!-- jpa-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
</dependencies>
</project>
2.resources 디 렉 터 리 에 새 application.properties(물론 Yml 를 사용 하 는 것 을 좋아 합 니 다.Yml 를 사용 할 수 있 습 니 다)
#
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/test
spring.datasource.username=root
spring.datasource.password=sa
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
# JPA
spring.jpa.properties.hibernate.hbm2ddl.auto=update
3.SpringBoot 프로그램 시작 클래스 Springbootapplication.java 만 들 기
package cn.temptation;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class SpringbootApplication {
public static void main(String[] args) {
// SpringBoot
SpringApplication.run(SpringbootApplication.class, args);
}
}
4.실체 클래스 Category.java 만 들 기
package cn.temptation.model;
import javax.persistence.*;
//
//DROP TABLE category;
//
//CREATE TABLE category
//(
// categoryid INT AUTO_INCREMENT PRIMARY KEY,
// categoryname VARCHAR(10) NOT NULL
//);
//
//INSERT INTO category VALUES(NULL, ' '), (NULL, ' '), (NULL, ' '), (NULL, ' ');
//
//SELECT * FROM category;
@Entity
@Table(name = "category")
public class Category {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "categoryid")
private Integer categoryid;
@Column(name = "categoryname")
private String categoryname;
public Integer getCategoryid() {
return categoryid;
}
public void setCategoryid(Integer categoryid) {
this.categoryid = categoryid;
}
public String getCategoryname() {
return categoryname;
}
public void setCategoryname(String categoryname) {
this.categoryname = categoryname;
}
}
5,DAO 인터페이스 만 들 기 CategoryDao.java
package cn.temptation.dao;
import cn.temptation.model.Category;
import org.springframework.data.jpa.repository.JpaRepository;
public interface CategoryDao extends JpaRepository<Category, Integer> {
}
6.컨트롤 러 클래스 CategoryController.java 만 들 기
package cn.temptation.web;
import cn.temptation.dao.CategoryDao;
import cn.temptation.model.Category;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.servlet.ModelAndView;
import java.util.List;
@Controller
public class CategoryController {
@Autowired
private CategoryDao categoryDao;
/**
*
*
* @return
*/
// @RequestMapping("/categorylist")
// public ModelAndView categorylist() {
// List<Category> list = categoryDao.findAll();
//
// ModelAndView mav = new ModelAndView("categorylist");
// mav.addObject("list", list);
// return mav;
// }
/**
*
*
* @return
*/
@RequestMapping("/categorylist")
public ModelAndView categorylist(@RequestParam(value = "start", defaultValue = "0") Integer start,
@RequestParam(value = "limit", defaultValue = "2") Integer limit) {
start = start < 0 ? 0 : start;
Sort sort = new Sort(Sort.DEFAULT_DIRECTION, "categoryid");
Pageable pageable = new PageRequest(start, limit, sort);
Page<Category> page = categoryDao.findAll(pageable);
// System.out.println(page.getNumber());
// System.out.println(page.getNumberOfElements());
// System.out.println(page.getSize());
// System.out.println(page.getTotalElements());
// System.out.println(page.getTotalPages());
// System.out.println(page.isFirst());
// System.out.println(page.isLast());
ModelAndView mav = new ModelAndView("categorylist");
mav.addObject("page", page);
return mav;
}
/**
*
* @return
*/
@RequestMapping("/categoryinit")
public String categoryinit() {
return "categoryinit";
}
/**
*
* @param model
* @return
*/
@RequestMapping("/categoryinsert")
public String categoryinsert(Category model) {
categoryDao.save(model);
return "redirect:categorylist";
}
/**
*
* @param categoryid
* @return
*/
@RequestMapping("/categorydelete")
public String categorydelete(Integer categoryid) {
categoryDao.deleteById(categoryid);
return "redirect:categorylist";
}
/**
*
* @param categoryid
* @return
*/
@RequestMapping("/categoryedit")
public ModelAndView categoryedit(Integer categoryid) {
Category model = categoryDao.getOne(categoryid);
ModelAndView mav = new ModelAndView("categoryedit");
mav.addObject("category", model);
return mav;
}
/**
*
* @param model
* @return
*/
@RequestMapping("/categoryupdate")
public String categoryupdate(Category model) {
categoryDao.save(model);
return "redirect:categorylist";
}
}
7.resources 디 렉 터 리 에 새 templates 디 렉 터 리 를 만 들 고 표현 층 을 만 듭 니 다.카 테 고리 목록 페이지(category list.html),카 테 고리 추가 페이지(category init.html),카 테 고리 편집 페이지(category edit.html)카 테 고리 목록 페이지(categorist.html)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title> </title>
<style>
table, th, td {
border: 1px solid green;
border-collapse: collapse;
}
</style>
</head>
<body>
<a th:href="@{/categoryinit}"> </a>
<table>
<tr>
<th> </th>
<th> </th>
<th> </th>
</tr>
<!-- -->
<!--<tr th:each="item : ${list}">-->
<!-- -->
<tr th:each="item : ${page.content}">
<td th:text="${item.categoryid}"> </td>
<td th:text="${item.categoryname}"> </td>
<td>
<a th:href="@{/categoryedit(categoryid=${item.categoryid})}"> </a>
<a th:href="@{/categorydelete(categoryid=${item.categoryid})}"> </a>
</td>
</tr>
</table>
<div>
<a th:href="@{/categorylist(start=0)}">[ ]</a>
<a th:if="${not page.isFirst()}" th:href="@{/categorylist(start=${page.number-1})}">[ ]</a>
<a th:if="${not page.isLast()}" th:href="@{/categorylist(start=${page.number+1})}">[ ]</a>
<a th:href="@{/categorylist(start=${page.totalPages-1})}">[ ]</a>
</div>
</body>
</html>
카 테 고리 추가 페이지(categority init.html)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title> </title>
</head>
<body>
<form action="categoryinsert" method="post">
<label for="txtCategoryname"> :</label>
<input type="text" id="txtCategoryname" name="categoryname" /><br/>
<input type="submit" value=" ">
</form>
</body>
</html>
카 테 고리 편집 페이지(category edit.html)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title> </title>
</head>
<body>
<form action="categoryupdate" method="post">
<input type="hidden" id="txtCategoryid" name="categoryid" th:field="${category.categoryid}"/><br/>
<label for="txtCategoryname"> :</label>
<input type="text" id="txtCategoryname" name="categoryname" th:field="${category.categoryname}"/><br/>
<input type="submit" value=" ">
</form>
</body>
</html>
6.시작 항목,실행 효 과 는 다음 과 같 습 니 다.총결산
위 에서 말씀 드 린 것 은 편집장 님 께 서 소개 해 주신 IDEA+maven+SpringBoot+JPA+Thymeleaf 가 Crud 와 페이지 를 실현 하 는 데 도움 이 되 기 를 바 랍 니 다.궁금 한 점 이 있 으 시 면 메 시 지 를 남 겨 주세요.편집장 님 께 서 바로 답 해 드 리 겠 습 니 다.여기 서도 저희 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
IDEA 수정 toString 메서드 템플릿은 JSON 형식입니다.1. toString 방법 설정 인터페이스 열기 코드에서 Generate를 오른쪽 단추로 선택한 다음 toString () 을 선택하십시오.단축키도 사용할 수 있습니다. 윈도우즈 아래는 Alt + Insert, 맥 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.