ホームページ  >  記事  >  Java  >  Spring Boot が JdbcTemplate を統合する方法

Spring Boot が JdbcTemplate を統合する方法

王林
王林転載
2023-05-12 14:17:141090ブラウズ

Integrate JdbcTemplate

JdbcTemplate は、Spring が提供する JDBC テンプレート フレームワークのセットであり、AOP テクノロジを使用して、JDBC を直接使用する場合に大量のコードが繰り返される問題を解決します。 JdbcTemplate は Mybatis ほど柔軟ではありませんが、JDBC を直接使用するよりもはるかに便利です。 Spring Boot での JdbcTemplate の使用により、自動構成クラス JdbcTemplateAutoConfiguration が提供されます。ソース コードの一部は次のとおりです:

@Configuration
@ConditionalOnClass({DataSource.class, JdbcTemplate.class})
@ConditionalOnSingleCandidate(DataSource.class)
@AutoConfigureAfter({DataSourceAutoConfiguration.class})
@EnableConfigurationProperties({JdbcProperties.class})
public class JdbcTemplateAutoConfiguration {
    public JdbcTemplateAutoConfiguration() {
    }
    @Configuration
    @Import({JdbcTemplateAutoConfiguration.JdbcTemplateConfiguration.class})
    static class NamedParameterJdbcTemplateConfiguration {
        NamedParameterJdbcTemplateConfiguration() {
        }
        @Bean
        @Primary
        @ConditionalOnSingleCandidate(JdbcTemplate.class)
        @ConditionalOnMissingBean({NamedParameterJdbcOperations.class})
        public NamedParameterJdbcTemplate namedParameterJdbcTemplate(JdbcTemplate jdbcTemplate) {
            return new NamedParameterJdbcTemplate(jdbcTemplate);
        }
    }
    @Configuration
    static class JdbcTemplateConfiguration {
        private final DataSource dataSource;
        private final JdbcProperties properties;

        JdbcTemplateConfiguration(DataSource dataSource, JdbcProperties properties) {
            this.dataSource = dataSource;
            this.properties = properties;
        }
        @Bean
        @Primary
        @ConditionalOnMissingBean({JdbcOperations.class})
        public JdbcTemplate jdbcTemplate() {
            JdbcTemplate jdbcTemplate = new JdbcTemplate(this.dataSource);
            Template template = this.properties.getTemplate();
            jdbcTemplate.setFetchSize(template.getFetchSize());
            jdbcTemplate.setMaxRows(template.getMaxRows());
            if (template.getQueryTimeout() != null) {
                jdbcTemplate.setQueryTimeout((int)template.getQueryTimeout().getSeconds());
            }
            return jdbcTemplate;
        }
    }
}

ソース コードから、DataSource と JdbcTemplate が以下に存在する場合に自動構成が有効になることがわかります。クラスパスであり、 DataSource. のインスタンスが 1 つだけある場合、開発者が JdbcOperations を提供しない場合、Spring Boot は自動的に JdbcTemplate をコンテナーに挿入します (JdbcTemplate は JdbcOperations のサブクラスです)。したがって、JdbcTemplate を使用したい開発者は、JdbcTemplate の依存関係と DataSource の依存関係を提供するだけで済みます。

データベースとテーブルの作成

次のように、データベースにテーブルを作成します。プロジェクトの作成

Spring Boot プロジェクトを作成し、依存関係を追加します

CREATE TABLE `book` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(128) DEFAULT NULL,
  `author` varchar(128) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
INSERT INTO `chapter05`(`id`, `name`, `author`) VALUES (1, '斗罗大陆Ⅰ', '唐家三少');
INSERT INTO `chapter05`(`id`, `name`, `author`) VALUES (2, '斗罗大陆Ⅱ', '唐家三少');

spring-jdbc は spring-boot-starter-jdbc で提供され、データベース ドライバーの依存関係とデータベース接続プールの依存関係も追加されます

データベース構成

application.propertiesで基本的なデータベース接続情報を構成します

spring.datasource.type=com.alibaba.druid.pool.DruidDataSource

spring。 datasource.url=jdbc:mysql://localhost:3306/weirdo
spring.datasource.username=root

spring.datasource.password=root


エンティティ クラスの作成

Book エンティティ クラスを作成します。コードは次のとおりです。

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-jdbc</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>com.alibaba</groupId>
  <artifactId>druid</artifactId>
  <version>1.1.9</version>
</dependency>

データベース アクセス層を作成します。

BookDao を作成します。コードは次のとおりです。

public class Book {
    private int id;
    private String name;
    private String author;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getAuthor() {
        return author;
    }
    public void setAuthor(String author) {
        this.author = author;
    }
}

コード説明:

BookDao を作成し、jdbcTemplate を挿入します。 spring-jdbc関連の依存関係が追加されているため、SpringコンテナにJdbcTemplateが自動的に登録されるので、ここにJdbcTemplateを直接注入することができます。主に update メソッドとbatchUpdate メソッドを完了するために使用され、query メソッドと queryForObject メソッドは主にクエリ関数を完了するために使用されます。さらに、任意のSQLを実行するために使用できるexecuteメソッド、ストアドプロシージャを呼び出すために使用されるcallメソッドなどもあります。
  • クエリ操作を実行する場合、 RowMapper はクエリされた列を結合するために必要です。エンティティ クラスの属性間には 1 対 1 の対応があります。列名と属性名が同じ場合は BeanPropertyRowMapper を直接使用できますが、列名と属性名が異なる場合は、開発者が独自に RowMapper インターフェースを実装して列とエンティティ クラスの属性を 1 対 1 にマッピングする必要があります。
  • サービスとコントローラーの作成
  • BookService と BooKController の作成

    @Repository
    public class BookDao {
        @Autowired
        JdbcTemplate jdbcTemplate;
        public int addBook(Book book) {
            return jdbcTemplate.update("INSERT INTO book(name,author) VALUES (?,?)",
                    book.getName(), book.getAuthor());
        }
        public int updateBook(Book book) {
            return jdbcTemplate.update("UPDATE book SET name=?,author=? WHERE id=?",
                    book.getName(), book.getAuthor(), book.getId());
        }
        public int deleteBookById(Integer id) {
            return jdbcTemplate.update("DELETE FROM book WHERE id=?", id);
        }
        public Book getBookById(Integer id) {
            return jdbcTemplate.queryForObject("select * from book where id=?",
                    new BeanPropertyRowMapper<>(Book.class), id);
        }
        public List<Book> getAllBooks() {
            return jdbcTemplate.query("select * from book",
                    new BeanPropertyRowMapper<>(Book.class));
        }
    }
    @Service
    public class BookService {
        @Autowired
        BookDao bookDao;
        public int addBook(Book book) {
            return bookDao.addBook(book);
        }
        public int updateBook(Book book) {
            return bookDao.updateBook(book);
        }
        public int deleteBookById(Integer id) {
            return bookDao.deleteBookById(id);
        }
        public Book getBookById(Integer id) {
            return bookDao.getBookById(id);
        }
        public List<Book> getAllBooks() {
            return bookDao.getAllBooks();
        }
    }

    最後にブラウザで http://localhost:8081/bookOps アドレスにアクセスします。コンソールは次のようにログを出力します:

addBook>>>1

updateBook>>>1

getBookById>>>com.sang.Book@35e33288

deleteBookById>>>1

getAllBooks>>>[com.sang.Book@2f7c2d6d, com.sang.Book@32db4b36]

データベース内のデータ以下のとおりであります:########### #

以上がSpring Boot が JdbcTemplate を統合する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。