欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JdbcTemplate方法介紹與增刪改查操作實(shí)現(xiàn)

 更新時(shí)間:2019年11月02日 14:42:02   作者:農(nóng)農(nóng)  
這篇文章主要給大家介紹了關(guān)于JdbcTemplate方法與增刪改查操作實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用JdbcTemplate具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

JdbcTemplate介紹

為了使 JDBC 更加易于使用,Spring 在 JDBCAPI 上定義了一個(gè)抽象層, 以此建立一個(gè)JDBC存取框架,Spring Boot Spring Data-JPA。

作為 SpringJDBC 框架的核心, JDBC 模板的設(shè)計(jì)目的是為不同類型的JDBC操作提供模板方法. 每個(gè)模板方法都能控制整個(gè)過程,并允許覆蓋過程中的特定任務(wù)。

通過這種方式,可以在盡可能保留靈活性的情況下,將數(shù)據(jù)庫存取的工作量降到最低。

JdbcTemplate方法介紹

JdbcTemplate主要提供以下五類方法:

1、execute方法:可以用于執(zhí)行任何SQL語句,一般用于執(zhí)行DDL語句;

       Execute、executeQuery、executeUpdate

2、update方法及batchUpdate方法:update方法用于執(zhí)行新增、修改、刪除等語句;batchUpdate方法用于執(zhí)行批處理相關(guān)語句 SQL SERVCER(GO SQL語句 GO) ;

3、query方法及queryForXXX方法:用于執(zhí)行查詢相關(guān)語句;

4、call方法:用于執(zhí)行存儲(chǔ)過程、函數(shù)相關(guān)語句。

JdbcTemplate實(shí)現(xiàn)增刪改查

JdbcTemplate添加數(shù)據(jù)

1. 使用配置實(shí)現(xiàn)

1.1 創(chuàng)建實(shí)體類

public class Account {
 private Integer accountid;
 private String accountname;
 private Double balance;

 public Integer getAccountid() {
 return accountid;
 }

 public void setAccountid(Integer accountid) {
 this.accountid = accountid;
 }

 public String getAccountname() {
 return accountname;
 }

 public void setAccountname(String accountname) {
 this.accountname = accountname;
 }

 public Double getBalance() {
 return balance;
 }

 public void setBalance(Double balance) {
 this.balance = balance;
 }
}

實(shí)體類

1.2 創(chuàng)建Dao層

//查詢所有所有賬戶
public List<Account> getAllAccounts();

.3 創(chuàng)建Dao層實(shí)現(xiàn)類并繼承JdbcDaoSupport接口

public class AccountDaoImpl extends JdbcDaoSupport implements AccountDao {


 @Override
 public List<Account> getAllAccounts() {
 JdbcTemplate jdbcTemplate = getJdbcTemplate();
 String sql = "select * from accounts";

 //RowMapper:接口 封裝了記錄的行映射關(guān)系
 List<Account> lists = jdbcTemplate.query(sql, new RowMapper<Account>() {


  @Override
  public Account mapRow(ResultSet resultSet, int i) throws SQLException {
  //創(chuàng)建Account對(duì)象
  Account account = new Account();
  //從ResultSet中解數(shù)據(jù)保到Accounts對(duì)象中
  account.setAccountid(resultSet.getInt("accountid"));
  account.setAccountname(resultSet.getString("accountname"));
  account.setBalance(resultSet.getDouble("balance"));

  return account;
  }
 });

return account;

}

實(shí)現(xiàn)查詢方法

1.4創(chuàng)建Service層

//查詢所有所有賬戶
public List<Account> getAllAccounts();

1.5創(chuàng)建Service層實(shí)現(xiàn)類

AccountDao accountDao;
@Override
public List<Account> getAllAccounts() {
 List<Account> allAccounts = accountDao.getAllAccounts();
 return allAccounts;
}

1.6 編寫applicationContext.xml文件

<!--識(shí)別到配置文件-->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!--配置數(shù)據(jù)源-->
<!--spring內(nèi)置的數(shù)據(jù)源:提供連接的,不負(fù)責(zé)管理,使用連接池-->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
 <property name="driverClassName" value="${jdbc.driver}"></property>
 <property name="url" value="${jdbc.url}"></property>
 <property name="username" value="${jdbc.username}"></property>
 <property name="password" value="${jdbc.password}"></property>
</bean>
<!--構(gòu)建jdbcTemplate-->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
 <property name="dataSource" ref="dataSource"></property>
</bean>

<bean id="accountDao" class="cn.spring.accounttest.dao.impl.AccountDaoImpl">
 <property name="jdbcTemplate" ref="jdbcTemplate"></property>
</bean>
<!--Service-->
<bean id="accountService" class="cn.spring.accounttest.service.impl.AccountServiceImpl">
 <property name="accountDao" ref="accountDao"></property>
</bean>

applicationContext.xml

1.7編寫測(cè)試類 

@Test
public void getAllAccount(){
 ApplicationContext context=new ClassPathXmlApplicationContext("applicationContext.xml");
 //從spring容器中獲取Service對(duì)象
 AccountService accountService = (AccountService)context.getBean("accountService");
 List<Account> allAccounts = accountService.getAllAccounts();
 for (Account account:allAccounts) {
 System.out.println("賬戶名:"+account.getAccountname()+",余額為:"+account.getBalance());
 }
}

查詢測(cè)試類

2. 使用注解方式實(shí)現(xiàn)

2.1 創(chuàng)建實(shí)體類 

實(shí)體類

2.2 創(chuàng)建Dao層

查詢方法

2.3 創(chuàng)建Dao層實(shí)現(xiàn)類

@Repository
public class AccountDaoImpl implements AccountDao {

 @Autowired
 private JdbcTemplate jdbcTemplate;

 Account account = new Account();
 @Override
 public List<Account> getAllAccounts() {

  String sql = "select * from accounts";

  
  //自動(dòng)映射
  RowMapper<Account> rowMapper = new BeanPropertyRowMapper<>(Account.class);
  List<Account> query = jdbcTemplate.query(sql, rowMapper);
  for (Account account : query) {
   System.out.println(account);
  }
  return query;
  }
 }

Dao實(shí)現(xiàn)類

2.4創(chuàng)建Service層

查詢方法

2.5創(chuàng)建Service層實(shí)現(xiàn)類

實(shí)現(xiàn)查詢方法

2.6編寫applicationContext.xml文件

<!--掃描注解:包掃描器-->
<context:component-scan base-package="cn.spring"/>

<!--識(shí)別到配置文件-->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!--配置數(shù)據(jù)源-->
<!--spring內(nèi)置的數(shù)據(jù)源:提供連接的,不負(fù)責(zé)管理,使用連接池-->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
 <property name="driverClassName" value="${jdbc.driver}"></property>
 <property name="url" value="${jdbc.url}"></property>
 <property name="username" value="${jdbc.username}"></property>
 <property name="password" value="${jdbc.password}"></property>
</bean>
<!--構(gòu)建jdbcTemplate-->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
 <property name="dataSource" ref="dataSource"></property>
</bean>

applicationContext.xml

2.7編寫測(cè)試類

查詢測(cè)試類

JdbcTemplate實(shí)現(xiàn)增刪改操作

使用注解方式實(shí)現(xiàn),配置式同添加操作

1.創(chuàng)建Dao層

//刪除賬戶
public int delAccount(int id);

//添加用戶
public int addAccount(Account account);

//修改賬戶
public int updaAccount(Account account);

增刪改方法

2.創(chuàng)建Dao曾實(shí)現(xiàn)類

@Override
 public int delAccount(int id) {

  String sql="delete from accounts where accountid=2";
  int count = jdbcTemplate.update(sql);
  return count;
 }

@Override
 public int addAccount(Account account) {
  String sql="insert into Accounts(accountname,balance) values(?,?)";
  int count = jdbcTemplate.update(sql,account.getAccountname(),account.getBalance());
  return count;
 }

 @Override
 public int updaAccount(Account account) {
  String sql="update accounts set accountname=?,balance=? where accountid=?";
  int count = jdbcTemplate.update(sql, account.getAccountname(),account.getBalance(),account.getAccountid() );
  return count;
 }

增刪改方法實(shí)現(xiàn)類

3. 創(chuàng)建Service層

4. 創(chuàng)建Service層實(shí)現(xiàn)類

5. 編寫applicationContext.xml文件

6. 編寫測(cè)試類

@Test
public void delAccount(){
 ApplicationContext context=new ClassPathXmlApplicationContext("applicationContext.xml");
 AccountService accountService =(AccountService) context.getBean("accountServiceImpl");
 int i = accountService.delAccount(2);
 if (i>0){
  System.out.println("刪除成功");
 }
}

@Test
public void addAccount(){
 ApplicationContext context=new ClassPathXmlApplicationContext("applicationContext.xml");
 AccountService accountServiceImpl = (AccountService) context.getBean("accountServiceImpl");
 Account account=new Account();
 account.setAccountname("劉磊");
 account.setBalance(Double.valueOf(784));
 int count = accountServiceImpl.addAccount(account);
 if (count>0){
  System.out.println("添加成功");
 }
}

@Test
public void updaAcccount(){
 ApplicationContext context=new ClassPathXmlApplicationContext("applicationContext.xml");
 AccountService accountServiceImpl = (AccountService) context.getBean("accountServiceImpl");
 Account account=new Account();
 account.setAccountid(10);
 account.setAccountname("劉磊");
 account.setBalance(Double.valueOf(784));
 int count = accountServiceImpl.updaAccount(account);
 if (count>0){
  System.out.println("修改成功");
 }
}

增刪改測(cè)試類

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • SpringMVC攔截器詳解

    SpringMVC攔截器詳解

    本篇文章主要介紹了SpringMVC攔截器配置及使用方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2021-07-07
  • 利用MyBatis實(shí)現(xiàn)條件查詢的方法匯總

    利用MyBatis實(shí)現(xiàn)條件查詢的方法匯總

    這篇文章主要給大家介紹了關(guān)于利用MyBatis實(shí)現(xiàn)條件查詢的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用MyBatis具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • SpringBoot logback日志框架使用過程解析

    SpringBoot logback日志框架使用過程解析

    這篇文章主要介紹了SpringBoot logback日志框架使用過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Java操作excel的三種常見方法實(shí)例

    Java操作excel的三種常見方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于Java操作excel的三種常見方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • springboot整合webservice使用簡(jiǎn)單案例總結(jié)

    springboot整合webservice使用簡(jiǎn)單案例總結(jié)

    WebService是一個(gè)SOA(面向服務(wù)的編程)的架構(gòu),它是不依賴于語言,平臺(tái)等,可以實(shí)現(xiàn)不同的語言間的相互調(diào)用,下面這篇文章主要給大家介紹了關(guān)于springboot整合webservice使用的相關(guān)資料,需要的朋友可以參考下
    2024-07-07
  • Spring?DI依賴注入過程解析

    Spring?DI依賴注入過程解析

    依賴注入是由“依賴”和“注入”兩個(gè)詞匯組合而成,那么我們?cè)僖淮雾樚倜?,分別分析這兩個(gè)詞語,這篇文章主要介紹了Spring?DI依賴注入詳解,需要的朋友可以參考下
    2022-11-11
  • java線程池對(duì)象ThreadPoolExecutor的深入講解

    java線程池對(duì)象ThreadPoolExecutor的深入講解

    在我們的開發(fā)中“池”的概念并不罕見,有數(shù)據(jù)庫連接池、線程池、對(duì)象池、常量池等等。下面這篇文章主要給大家介紹了關(guān)于java線程池對(duì)象ThreadPoolExecutor的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧
    2018-09-09
  • maven報(bào)錯(cuò):Failed to execute goal on project問題及解決

    maven報(bào)錯(cuò):Failed to execute goal on p

    這篇文章主要介紹了maven報(bào)錯(cuò):Failed to execute goal on project問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • springboot多數(shù)據(jù)源配合docker部署mysql主從實(shí)現(xiàn)讀寫分離效果

    springboot多數(shù)據(jù)源配合docker部署mysql主從實(shí)現(xiàn)讀寫分離效果

    這篇文章主要介紹了springboot多數(shù)據(jù)源配合docker部署mysql主從實(shí)現(xiàn)讀寫分離,通過使用docker獲取mysql鏡像,具體內(nèi)容詳情跟隨小編一起看看吧
    2021-09-09
  • 使用WebUploader實(shí)現(xiàn)分片斷點(diǎn)上傳文件功能(二)

    使用WebUploader實(shí)現(xiàn)分片斷點(diǎn)上傳文件功能(二)

    這篇文章主要為大家詳細(xì)介紹了使用WebUploader實(shí)現(xiàn)分片斷點(diǎn)上傳文件功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01

最新評(píng)論