中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JdbcTemplate方法介紹與增刪改查操作實現

發布時間:2020-10-04 18:36:36 來源:腳本之家 閱讀:214 作者:農農 欄目:編程語言

JdbcTemplate介紹

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

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

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

JdbcTemplate方法介紹

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

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

       Execute、executeQuery、executeUpdate

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

3、query方法及queryForXXX方法:用于執行查詢相關語句;

4、call方法:用于執行存儲過程、函數相關語句。

JdbcTemplate實現增刪改查

JdbcTemplate添加數據

1. 使用配置實現

1.1 創建實體類

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;
 }
}

實體類

1.2 創建Dao層

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

.3 創建Dao層實現類并繼承JdbcDaoSupport接口

public class AccountDaoImpl extends JdbcDaoSupport implements AccountDao {


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

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


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

  return account;
  }
 });

return account;

}

實現查詢方法

1.4創建Service層

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

1.5創建Service層實現類

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

1.6 編寫applicationContext.xml文件

<!--識別到配置文件-->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!--配置數據源-->
<!--spring內置的數據源:提供連接的,不負責管理,使用連接池-->
<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>
<!--構建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編寫測試類 

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

查詢測試類

2. 使用注解方式實現

2.1 創建實體類 

實體類

2.2 創建Dao層

查詢方法

2.3 創建Dao層實現類

@Repository
public class AccountDaoImpl implements AccountDao {

 @Autowired
 private JdbcTemplate jdbcTemplate;

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

  String sql = "select * from accounts";

  
  //自動映射
  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實現類

2.4創建Service層

查詢方法

2.5創建Service層實現類

實現查詢方法

2.6編寫applicationContext.xml文件

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

<!--識別到配置文件-->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!--配置數據源-->
<!--spring內置的數據源:提供連接的,不負責管理,使用連接池-->
<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>
<!--構建jdbcTemplate-->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
 <property name="dataSource" ref="dataSource"></property>
</bean>

applicationContext.xml

2.7編寫測試類

查詢測試類

JdbcTemplate實現增刪改操作

使用注解方式實現,配置式同添加操作

1.創建Dao層

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

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

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

增刪改方法

2.創建Dao曾實現類

@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;
 }

增刪改方法實現類

3. 創建Service層

4. 創建Service層實現類

5. 編寫applicationContext.xml文件

6. 編寫測試類

@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("修改成功");
 }
}

增刪改測試類

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

蒙阴县| 阿鲁科尔沁旗| 亚东县| 房山区| 高雄县| 五常市| 塔城市| 密云县| 江门市| 嫩江县| 沁水县| 双流县| 泰州市| 贵南县| 登封市| 安国市| 平南县| 资讯| 鄂托克旗| 筠连县| 铁岭县| 宁远县| 祁连县| 杭锦后旗| 福建省| 桑日县| 唐海县| 启东市| 崇阳县| 永兴县| 黄梅县| 新泰市| 驻马店市| 沙坪坝区| 惠州市| 拉萨市| 陆河县| 竹山县| 邯郸市| 吴堡县| 鱼台县|