SpringのjdbcTemplateは、スタディノートを使用して、データベースでの操作を簡素化します

    Spring Frameworkには各レイヤーのソリューションがあり、永続レイヤーのソリューション(ORMモジュールとJDBCテンプレート)も提供していることを前に述べました。次に、小さなケースを通してJDBCテンプレートの簡単な使用法を最初に理解しましょう。
    準備:永続層はデータベース上で動作するため、最初にデータベーステーブルを作成する必要があり、データベーステーブルを自由に作成できます。作成したのはアカウントデータテーブルです。

CREATE TABLE `account` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `name` varchar(255) NOT NULL COMMENT '用户名',
  `money` float NOT NULL COMMENT '金额',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

Mavenプロジェクトを作成し、pomファイルに次の座標を追加します。

 <dependencies>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.2.8.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-tx</artifactId>
            <version>5.2.6.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>5.2.6.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.47</version>
        </dependency>
 </dependencies>

自分の習慣に従ってMavenプロジェクトでパッケージを作成し、クラスを作成して、main関数を記述します。私が書いたのは次のとおりです。

public class JdbcTemplateDemo {
    
    
    public static void main(String[] args) {
    
    
        //创建数据源
        DriverManagerDataSource dm = new DriverManagerDataSource();
        //设置数据库连接信息
        dm.setDriverClassName("com.mysql.jdbc.Driver");
        dm.setUrl("jdbc:mysql://localhost:3306/stu");
        dm.setUsername("root");
        dm.setPassword("123456");
        //创建JdbcTemplate对象
        JdbcTemplate jt = new JdbcTemplate(dm);
        //执行sql语句
        jt.update("insert into account(name,money) value (?,?)","小八","1000");
        //jt.execute("insert into account(name,money) value ('小五',1000)");
    }
}

    実行の結果、作成したデータベースにデータが追加されます。上記は、SpringでのJDBCテンプレートの簡単な使用法です。上記のコードにはまだ問題があります。springIocコンテナを学習したので、データソースの作成とJdbcTemplateテンプレートの作成はすべて新規であり、データベース接続情報はセットを介して設定されていることがわかりました。メソッド。これらはすべてspringIocを介して設定できます。解決するコンテナ。次に、上記のコードを変更します。
    bean.xmlファイルを作成し、次のように構成します。

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd">

    <!--配置数据源,我在这使用的是spring框架中的内置的数据源,其实也可以使用c3p0,dbcp,durid数据库连接池-->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
        <property name="url" value="jdbc:mysql://localhost:3306/stu"></property>
        <property name="username" value="root"></property>
        <property name="password" value="123456"></property>
    </bean>

    <!--配置jdbcTemplate模板-->
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
        <constructor-arg name="dataSource" ref="dataSource"></constructor-arg>
    </bean>
</beans>

別のメインメソッドを書いてみましょう:

public class JdbcTemplateDemo2 {
    
    
    public static void main(String[] args) {
    
    
        //加载bean.xml文件
        ApplicationContext context = new ClassPathXmlApplicationContext("bean.xml");
        //获取jdbcTemplate模板的bean对象
        JdbcTemplate jt = (JdbcTemplate) context.getBean("jdbcTemplate");
        //执行sql语句
        jt.update("insert into account(name,money) value (?,?)", "小九", "1000");
    }
}

    上記は変換後のコードです。次に、JdbcTemplateを使用して、daoでいくつかのメソッドを記述し、実行して結果を確認します。
アカウントエンティティクラス:

public class Account implements Serializable {
    
    
    private Integer id;
    private String name;
    private Float money;
    //get/set方法别忘记生成
    //toString方法也别忘记生成
}

AccountDaoインターフェース:

public interface AccountDao {
    
    
    /**
    * 查询所有用户
    */
    List<Account> findAll();

    /**
     * 根据id查询用户
     */
    Account findAccountById(Integer accountId);

    /**
     * 根据用户名查询用户
     */
    Account findAccountByName(String accountName);

    /**
     * 更新账户
     */
    void updateAccount(Account account);

    /**
     * 删除账户
     */
    void deleteAccountById(Integer accountId);
}

AccountDaoImplインターフェイス実装クラス:

public class AccountDaoImpl implements AccountDao {
    
    

    private JdbcTemplate jdbcTemplate;

    public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
    
    
        this.jdbcTemplate = jdbcTemplate;
    }

    public List<Account> findAll() {
    
    
        List<Account> list = jdbcTemplate.query("select * from account",new BeanPropertyRowMapper<Account>(Account.class));
        return list;
    }

    public Account findAccountById(Integer accountId) {
    
    
        List<Account> list = jdbcTemplate.query("select * from account where id = ?",new BeanPropertyRowMapper<Account>(Account.class),accountId);
        return list.isEmpty() ? null : list.get(0);
    }

    public Account findAccountByName(String accountName) {
    
    
        List<Account> list = jdbcTemplate.query("select * from account where name = ?", new BeanPropertyRowMapper<Account>(Account.class), accountName);
        if (list.isEmpty()){
    
    
            return null;
        }else if (list.size() > 1){
    
    
            throw new RuntimeException("结果集不唯一");
        }
        return list.get(0);
    }

    public void updateAccount(Account account) {
    
    
        jdbcTemplate.update("update account set name = ? , money = ? where id = ?", account.getName(),account.getMoney(),account.getId());

    }

    public void deleteAccountById(Integer accountId) {
    
    
        jdbcTemplate.update("delete from account where id = ?" , accountId);
    }
}

mainメソッドを実行して、結果を確認します。

public class JdbcTemplateDemo3 {
    
    
    public static void main(String[] args) {
    
    
        ApplicationContext context = new ClassPathXmlApplicationContext("bean.xml");
        AccountDao jt = (AccountDao) context.getBean("accountDao");
        //查询所用账户信息
        List<Account> lists = jt.findAll();
        for (Account list : lists){
    
    
            System.out.println(list);
        }
    }
}

クエリ結果:
ここに画像の説明を挿入
IDに従ってアカウントをクエリします:

Account account = jt.findAccountById(4);
System.out.println(account);

操作結果:
ここに画像の説明を挿入
他の方法については説明しません。わからない場合はメッセージを残してください。
AccountDaoImpl実装クラスには、これらのコード行があります。さまざまな永続レイヤーに対して次のコードを記述するのは、より面倒です。

private JdbcTemplate jdbcTemplate;
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
    this.jdbcTemplate = jdbcTemplate;
}
//可以通过继承JdbcDaoSupport类来解决这个问题
public class AccountDaoImpl extends JdbcDaoSupport implements AccountDao {
    
    

    /*private JdbcTemplate jdbcTemplate;

    public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }*/

    public List<Account> findAll() {
    
    
        List<Account> list = super.getJdbcTemplate().query("select * from account",new BeanPropertyRowMapper<Account>(Account.class));
        return list;
    }
    //其他几个方法我就不写了,也就改了super.getJdbcTemplate()这个代码
}

    JdbcDaoSupportを継承することとdaoでJdbcTemplateを書くことの具体的な違いは何ですか?違いは、これらのコードはSpringフレームワークで変更できず、xmlメソッドしか使用できないため、継承した場合はアノテーションを介して開発できないことです。daoでJdbcTemplateを定義する方法では、xmlメソッドとアノテーションメソッドの両方を使用できます。
    もちろん、ここではxmlメソッドのみを使用し、アノテーションメソッドも可能です。bean.xmlでアノテーションスキャンを有効にする必要があります

<!--开启注解扫描-->
<context:component-scan base-package="com.zy.jdbcTemplate.dao"></context:component-scan>

AccountDaoImpl実装クラスを変更し、注釈を追加します。

@Repository("accountDao")
public class AccountDaoImpl /*extends JdbcDaoSupport*/ implements AccountDao {
    
    

    @Autowired
    private JdbcTemplate jdbcTemplate;
    //......
}

いい加減にして!

おすすめ

転載: blog.csdn.net/qq_42494654/article/details/113871643