gpt4 book ai didi

IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 28 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

1、开发环境:

1、windows 7 企业版 。

2、idea 14 。

3、jdk 1.8 。

4、maven 3.5.2 。

5、mariadb 。

6、sqlyog 。

IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页

2、maven设置:

maven目录下的conf目录下的settings.xml做如下内容的添加:

1、使用阿里云的仓库,比官网访问速度快很多 。

?
1
2
3
4
5
6
<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配置 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
<!-- 全局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目录,同时配置文件和本地仓库 。

IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页

2、字符编码设置 。

IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页

4、使用idea创建maven工程:

IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页

IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页

IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页

IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页

选择enable auto-import,创建好的工程目录如下图:

IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页

5、体验springboot结合jpa的快速开发吧 。

1、pom.xml 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
<?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(当然喜欢用yaml的可以用yaml) 。

?
1
2
3
4
5
6
7
# 数据库连接
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 。

?
1
2
3
4
5
6
7
8
9
10
11
12
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 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
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 。

?
1
2
3
4
5
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 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
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目录,创建表现层:类别列表页面(categorylist.html)、类别新增页面(categoryinit.html)、类别编辑页面(categoryedit.html) 。

类别列表页面(categorylist.html) 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
<!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>

类别新增页面(categoryinit.html) 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<!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>

类别编辑页面(categoryedit.html) 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<!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及分页

总结 。

以上所述是小编给大家介绍的idea+maven+springboot+jpa+thymeleaf实现crud及分页,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我网站的支持! 。

原文链接:https://www.cnblogs.com/iflytek/p/8526182.html 。

最后此篇关于IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页的文章就讲到这里了,如果你想了解更多关于IDEA+maven+SpringBoot+JPA+Thymeleaf实现Crud及分页的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com