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

spring通過jdbc連接數(shù)據(jù)庫

 更新時間:2019年08月21日 11:07:56   作者:just_you_java  
這篇文章主要為大家詳細介紹了spring通過jdbc連接數(shù)據(jù)庫的相關代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了spring通過jdbc連接數(shù)據(jù)庫的具體代碼,供大家參考,具體內(nèi)容如下

首先看下整個工程的架構(gòu)目錄:

需要的jar包:

一、建表

create table student(
 id int primary key auto_increment,
 name varchar(32),
 age int,
 phone varchar(32)
);

二、新建與數(shù)據(jù)庫對應JavaBean

package com.etoak.bean;
 
public class Student {
 /**
 * 一個標準的javaBean對象 : 
 *  表字段對應的屬性
 *  屬性對應的getter、setter方法
 *  無參構(gòu)造器
 *  除id[主鍵]之外其他參數(shù)組成的構(gòu)造器
 *  所有參數(shù)組成的構(gòu)造器
 */
 
 private Integer id;
 private String name;
 private Integer age;
 private String phone;
 public Student() {
 super();
 }
 public Student(String name, Integer age, String phone) {
 super();
 this.name = name;
 this.age = age;
 this.phone = phone;
 }
 public Student(Integer id, String name, Integer age, String phone) {
 super();
 this.id = id;
 this.name = name;
 this.age = age;
 this.phone = phone;
 }
 public Integer getId() {
 return id;
 }
 public void setId(Integer id) {
 this.id = id;
 }
 public String getName() {
 return name;
 }
 public void setName(String name) {
 this.name = name;
 }
 public Integer getAge() {
 return age;
 }
 public void setAge(Integer age) {
 this.age = age;
 }
 public String getPhone() {
 return phone;
 }
 public void setPhone(String phone) {
 this.phone = phone;
 }
}

三、spring的applicationContext配置文件

<beans xmlns="http://www.springframework.org/schema/beans"
 xmlns:context="http://www.springframework.org/schema/context"
 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-3.2.xsd
 http://www.springframework.org/schema/context
 http://www.springframework.org/schema/context/spring-context-3.2.xsd">
 
 <!-- 
 使用spring提供的整合jdbc功能
 需要導入DAO層提供的兩個jar包[spring-jdbc spring-tx]
 
 通過ioc依賴注入 將JdbcTemplate注入給StuDaoImpl
 -->
 <bean id="dao" class="com.etoak.dao.StuDaoImpl">
 <!-- 
  name="jt"  setJt(JdbcTemplate jt)
  ref="jt"  id="jt"
  自定義對象 ref=""
  -->
 <property name="jt" ref="jt"></property>
 </bean>
 
 <bean id="jt" class="org.springframework.jdbc.core.JdbcTemplate">
 <property name="dataSource" ref="ds"></property>
 </bean>
 <!-- 
 此時的JdbcTemplate還不具備數(shù)據(jù)庫連接能力
 為了讓其具備數(shù)據(jù)庫連接能力,需要為其提供DataSource 連接池、數(shù)據(jù)源
  setDataSource(DataSource ds)
 需要在ioc容器中再配置一個DataSource對象:
  driverClassName
  url
  username
  password
  maxIdle
  maxActive
  maxWait
 
 DataSource 接口
  1 實現(xiàn)類  
  BasicDataSource  commons-dbcp.jar
  spring框架自帶了DataSource實現(xiàn)類
  DriverManagerDataSource
   setDriverClassName(String driver)
   setUrl(String url)
   setUsername(String u)
   setPassword(String p)
  [
   ref屬性 : 表示調(diào)用該方法需要注入的數(shù)據(jù)類型 : 自定義類型/引用類型
   value屬性 : 表示調(diào)用該方法需要注入的數(shù)據(jù)類型 : 基本數(shù)據(jù)類型/String類型/Class類型
  ] 
  2 工廠bean
 -->
 <bean id="ds" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
 <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
 <property name="url" value="jdbc:mysql://localhost:3306/etoak"/>
 <property name="username" value="root"/>
 <property name="password" value="root"/>
 </bean>
 
</beans>

四、編寫Dao

package com.etoak.dao;
 
import java.util.List;
import java.util.Map;
 
import org.springframework.jdbc.core.JdbcTemplate;
 
import com.etoak.bean.Student;
 
/**
 * 使用jdbc方式對student表數(shù)據(jù)進行CRUD操作
 *  1 傳統(tǒng)的jdbc開發(fā)方式 [ConFactory ...]
 *  2 spring提供的整合方案  JdbcTemplate
 */
public class StuDaoImpl {
 
 private JdbcTemplate jt;
 public void setJt(JdbcTemplate jt) {
 this.jt = jt;
 }
 
 /**
 * JdbcTemplate將連接數(shù)據(jù)庫執(zhí)行添加操作的流程封裝在其update(sql)
 */
 public boolean addStu(Student stu){
 String sql = "insert into student values(null,?,?,?)";
 Object[] args = {stu.getName() , stu.getAge() , stu.getPhone()};
 int result = jt.update(sql , args);
 // result 執(zhí)行當前操作影響的數(shù)據(jù)量
 return result==1;
 }
 
 public boolean delStuById(Integer id){
 String sql = "delete from student where id="+id;
 return jt.update(sql)==1;
 }
 public boolean updateStu(Student stu){
 String sql = "update student set name=?,age=?,phone=? where id=?";
 Object[] args = {stu.getName() , stu.getAge() , stu.getPhone() , stu.getId()};
 return jt.update(sql , args)==1;
 }
 
 /**
 * jt.queryForMap(sql) - Map 
 *  Jdbc不是ORM工具,不知道sql查詢的對應哪個對象
 *  只能將查詢出的關系型數(shù)據(jù)封裝在一個Map集合中返回
 *  {字段名=字段值,...}
 *  map.get("id/name/age/phone") 
 * 注意 : 
 *  在使用queryForMap(sql)查詢單條數(shù)據(jù)時
 *  必須能夠確保根據(jù)傳入的sql語句能夠并且只能查詢出單條數(shù)據(jù)
 *  否則使用該方法會拋出異常
 */
 public Map selStuById(Integer id){
 String sql = "select * from student where id="+id;
 Map map = jt.queryForMap(sql);
 return map;
 }
 
 // List<Map> 每一個student被封裝成了一個Map對象
 public List selectAllStus(){
 String sql = "select * from student";
 return jt.queryForList(sql);
 }
 
 public int selectStuCount(){
 String sql = "select count(*) from student";
 return jt.queryForInt(sql);
 }
 
 public List selectStusByPage(int start , int max){
 String sql = "select * from student limit ?,?";
 Object[] args = {start , max};
 return jt.queryForList(sql , args);
 }
}

五、測試

package com.etoak.test;
 
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
 
import com.etoak.bean.Student;
import com.etoak.dao.StuDaoImpl;
 
public class Test {
 
 public static void main(String[] args) {
 ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
 StuDaoImpl dao = (StuDaoImpl)ac.getBean("dao");
 Student stu = new Student("sheldon",30,"111");
 boolean flag = dao.addStu(stu);
 System.out.println(flag);
 }
 
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 解決MyEclipse6.5無法啟動,一直停留剛開始啟動界面的詳解

    解決MyEclipse6.5無法啟動,一直停留剛開始啟動界面的詳解

    本篇文章是對解決MyEclipse6.5無法啟動,一直停留剛開始啟動界面的方法進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • 淺談Java的虛擬機結(jié)構(gòu)以及虛擬機內(nèi)存的優(yōu)化

    淺談Java的虛擬機結(jié)構(gòu)以及虛擬機內(nèi)存的優(yōu)化

    這篇文章主要介紹了Java的虛擬機結(jié)構(gòu)以及虛擬機內(nèi)存的優(yōu)化,講到了JVM的堆和??臻g及GC垃圾回收等重要知識,需要的朋友可以參考下
    2016-03-03
  • Java?NIO緩沖區(qū)Buffer基礎教程示例

    Java?NIO緩沖區(qū)Buffer基礎教程示例

    這篇文章主要介紹了Java?NIO緩沖區(qū)Buffer基礎教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • jcrop 網(wǎng)頁截圖工具(插件)開發(fā)

    jcrop 網(wǎng)頁截圖工具(插件)開發(fā)

    今天給大家介紹一下一個web 中經(jīng)常會用到的截圖(如:頭像等)工具,需要的朋友可以了解下
    2012-11-11
  • Java?數(shù)據(jù)結(jié)構(gòu)與算法系列精講之漢諾塔

    Java?數(shù)據(jù)結(jié)構(gòu)與算法系列精講之漢諾塔

    漢諾塔是源于印度一個古老傳說的益智玩具。大梵天創(chuàng)造世界時做了三根石柱,在一根柱子上從下往上按大小順序摞著64片黃金圓盤。大梵天命令婆羅門把圓盤從下面開始按大小順序重新擺放在另一根柱子上。并且規(guī)定,在小圓盤上不能放大圓盤,三根柱子之間一次只能移動一個圓盤
    2022-02-02
  • SpringBoot中使用@Async注解失效場景及說明

    SpringBoot中使用@Async注解失效場景及說明

    在Spring?Boot中,@Async注解就像一把刀,能幫你輕松處理那些耗時的任務,讓主線程可以繼續(xù)忙別的事兒,不過,跟所有強大的工具一樣,用不好它也可能出岔子,為了避免這些坑,咱們得深入了解下@Async注解,接下來,咱們就來聊聊7種常見的@Async失效情況,需要的朋友可以參考下
    2024-07-07
  • JavaWeb ServletConfig作用及原理分析講解

    JavaWeb ServletConfig作用及原理分析講解

    ServletConfig對象,叫Servlet配置對象。主要用于加載配置文件的初始化參數(shù)。我們知道一個Web應用里面可以有多個servlet,如果現(xiàn)在有一份數(shù)據(jù)需要傳給所有的servlet使用,那么我們就可以使用ServletContext對象了
    2022-10-10
  • SpringBoot優(yōu)雅接收前端請求參數(shù)的詳細過程

    SpringBoot優(yōu)雅接收前端請求參數(shù)的詳細過程

    這篇文章主要介紹了SpringBoot如何優(yōu)雅接收前端請求參數(shù),我們可以通過@RequestParm注解去綁定請求中的參數(shù),將(查詢參數(shù)或者form表單數(shù)據(jù))綁定到controller的方法參數(shù)中,本文結(jié)合示例代碼給大家講解的非常詳細,需要的朋友可以參考下
    2023-06-06
  • 基于Java實現(xiàn)的一層簡單人工神經(jīng)網(wǎng)絡算法示例

    基于Java實現(xiàn)的一層簡單人工神經(jīng)網(wǎng)絡算法示例

    這篇文章主要介紹了基于Java實現(xiàn)的一層簡單人工神經(jīng)網(wǎng)絡算法,結(jié)合實例形式分析了java實現(xiàn)人工神經(jīng)網(wǎng)絡的具體實現(xiàn)技巧,需要的朋友可以參考下
    2017-12-12
  • MyBatis綁定錯誤提示BindingException:Invalid bound statement (not found)的解決方法

    MyBatis綁定錯誤提示BindingException:Invalid bound statement (not f

    這篇文章主要介紹了MyBatis綁定錯誤提示BindingException:Invalid bound statement (not found)的解決辦法,非常不錯,具有參考借鑒價值,需要的的朋友參考下吧
    2017-01-01

最新評論