Spring使用JdbcTemplate操作数据库

首先,假设如下SQL表中有数据username=test1,passwd=test1,address=test1

CREATE TABLE `login` (
  `username` varchar(10) default NULL,
  `passwd` varchar(10) default NULL,
  `address` varchar(10) default NULL
) ENGINE=InnoDB DEFAULT CHARSET=gb2312;

 

配置文件:

<?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="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
   <property name="driverClassName">
     <value>com.mysql.jdbc.Driver</value>
   </property>
   <property name="url">
     <value>jdbc:mysql://localhost:3306/javaee</value>
   </property>
   <property name="username">
     <value>root</value>
   </property>
   <property name="password">
     <value>1234</value>
   </property>
 </bean>
 <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
   <property name="dataSource">
     <ref local="dataSource"/>
   </property>
 </bean>

<bean id="personDAO" class="SpringJDBCSupport.ReadData.PersonDAO">
  <property name="jdbcTemplate">
    <ref local="jdbcTemplate"/>
  </property>
</bean> 
</beans>

 

 JavaBean:

package SpringJDBCSupport.ReadData;
import com.mysql.jdbc.Driver;
public class Person ...{
  private String name;
  private String password;
  private String address;
  public Person()...{
      
  }
  public Person(String name,String password,String address)...{
      this.name=name;
      this.password=password;
      this.address=address;
  }
public String getAddress() ...{
    return address;
}
public void setAddress(String address) ...{
    this.address = address;
}
public String getName() ...{
    return name;
}
public void setName(String name) ...{
    this.name = name;
}
public String getPassword() ...{
    return password;
}
public void setPassword(String password) ...{
    this.password = password;
}
public String toString()...{
    return this.getName()+"-"+this.getPassword()+"-"+this.getAddress();
}
}

 

DAO:

其中getPersonByRowCallbackHandler方法根据username获得person对象

package SpringJDBCSupport.ReadData;

import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Types;
import java.util.List;

import org.springframework.jdbc.core.BatchPreparedStatementSetter;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowCallbackHandler;

public class PersonDAO ...{
  private JdbcTemplate jdbcTemplate;

public JdbcTemplate getJdbcTemplate() ...{
    return jdbcTemplate;
}

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

public int insertPersonUseUpdate(Person person)...{
    String sql="insert into login values(?,?,?)";
    Object[] params=new Object[]...{
            person.getName(),
            person.getPassword(),
            person.getAddress()
    };
    return this.getJdbcTemplate().update(sql,params);
}
public int insertPersonUseExecute(Person person)...{
    String sql="insert into login values(?,?,?)";
    Object[] params=new Object[]...{
            person.getName(),
            person.getPassword(),
            person.getAddress()
    };
    int[] types=new int[]...{
            Types.VARCHAR,
            Types.VARCHAR,
            Types.VARCHAR
    };
    return this.getJdbcTemplate().update(sql,params,types);
}
public int[] updatePersonUseBatchUpdate( final List persons)...{
    String sql="insert into login values(?,?,?)";
    BatchPreparedStatementSetter setter=null;
    setter=new BatchPreparedStatementSetter()...{
        public int getBatchSize()...{
            return persons.size();
        }
        public void setValues(PreparedStatement ps,int index) throws SQLException...{
            Person person=(Person)persons.get(index);
            ps.setString(1,person.getName());
            ps.setString(2,person.getPassword());
            ps.setString(3,person.getAddress());
        }
    };
    return this.getJdbcTemplate().batchUpdate(sql,setter);
}

public Person getPersonByRowCallbackHandler(String username)...{

    String sql="select * from login where username=?";
    final Person person=new Person();
    final Object params[]=new Object[]...{username};
    this.getJdbcTemplate().query(sql,params,new RowCallbackHandler()...{
        public void processRow(ResultSet rs)throws SQLException...{
            person.setName(rs.getString("username"));
            person.setPassword(rs.getString("passwd"));
            person.setAddress(rs.getString("address"));
        }
    });
    return person;
}
  
}

 

测试代码:

package SpringJDBCSupport.ReadData;

import java.io.File;
import java.util.ArrayList;
import java.util.List;

import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.core.io.FileSystemResource;

public class TestJDBCTemplate ...{

    public static String filePath="";
    public static BeanFactory factory=null;
    public static void main(String[] args) ...{
        filePath=System.getProperty("user.dir")+File.separator+"SpringJDBCSupport"+File.separator+"ReadData"+File.separator+"hello.xml";
        factory=new XmlBeanFactory(new FileSystemResource(filePath));
        PersonDAO personDAO=(PersonDAO)factory.getBean("personDAO");
        /**//*
         * 准备数据
         */
        Person p1=new Person("test1","test1","test1");
        Person p2=new Person("test2","test2","test2");
        Person p3=new Person("test3","test3","test3");
        Person p4=new Person("test4","test4","test4");
        Person p5=new Person("test5","test5","test5");
        List persons=new ArrayList();
        persons.add(p3);
        persons.add(p4);
        persons.add(p5);
        //使用jdbcTemplate.update方式
    //    personDAO.insertPersonUseUpdate(p1);
        //使用jdbcTemplate.execute方式
    //    personDAO.insertPersonUseExecute(p2);
    //    //使用jdbcTemplate批处理方式
    //    personDAO.updatePersonUseBatchUpdate(persons);
        
        //使用RowCallbackHandler执行一次查询,并打印person信息
        System.out.println(personDAO.getPersonByRowCallbackHandler("test1"));
    }
    
    

}

 

运行结果:

test1-test1-test1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JdbcTemplateSpring框架提供的一个用于简化数据库操作的工具类。它封装了JDBC的细节,提供了一组简洁的API来执行SQL语句并处理结果集。下面是使用JdbcTemplate进行数据库操作的基本步骤: 1. 配置数据源:在Spring配置文件中配置数据源,例如使用`org.springframework.jdbc.datasource.DriverManagerDataSource`类配置一个基于驱动程序管理的数据源。 2. 创建JdbcTemplate对象:在Spring配置文件中创建一个`org.springframework.jdbc.core.JdbcTemplate`对象,并将数据源注入到该对象中。 3. 编写SQL语句:根据需求编写SQL语句,可以使用占位符来代替参数。 4. 执行SQL语句:使用JdbcTemplate对象的方法执行SQL语句,例如`update()`方法用于执行INSERT、UPDATE和DELETE语句,`query()`方法用于执行SELECT语句。 5. 处理结果集:根据需要处理查询结果集,可以使用`RowMapper`接口来映射每一行的数据到Java对象。 下面是一个简单的示例代码: ```java import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.RowMapper; public class UserDao { private JdbcTemplate jdbcTemplate; public void setJdbcTemplate(JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; } public void addUser(User user) { String sql = "INSERT INTO user (id, name, age) VALUES (?, ?, ?)"; jdbcTemplate.update(sql, user.getId(), user.getName(), user.getAge()); } public User getUserById(int id) { String sql = "SELECT * FROM user WHERE id = ?"; RowMapper<User> rowMapper = new UserRowMapper(); return jdbcTemplate.queryForObject(sql, rowMapper, id); } } class User { private int id; private String name; private int age; // 省略getter和setter方法 } class UserRowMapper implements RowMapper<User> { @Override public User mapRow(ResultSet rs, int rowNum) throws SQLException { User user = new User(); user.setId(rs.getInt("id")); user.setName(rs.getString("name")); user.setAge(rs.getInt("age")); return user; } } ``` 以上代码演示了如何使用JdbcTemplate进行数据库操作,包括插入数据和查询数据。你可以根据具体的需求进行扩展和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值