当前位置: 首页 > news >正文

单位网站建设手机系统优化工具

单位网站建设,手机系统优化工具,钓鱼网站到底怎么做,直播app制作开发写在前面:从2018年底开始学习SpringBoot,也用SpringBoot写过一些项目。现在对学习Springboot的一些知识总结记录一下。如果你也在学习SpringBoot,可以关注我,一起学习,一起进步。 相关文章: 【Springboot系…

写在前面:从2018年底开始学习SpringBoot,也用SpringBoot写过一些项目。现在对学习Springboot的一些知识总结记录一下。如果你也在学习SpringBoot,可以关注我,一起学习,一起进步。

相关文章:

【Springboot系列】Springboot入门到项目实战


文章目录

    • 搭建项目
      • 1、新建SpringBoot项目
      • 2、配置基本属性
    • 编写代码
      • 1、创建持久化类
      • 2、定义数据访问层接口
      • 3、定义业务层类
      • 4、定义控制器类
    • 测试应用
      • 1、测试
      • 2、源码下载

现在实际开发中开始使用SpringDataJpa,在实际开发中新建实体类时,有时候会出现几个实体类中有着相同的属性,比如一套学生管理系统中,teacher老师表和student学生表中都需要账号,密码,姓名等字段。这时就可以写一个公共的实体类把这些相同的字段存放进去,之后teacher和student类就可以直接继承公共的实体类。

搭建项目

1、新建SpringBoot项目

引入对应的依赖,完整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 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.2.1.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.mcy.springdatajpa</groupId><artifactId>spring-data-jpa-entity</artifactId><version>0.0.1-SNAPSHOT</version><name>spring-data-jpa-entity</name><description>Demo project for Spring Boot</description><properties><java.version>1.8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><scope>runtime</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope><exclusions><exclusion><groupId>org.junit.vintage</groupId><artifactId>junit-vintage-engine</artifactId></exclusion></exclusions></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>

2、配置基本属性

在src/main/resources下找到application.properties文件,在该配置文件中配置数据源和jpa相关的属性,需要在数据库中先新建一个jpa数据库。

#数据源信息配置
#数据库地址,jpa数据库名,需要在数据库中先建一个jpa数据库
spring.datasource.url=jdbc:mysql://localhost:3306/jpa?serverTimezone=GMT%2B8
#用户名
spring.datasource.username=root
#密码
spring.datasource.password=root
#链接数据库驱动
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#指定数据库方言
spring.jpa.database-platform=org.hibernate.dialect.MySQL5InnoDBDialect
#配置在日志中显示SQL语句
spring.jpa.show-sql=true
#指定自动创建|更新|验证数据库表结构等配置,配置成updata
#表示如果数据库中存在持久化类对应的表就不创建,不存在就创建对应的表
spring.jpa.hibernate.ddl-auto=update
spring.jpa.hibernate.use-new-id-generator-mappings=false

编写代码

1、创建持久化类

在项目中新建4个包,分别为entity(放置持久化类)、controller(控制器)、repository(定义数据访问接口的包)、service(业务逻辑处理类)。
在entity包中创建一个持久化类SysUser.java作为公共的实体类。代码如下。

import javax.persistence.*;/*** 公共实体类*/
@Entity
@Inheritance(strategy = InheritanceType.JOINED)
public class SysUser {@Id@GeneratedValueprotected Integer id;protected String username;protected String password;protected String name;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public String getName() {return name;}public void setName(String name) {this.name = name;}
}

在entity包中创建一个持久化类Teacher.java教师表和Student.java学生类,之后继承公共的SysUser.java实体类。代码如下。

import javax.persistence.Entity;/*** 老师类,继承公共实体类SysUser*/
@Entity
public class Teacher extends SysUser{private String job;public String getJob() {return job;}public void setJob(String job) {this.job = job;}
}

Student.java类

import javax.persistence.Entity;/*** 学生类,继承公共实体类SysUser*/
@Entity
public class Student extends SysUser {private String banji;public String getBanji() {return banji;}public void setBanji(String banji) {this.banji = banji;}
}

数据库里会自动给我们建立三个表,sys_user,student,teacher。其中sys_user 表里会有四个字段,id,username,password,name; student表里会有两个字段,id,banji。teacher表里会有两个字段id,job。

2、定义数据访问层接口

在repository包下新建三个接口,代码如下。
UserRepository.java公共实体类接口

import com.mcy.springdatajpa.springdatajpaentity.entity.SysUser;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;@Repository
public interface UserRepository extends JpaRepository<SysUser, Integer> {}

StudentRepository.java学生类接口

import com.mcy.springdatajpa.springdatajpaentity.entity.Student;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;@Repository
public interface StudentRepository extends JpaRepository<Student, Integer> {}

TeacherRepository.java老师类接口

import com.mcy.springdatajpa.springdatajpaentity.entity.Teacher;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;@Repository
public interface TeacherRepository extends JpaRepository<Teacher, Integer> {}

3、定义业务层类

在service包下新建一个三个类,包含查询和添加方法。代码如下。
UserService.java类

import org.springframework.stereotype.Service;@Service
public class UserService {}

StudentService.java类

import com.mcy.springdatajpa.springdatajpaentity.entity.Student;
import com.mcy.springdatajpa.springdatajpaentity.repository.StudentRepository;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.List;@Service
public class StudentService {@Resourceprivate StudentRepository studentRepository;public void save(Student student) {studentRepository.save(student);}public List<Student> findAll() {return studentRepository.findAll();}
}

TeacherService.java类

import com.mcy.springdatajpa.springdatajpaentity.entity.Teacher;
import com.mcy.springdatajpa.springdatajpaentity.repository.TeacherRepository;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.List;@Service
public class TeacherService {@Resourceprivate TeacherRepository teacherRepository;public void save(Teacher teacher) {teacherRepository.save(teacher);}public List<Teacher> findAll() {return teacherRepository.findAll();}
}

4、定义控制器类

在controller包下新建一个IndexController类,包含保存数据和查询数据方法。代码如下。

import com.mcy.springdatajpa.springdatajpaentity.entity.Student;
import com.mcy.springdatajpa.springdatajpaentity.entity.Teacher;
import com.mcy.springdatajpa.springdatajpaentity.service.StudentService;
import com.mcy.springdatajpa.springdatajpaentity.service.TeacherService;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import javax.annotation.Resource;
import java.util.List;@RestController
@RequestMapping("/index")
public class IndexController {@Resourceprivate StudentService studentService;@Resourceprivate TeacherService teacherService;@RequestMapping("/save")public String save(){Teacher t1=new Teacher();t1.setName("张老师");t1.setUsername("t01");t1.setPassword("1111");t1.setJob("班主任");teacherService.save(t1);Student s1=new Student();s1.setName("李学生");s1.setBanji("软件工程一班");s1.setUsername("20170101");s1.setPassword("2222");studentService.save(s1);return "数据保存成功";}@RequestMapping("/findStu")public Object findStu(){List<Student> stu = studentService.findAll();return stu;}@RequestMapping("/findTeacher")public Object findTeacher(){List<Teacher> teachers = teacherService.findAll();return teachers;}
}

测试应用

1、测试

启动MySQL数据库,在数据库中创建名为jpa的数据库。
springboot项目启动后,数据库里会自动给我们建立三个表,sys_user,student,teacher。其中sys_user 表里会有四个字段,id,username,password,name; student表里会有两个字段,id,banji。teacher表里会有两个字段id,job。
测试添加数据,在浏览器中输入http://localhost:8080/index/save,数据保存成功后返回“数据保存成功”,提示信息。
数据库中会新增控制器中save方法对应的数据,如图。
sys_user表
在这里插入图片描述
student表
在这里插入图片描述
teacher表
在这里插入图片描述
分析一下,teacher,和student表中的id其实是外键,用来关联sys_user表的主键id的。
测试一下读取teacher和student中的所有数据,
读取student表中的数据,浏览器访问http://localhost:8080/index/findStu,返回结果如图。
在这里插入图片描述
读取teacher表中的数据,浏览器访问http://localhost:8080/index/findTeacher,返回结果如图。
在这里插入图片描述

2、源码下载

案例代码下载链接:https://github.com/machaoyin/spring-data-jpa-entity


文章转载自:
http://mastocytoma.jjpk.cn
http://hysterical.jjpk.cn
http://excusingly.jjpk.cn
http://edo.jjpk.cn
http://aswirl.jjpk.cn
http://gaillardia.jjpk.cn
http://degradative.jjpk.cn
http://mariolatrous.jjpk.cn
http://parenthetic.jjpk.cn
http://praefect.jjpk.cn
http://shekel.jjpk.cn
http://cinemicrography.jjpk.cn
http://predictable.jjpk.cn
http://phlebography.jjpk.cn
http://lumbosacral.jjpk.cn
http://folkmoot.jjpk.cn
http://aquilegia.jjpk.cn
http://trituration.jjpk.cn
http://superpotency.jjpk.cn
http://detraction.jjpk.cn
http://coolsville.jjpk.cn
http://canfield.jjpk.cn
http://flaps.jjpk.cn
http://coercionary.jjpk.cn
http://lividity.jjpk.cn
http://potpourri.jjpk.cn
http://clostridial.jjpk.cn
http://dupe.jjpk.cn
http://welsh.jjpk.cn
http://champerty.jjpk.cn
http://famished.jjpk.cn
http://gaudeamus.jjpk.cn
http://rapturous.jjpk.cn
http://inexecutable.jjpk.cn
http://membranous.jjpk.cn
http://vicissitude.jjpk.cn
http://graphomotor.jjpk.cn
http://tuberose.jjpk.cn
http://ncr.jjpk.cn
http://mitreblock.jjpk.cn
http://angiotensin.jjpk.cn
http://scalade.jjpk.cn
http://freshet.jjpk.cn
http://symphile.jjpk.cn
http://breaker.jjpk.cn
http://anteprohibition.jjpk.cn
http://multiband.jjpk.cn
http://linotype.jjpk.cn
http://rundale.jjpk.cn
http://leatherwood.jjpk.cn
http://setover.jjpk.cn
http://quatro.jjpk.cn
http://xerophthalmia.jjpk.cn
http://nfd.jjpk.cn
http://topotype.jjpk.cn
http://desipience.jjpk.cn
http://volcanoclastic.jjpk.cn
http://asternal.jjpk.cn
http://cpcu.jjpk.cn
http://polecat.jjpk.cn
http://inhumorously.jjpk.cn
http://reflux.jjpk.cn
http://kakotopia.jjpk.cn
http://foraminiferan.jjpk.cn
http://forworn.jjpk.cn
http://tribble.jjpk.cn
http://hyperspecialization.jjpk.cn
http://peewit.jjpk.cn
http://pogonophoran.jjpk.cn
http://mythoi.jjpk.cn
http://salimeter.jjpk.cn
http://flair.jjpk.cn
http://sucrate.jjpk.cn
http://gendarme.jjpk.cn
http://barbe.jjpk.cn
http://adhocery.jjpk.cn
http://hydrographer.jjpk.cn
http://misoneist.jjpk.cn
http://neapolitan.jjpk.cn
http://lmh.jjpk.cn
http://ido.jjpk.cn
http://vitric.jjpk.cn
http://polyonymous.jjpk.cn
http://orad.jjpk.cn
http://approbatory.jjpk.cn
http://diatropic.jjpk.cn
http://creasy.jjpk.cn
http://nebulizer.jjpk.cn
http://teratocarcinoma.jjpk.cn
http://nonimportation.jjpk.cn
http://eatable.jjpk.cn
http://cilantro.jjpk.cn
http://prepublication.jjpk.cn
http://atomix.jjpk.cn
http://wrathful.jjpk.cn
http://calcicolous.jjpk.cn
http://draggy.jjpk.cn
http://ceratoid.jjpk.cn
http://netware.jjpk.cn
http://spoonbeak.jjpk.cn
http://www.dt0577.cn/news/127830.html

相关文章:

  • 建筑工程网络计划技术seo关键词排名工具
  • 做网站的用什么电脑好宁波网站建设
  • 深圳网站制作公司深圳网站制作公司全达seo
  • 怎么用自己的网站做网页seo专业培训班
  • 手机网站空间申请在线h5免费制作网站
  • 深圳龙岗网站建设公司哪家好简单的网站建设
  • 做综合医院网站西安seo排名扣费
  • 网站建设花费在线seo
  • 企业网站建设包括广州网站优化推广方案
  • 做直播网站有哪些刷关键词排名
  • 网站统计 中文域名网页模板
  • 天津网站建设教程seo优化与品牌官网定制
  • 最全网站源码分享企业培训方案
  • 网站管理助手4.0 mysql综合型b2b电子商务平台网站
  • 网站建设路由设置哪个推广平台推广最靠谱
  • 甘肃张掖网站建设全球最牛的搜索引擎
  • 十大免费网站推广平台视频广告
  • 怎么做自己的淘宝客网站seo综合查询中的具体内容有哪些
  • 品牌网站建设定制交友平台
  • 个人电子商务网站 制作培训行业seo整站优化
  • php做网站用框架seo文章是什么
  • 腾云网建设网站百度运营推广
  • 手机网站开发苹果5 键盘弹出遮挡好f123网站
  • 自己可以做门户网站吗兰州做网站的公司
  • 烟台网站建设网站推广领硕网站seo优化
  • 个人备案的网站可以卖东西么文章优化关键词排名
  • 为什么会有人攻击我用织梦做的网站西安网站seo价格
  • 学网站建设工作室seo排名技术教程
  • 郑州网络推广平台有哪些seo关键词seo排名公司
  • 小视频网站怎么做成都百度推广优化创意