IDEA 2024版创建第一个spring boot项目(末尾会分享jdk1.8安装包)+实现MySQl数据库的的增删改查
对于,新手来说我更加推荐下面这种,直接在test代码里面进行测试(注意:不用一次性都执行,不用进行测试的部分可以先打上注释)这里面主要是数据库地配置:里面地spring,是链接地spring里面地spring(千万别弄错了!首先,打开我们的IDEA 2024(专业版),打开文件->新建->项目;数据库地配置(MySQL,navicat);
·
首先,打开我们的IDEA 2024(专业版),打开文件->新建->项目;

接着,创建我们的spring boot 项目,左边边框里面选择spring boot ,右边跟着我的框框进行更改:

创建好了之后,记得更改自己的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>
<groupId>com</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo</name>
<description>demo</description>
<properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<spring-boot.version>2.6.13</spring-boot.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.3.2</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.24</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.23</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${spring-boot.version}</version>
<configuration>
<mainClass>com.example.demo.DemoApplication</mainClass>
<skip>true</skip>
</configuration>
<executions>
<execution>
<id>repackage</id>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
这是文章的创建结构:
首先,创建一个User类:
package com.example.demo.entity;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
@TableName("tb_user")//配置该实体类对于数据中的数据表,如果类名和表名一样,可以不用配置
public class User {
private Long id;
private String userName;
private String password;
private String name;
private Integer age;
private String email;
}
创建自己的UserMapper代码:
package com.example.demo.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.demo.entity.User;
import org.apache.ibatis.annotations.Mapper;
@Mapper
public interface UserMapper extends BaseMapper<User> {
//查询一条记录
int selectById(User id);
// 插入一条记录
int insert(User entity);
//删除一条记录
int deleteById(User id);
//更新一条记录,根据主键id来更新,遵循传入对象成员变量值为null则不修改对应数据库字段的规则
//int updateById(User id);
}
其实这里有两个方法用于测试,一种是在service层写一些测试方法,然后在test的里面进行调用:
package com.example.demo.service;
import com.example.demo.entity.User;
import com.example.demo.mapper.UserMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
public void addUser(User user) {
// User user = new User();
user.setName("John Doe");
user.setEmail("john.doe@example.com");
try {
int rows = userMapper.insert(user);
if (rows > 0) {
System.out.println("User inserted successfully. Inserted row count: " + rows);
} else {
System.out.println("Failed to insert user. No rows affected.");
}
} catch (Exception e) {
System.out.println("Error inserting user: " + e.getMessage());
}
}
}
对于,新手来说我更加推荐下面这种,直接在test代码里面进行测试(注意:不用一次性都执行,不用进行测试的部分可以先打上注释)
package com.example.demo;
import com.example.demo.entity.User;
import com.example.demo.mapper.UserMapper;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
class DemoApplicationTests {
@Autowired
private UserMapper userMapper;
@Test
public void test01(){
User user = userMapper.selectById(2L);
System.out.println(user);
}
// @Test
// public void test02() {
// User user = User.builder()
// .userName("hhh")
// .email("153@qq.com")
// .age(18)
// .name("a")
// .password("123")
// .build();
// int insert = userMapper.insert(user);
// System.out.println(insert);
// }
// @Test
// public void test03(){
// int user = userMapper.deleteById(1L);
// System.out.println(user);
// }
// @Test
// public void test04(){
// User user=User.builder()
// .id(2L)
// .password("1277")
// .build();
// //根据主键id来修改数据库的信息,如果这个对象的成员变量值为null,就不修改数据库的字段名
// int i = userMapper.updateById(user);
// System.out.println(i);
// }
}
还有最重要的:application.yml代码(用于数据库地链接):
#配置数据源
spring:
datasource:
username: root
password: dlm1234
url: jdbc:mysql://localhost:3306/spring?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC&useSSL=false
driver-class-name: com.mysql.cj.jdbc.Driver
## 设置mp运行时行为
#mybatis-plus:
# configuration:
# log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

这里面主要是数据库地配置:里面地spring,是链接地spring里面地spring(千万别弄错了!):
数据库地准备:
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for tb_user 没有给自增
-- ----------------------------
DROP TABLE IF EXISTS `tb_user`;
CREATE TABLE `tb_user` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`user_name` varchar(255) DEFAULT NULL,
`password` varchar(255) DEFAULT NULL,
`name` varchar(255) DEFAULT NULL,
`age` int(11) DEFAULT NULL,
`email` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
-- ----------------------------
-- Records of tb_user
-- ----------------------------
BEGIN;
INSERT INTO `tb_user` VALUES (1, '赵一伤', '123456', 'zys', 19, 'zys@itcast.cn');
INSERT INTO `tb_user` VALUES (2, '钱二败', '123456', 'qes', 18, 'qes@itcast.cn');
INSERT INTO `tb_user` VALUES (3, '孙三毁', '123456', 'ssh', 20, 'ssh@itcast.cn');
INSERT INTO `tb_user` VALUES (4, '李四摧', '123456', 'lsc', 20, 'lsc@itcast.cn');
INSERT INTO `tb_user` VALUES (5, '周五输', '123456', 'zws', 20, 'zws@itcast.cn');
INSERT INTO `tb_user` VALUES (6, '吴六破', '123456', 'wlp', 21, 'wlp@itcast.cn');
INSERT INTO `tb_user` VALUES (7, '郑七灭', '123456', 'zqm', 22, 'zqm@itcast.cn');
INSERT INTO `tb_user` VALUES (8, '王八衰', '123456', 'wbs', 22, 'wbs@itcast.cn');
INSERT INTO `tb_user` VALUES (9, '张无忌', '123456', 'zwj', 25, 'zwj@itcast.cn');
INSERT INTO `tb_user` VALUES (10, '赵敏', '123456', 'zm', 26, 'zm@itcast.cn');
INSERT INTO `tb_user` VALUES (11, '赵二伤', '123456', 'zes', 25, 'zes@itcast.cn');
INSERT INTO `tb_user` VALUES (12, '赵三伤', '123456', 'zss1', 28, 'zss1@itcast.cn');
INSERT INTO `tb_user` VALUES (13, '赵四伤', '123456', 'zss2', 29, 'zss2@itcast.cn');
INSERT INTO `tb_user` VALUES (14, '赵五伤', '123456', 'zws', 39, 'zws@itcast.cn');
INSERT INTO `tb_user` VALUES (15, '赵六伤', '123456', 'zls', 29, 'zls@itcast.cn');
INSERT INTO `tb_user` VALUES (16, '赵七伤', '123456', 'zqs', 39, 'zqs@itcast.cn');
COMMIT;
SET FOREIGN_KEY_CHECKS = 1;
运行结果:
查询:
更新:

插入:

删除:
大家一定要配置好开发环境(可以自己去找找相关文档):
jdk地配置;
maven地配置;
数据库地配置(MySQL,navicat);
更多推荐




所有评论(0)