springboot数据库操作

本文介绍了如何在SpringBoot中连接数据库,包括配置数据库连接参数和连接池。接着讲解了使用Mybatis框架的步骤,如添加依赖、编写Mapper接口和事务管理。此外,还详细阐述了利用SpringData JPA进行数据库操作,如定义实体类和JpaRepository接口,以及在Service层的调用。最后提到了多数据源的配置和使用。

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

连接数据库

1. 配置数据库连接参数

# 数据库连接参数
spring.datasource.username=iop0
spring.datasource.password=iop0
spring.datasource.url=jdbc:oracle:thin:@101.2.41.15:1521:ceshi
spring.datasource.driver-class-name=oracle.jdbc.OracleDriver
# 指定使用的连接池类型
spring.datasource.type=org.apache.commons.dbcp2.BasicDataSource
# mybatis开启驼峰命名匹配
mybatis.configuration.map-underscore-to-camel-case=true

2. 配置连接池参数

# 连接池参数
spring:
  datasource:
    initialSize: 5
    minIdle: 5
    maxActive: 20
    maxWait: 60000
    timeBetweenEvictionRunsMillis: 60000
    minEvictableIdleTimeMillis: 300000
    validationQuery: SELECT 1 FROM DUAL
    testWhileIdle: true
    testOnBorrow: false
    testOnReturn: false
    poolPreparedStatements: true
    #   配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙
    filters: stat,wall,log4j
    maxPoolPreparedStatementPerConnectionSize: 20
    useGlobalDataSourceStat: true
    connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500
@Configuration
public class TestConfig {
    // 使用配置文件中的连接池参数
    @Bean
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource dataSource(){
        return new BasicDataSource();
    }
}

以上配置完成后,启动springboot,DataSourceJdbcTemplate就已经可以通过@Autowired从IOC容器中获取了(springboot自动配置,通过JdbcTemplate就已经可以对数据库进行操作了。

使用Mybatis框架

添加mybatis依赖

        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.1.4</version>
        </dependency>

编写mapper的Dao接口,并加入容器。

@Mapper:描述数据层接口的注解,通知spring框架此接口的实现类由mybatis负责创建。

@Mapper
@Repository
public interface TestMapperDao {
    @Select("select * from xzqh where qhbm=#{areacode}")
    public List<Xzqh> getAreaCodeById(@Param("areacode") String areacode);

    @Update("update xzqh set qhjb=#{qhjb} where qhbm='34'")
    public void update(String qhjb);
}

在service层注入TestMapperDao 并调用其中的方法。使用@Transactional进行统一事务管理。

使用SpringData JPA

java 持久化API,使用的也是ORM思想,底层实现有Hibernate(默认)、Toplink、OpenJpa

1. 编写数据表实体类,并用@Entity、@Table、@Id、@Column等注解标注所对应的表和字段。当没有指定表名和字段名时,默认对应类名的表名和驼峰字段名。

2. 编写Dao extends JpaRepository 接口,不用加注解就能被扫描到容器。

3. service中调用dao中的方法。

@Select("select * from xzqh where qhbm=#{areacode}")
public List<Xzqh> getAreaCodeById(String areacode);

多数据源使用

参考: https://www.cnblogs.com/e-x-c-e-ption/p/13452871.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值