jpa操作数据库
注意:数据库采用的是本机数据库,下面是建表语句及初始化数据:
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for user
-- ----------------------------
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
`id` bigint(0) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
`dpt_id` bigint(0) NULL DEFAULT NULL COMMENT '部门id',
`name` varchar(30) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '姓名',
`age` int(0) NULL DEFAULT NULL COMMENT '年龄',
`email` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '邮箱',
`head_img` varchar(200) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '头像',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 0 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '用户类' ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES (1, 1, 'Jone', 18, 'test1@baomidou.com', 'e');
INSERT INTO `user` VALUES (2, 1, 'Jack', 20, 'test2@baomidou.com', 'd');
INSERT INTO `user` VALUES (3, 1, 'Tom', 28, 'test3@baomidou.com', 'c');
INSERT INTO `user` VALUES (4, 1, 'Sandy', 21, 'test4@baomidou.com', 'b');
INSERT INTO `user` VALUES (5, 1, 'Billie', 24, 'test5@baomidou.com', 'a');
SET FOREIGN_KEY_CHECKS = 1;复制
在idea中配置数据源:idea-->view-->tool windows-->database

<!--springboot web依赖-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<!--springboot 操作数据库使用jpa的依赖-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--mysql数据库连接驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!--lombok 一款神器,后面专题介绍-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>复制
spring:
datasource:
url: jdbc:mysql://localhost:3306/demo?charset=UTF-8&serverTimezone=GMT%2B8
username: root
password: 123456
driver-class-name: com.mysql.cj.jdbc.Driver复制

user
代码:
@Entity//标识这个是一个与数据库表对应的entity类
@Data//lombok神器的一个注解,后面专题介绍
@Table ( name ="user" )//这个类是与数据库的哪个表对应的
public class User implements Serializable {
private static final long serialVersionUID = 829933141479418804L;
/**
* 主键ID
*/
@Id//这个字段是数据库表的主键
@Column(name = "id" )//这个属性对应表的哪个字段
@GeneratedValue(strategy= GenerationType.IDENTITY)//主键采用数据库自增方式
private Long id;
/**
* 部门id
*/
@Column(name = "dpt_id" )
private Long dptId;
/**
* 姓名
*/
@Column(name = "name" )
private String name;
/**
* 年龄
*/
@Column(name = "age" )
private Long age;
/**
* 邮箱
*/
@Column(name = "email" )
private String email;
/**
* 头像
*/
@Column(name = "head_img" )
private String headImg;
}复制
@GeneratedValue
注解的strategy属性提供四种值:
–AUTO:主键由程序控制,是默认选项,不设置即此项。 –IDENTITY:主键由数据库自动生成,即采用数据库ID自增长的方式,Oracle不支持这种方式。 –SEQUENCE:通过数据库的序列产生主键,通过@SequenceGenerator 注解指定序列名,mysql不支持这种方式。 –TABLE:通过特定的数据库表产生主键,使用该策略可以使应用更易于数据库移植。
userJpa
代码:
@Repository//表示这个是一个操作数据库的Repository类
public interface UserJpa extends JpaRepository<User,Long> {
}复制
userController
代码:
@RestController
@RequestMapping("user")
public class UserController {
@Resource
private UserJpa userJpa;
@GetMapping("findAll")//查找所有数据
public List<User> findAll(){
return this.userJpa.findAll();
}
@GetMapping("get")//按主键查找数据
public User get(@RequestParam("id")Long id){
return this.userJpa.findById(id).get();
}
}复制


https://javawu.com/archives/2737
重磅!Java纯交流群(无广告)已成立
在群里和大家分享一些Java开发相关的知识,包括部分自己的实战项目,基础入门知识,spring,jvm,mysql等等。也会免费分享一些Java视频教程、电子资料、Mysql资料、Kubernetes及最新Java面试资料。
同时为了帮助到其他技术栈 小伙伴,我也准备了一些Python,前端,Linux,C语言等其他技术资料!
有兴趣入群的同学,可长按扫描下方二维码添
一定要备注:Java,可更快被通过且邀请进群
文章转载自Java实验室,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【专家有话说第五期】在不同年龄段,DBA应该怎样规划自己的职业发展?
墨天轮编辑部
1409次阅读
2025-03-13 11:40:53
MySQL8.0统计信息总结
闫建(Rock Yan)
534次阅读
2025-03-17 16:04:03
2月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
488次阅读
2025-03-13 14:38:19
SQL优化 - explain查看SQL执行计划(一)
金同学
419次阅读
2025-03-13 16:04:22
MySQL突然崩溃?教你用gdb解剖core文件,快速锁定“元凶”!
szrsu
412次阅读
2025-03-13 00:29:43
MySQL生产实战优化(利用Index skip scan优化性能提升257倍)
chengang
362次阅读
2025-03-17 10:36:40
MySQL数据库当前和历史事务分析
听见风的声音
337次阅读
2025-04-01 08:47:17
MySQL 生产实践-Update 二级索引导致的性能问题排查
chengang
298次阅读
2025-03-28 16:28:31
墨天轮个人数说知识点合集
JiekeXu
290次阅读
2025-04-01 15:56:03
一键装库脚本3分钟极速部署,传统耗时砍掉95%!
IT邦德
281次阅读
2025-03-10 07:58:44