SpringJDBC下操作数据源dataSource

1)SpringJDBC下操作数据源:

为了学习TransactionManager,我们先学习一下SpringJDBC下操作数据源:org.apache.commons.dbcp.BasicDataSource。做以下实验时,要先导几个包。commons-collections-3.2.1.jar,commons-dbcp-1.4.jar,commons-pool-1.5.4.jar,mysql-connector-java-3.1.10-bin.jar,spring-jdbc-3.0.5.RELEASE.jar,spring-orm-3.0.5.RELEASE.jar,spring-tx-3.0.5.RELEASE.jar,

例 2.2.1

先在web.xml中加入下面的语句:
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" >
         <property name="driverClassName"
                      value="com.mysql.jdbc.Driver"></property>
         <property name="url"
                      value="jdbc:mysql://localhost:3306/test"></property>
         <property name="username"
                      value="root"></property>
         <property name="password"
                      value="1234"></property>
    </bean>
    <bean id="jt" class="org.springframework.jdbc.core.JdbcTemplate">
        <constructor-arg ref="dataSource" />
    </bean>



package service;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.annotation.Resource;
import org.springframework.jdbc.core.JdbcTemplate;
import com.NiutDAO;
import service.interfac.ILoginService;
import org.springframework.jdbc.core.RowCallbackHandler;

public class LoginServiceImpl implements ILoginService {
    @Resource
    private JdbcTemplate jt;
    

    public void login() {
        System.out.println("LoginServiceImpl");
        String sql = "SELECT COUNT(id) FROM register";
        Object[] params = new Object[] {};
        jt.query(sql, params, new RowCallbackHandler() {
            public void processRow(ResultSet rs) throws SQLException {
                System.out.println(rs.getInt(1)) ;
            }
        });
    }    
}


运行结果:

LoginServiceImpl
10
after loginServic.login()


后记:processRow只能处理一行,想处理多行参考下段。
        final List objList = new ArrayList();  
        jdbcTemplate.query(listSql, new RowCallbackHandler() {  
            @Override  
            public void processRow(ResultSet rs) throws SQLException {  
                Map row = new HashMap();  
                row.put(rs.getInt("id"), rs.getString("name"));  
                objList.add(row);  
            }  
        });

例 2.2.1_1:(simpleJdbcTemplate的项目【比JdbcTemplate更好使用】):

TeacherPupil.java:

package com;

public class TeacherPupil  {
    public String toString() {  
        return "pname:"+pname+"tid:"+tid+"\nname:"+name+"\nage:"+age;  
    }  
    private String pname;
    public String getPname() {
        return pname;
    }
    public void setPname(String pname) {
        this.pname = pname;
    }
    private Integer tid;
    private String name;
    private Integer age;

    public Integer getTid() {
        return tid;
    }
    public void setTid(Integer tid) {
        this.tid = tid;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name == null ? null : name.trim();
    }
    public Integer getAge() {
        return age;
    }
    public void setAge(Integer age) {
        this.age = age;
    }
}

LoginServiceImpl.java:

package service;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import javax.annotation.Resource;

import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;

import service.interfac.ILoginService;

import org.springframework.jdbc.core.RowCallbackHandler;
import org.springframework.jdbc.core.namedparam.BeanPropertySqlParameterSource;
import org.springframework.jdbc.core.namedparam.SqlParameterSource;
import org.springframework.jdbc.core.simple.SimpleJdbcTemplate;

import com.Register;
import com.TeacherPupil;




public class LoginServiceImpl implements ILoginService {
    @Resource
    private JdbcTemplate jt1;
    public void setJt1(JdbcTemplate jt) {
        this.jt1 = jt;
    }
    
    @Resource
    private SimpleJdbcTemplate simpleJdbcTemplate;

    public void setSimpleJdbcTemplate(SimpleJdbcTemplate simpleJdbcTemplate) {
        this.simpleJdbcTemplate = simpleJdbcTemplate;
    }
    
    public void login() {
        System.out.println("LoginServiceImpl1111");
        String sql = "SELECT COUNT(id) FROM register";
        Object[] params = new Object[] {};
        jt1.query(sql, params, new RowCallbackHandler() {
            public void processRow(ResultSet rs) throws SQLException {
                System.out.println(rs.getInt(1)) ;
            }
        });
        int res=this.simpleJdbcTemplate.queryForInt(sql);
        System.out.println("res is "+res) ;
//增        
        Register reg = new Register();
        reg.setId(61);
        reg.setName("abc");
        reg.setAge(28);
        
        String sqlInsert = "insert into register(id,name,age) values(:id,:name,:age)";
        simpleJdbcTemplate.update(sqlInsert.toString(), new BeanPropertySqlParameterSource(reg));
        System.out.println("insert ok ") ;
        

///改
        StringBuffer sqlgai = new StringBuffer();
        sqlgai.append("update register set name=? where id=?");
        simpleJdbcTemplate.update(sqlgai.toString(),"abc1", 61);
        System.out.println("改 ok ") ;
///改2
        StringBuffer sqlgai1 = new StringBuffer();
        sqlgai1.append("update register set name=? where id=?");
        simpleJdbcTemplate.update(sqlgai1.toString(),new Object[] { "abc2", 61 });
        System.out.println("改 ok1 ") ;        
///批量改
        StringBuffer sqlgaibatch = new StringBuffer();
        sqlgaibatch.append("update register set name=? where id=?");
        
        List<Object[]> parameters = new ArrayList<Object[]>();


        parameters.add(new Object[] { "qwe1",1 });
        parameters.add(new Object[] { "ert2",2 });
        simpleJdbcTemplate.batchUpdate(sqlgaibatch.toString(), parameters);
        System.out.println("批量改 ok ") ;
        
/查询
        String sqldan = "select *  from register where id=?";
        Register regi=simpleJdbcTemplate.queryForObject(sqldan,new BeanPropertyRowMapper(Register.class),1);
        System.out.println("一个 regi "+ regi.getName()) ;
        
        
///查询多个        
        String sqlselec = "select * from register";
        List<Register> regis = simpleJdbcTemplate.query(sqlselec, new BeanPropertyRowMapper(Register.class));
        for(Object obj :regis){
            System.out.println(obj);
        }
        System.out.println("成功查询多个");
/
/*一对多,专门做一个类TeacherPupil,接收.用底下的as 别名方法,就可以解决teacher和pupil表中都有同名的字段name的方法。这样就可以从不同的表中同时取值了。*/
        String sqlotm = "select pupil.name as pname, teacher.name,pupil.tid from pupil,teacher where tid=teacher.id and teacher.name='qixy';";
        List<TeacherPupil> teaPup = simpleJdbcTemplate.query(sqlotm, new BeanPropertyRowMapper(TeacherPupil.class));
        for(Object obj :teaPup){
            System.out.println(obj);
        }    
        System.out.println("成功一对多");
///查询多个带条件        
        String sqlselecc = "select * from register where id<:id";
        List<Register> regisc = simpleJdbcTemplate.query(sqlselecc, new BeanPropertyRowMapper(Register.class), new BeanPropertySqlParameterSource(reg));
        for(Object obj :regisc){
            System.out.println(obj);
        }    
//删
        String sqldel = " delete from register where id=?";
        simpleJdbcTemplate.update(sqldel, 61);

    }  
    
    public static void main(String[] args)
    {
        ClassPathXmlApplicationContext cp=  new ClassPathXmlApplicationContext("applicationContext.xml");
        ILoginService ls=(ILoginService)cp.getBean("loginService");
        ls.login();
    }  
}

applicationContext.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
    <bean id="loginService" class="service.LoginServiceImpl" >
        <property name="simpleJdbcTemplate">
            <ref bean="simpleJdbcTemplate" />
        </property>
    </bean>
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" >
         <property name="driverClassName"
                      value="com.mysql.jdbc.Driver"></property>
         <property name="url"
                      value="jdbc:mysql://localhost:3306/test"></property>
         <property name="username"
                      value="root"></property>
         <property name="password"
                      value="1234"></property>
    </bean>
    <bean id="simpleJdbcTemplate" class="org.springframework.jdbc.core.simple.SimpleJdbcTemplate">
        <constructor-arg ref="dataSource" />
    </bean>
</beans>


更多内容请见原文,文章转载自:https://blog.csdn.net/qq_44591615/article/details/109206371

上一篇:springboot系列10: 多数据源


下一篇:LR: GLU-Net: Global-Local Universal Network for Dense Flow and Correspondences