springboot使用JdbcTemplate操作mysql数据库

本文详细介绍如何使用SpringBoot创建web工程,并整合MySQL数据库。通过IDEA的SpringBoot创建向导,配置pom依赖,设置application.yml,创建数据库表,定义实体类,实现控制器访问等步骤,完成一个简单的用户信息查询功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

新建工程

采用idea的spring boot创建向导创建web工程demo

pom依赖
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<!--自动生成getter,setter-->
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <optional>true</optional>
</dependency>
application.yml配置
# 数据库url地址
spring:
  datasource:
    url: jdbc:mysql://localhost:3306/test
    username: root
    password: root
    driver-class-name: com.mysql.jdbc.Driver
    dbcp2:
      max-idle: 10
      max-wait-millis: 10000
      min-idle: 5
      initial-size: 5
数据库
CREATE TABLE `user` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `username` varchar(30) NOT NULL,
  `password` varchar(30) NOT NULL,
  `email` varchar(30) NOT NULL,
  `age` int(3) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

实体

package com.demo.entity;

import lombok.Data;

/**
 * @author Administrator
 * @date 2019/4/12
 */
@Data
public class User {
    private Long id;
    private String username;
    private String password;
    private String email;
    private Integer age;
}
访问controller
@RestController
public class UserController {

    @Autowired
    private JdbcTemplate jdbcTemplate;

    @GetMapping(value = "/user/{id}")
    public User getUser(@PathVariable("id") Long id) {
        String sql = "select * from user where id = ?";
        Object[] args = {id};
        List<User> users = jdbcTemplate.query(sql, args, (rs, i) -> {
            User user = new User();
            user.setId(rs.getLong("id"));
            user.setUsername(rs.getString("username"));
            user.setPassword(rs.getString("password"));
            user.setEmail(rs.getString("email"));
            user.setAge(rs.getInt("age"));
            return user;
        });
        return users.isEmpty() ? new User() : users.get(0);
    }
}
结果

访问http://localhost:8080/user/1


{"id":1,"username":"admin","password":"admin","email":"asrew@qq.com","age":20}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值