<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FSpring%2FSqlUpdate</id>
		<title>Java/Spring/SqlUpdate - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FSpring%2FSqlUpdate"/>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Spring/SqlUpdate&amp;action=history"/>
		<updated>2026-04-21T10:45:17Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java/Spring/SqlUpdate&amp;diff=6607&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Spring/SqlUpdate&amp;diff=6607&amp;oldid=prev"/>
				<updated>2010-06-01T06:16:42Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 06:16, 1 июня 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java/Spring/SqlUpdate&amp;diff=6606&amp;oldid=prev</id>
		<title> в 18:01, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Spring/SqlUpdate&amp;diff=6606&amp;oldid=prev"/>
				<updated>2010-05-31T18:01:44Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Delete Statement With Parameter ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
       &lt;br /&gt;
File: context.xml&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;UTF-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;beans xmlns=&amp;quot;http://www.springframework.org/schema/beans&amp;quot;&lt;br /&gt;
       xmlns:xsi=&amp;quot;http://www.w3.org/2001/XMLSchema-instance&amp;quot;&lt;br /&gt;
       xmlns:util=&amp;quot;http://www.springframework.org/schema/util&amp;quot;&lt;br /&gt;
       xmlns:tx=&amp;quot;http://www.springframework.org/schema/tx&amp;quot;&lt;br /&gt;
       xmlns:aop=&amp;quot;http://www.springframework.org/schema/aop&amp;quot;&lt;br /&gt;
       xmlns:lang=&amp;quot;http://www.springframework.org/schema/lang&amp;quot;&lt;br /&gt;
       xsi:schemaLocation=&amp;quot;http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/lang http://www.springframework.org/schema/lang/spring-lang-2.0.xsd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;!--&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;dataSource&amp;quot; class=&amp;quot;org.apache.rumons.dbcp.BasicDataSource&amp;quot; destroy-method=&amp;quot;close&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;driverClassName&amp;quot; value=&amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;url&amp;quot; value=&amp;quot;jdbc:oracle:thin:@oracle.devcake.co.uk:1521:INTL&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;username&amp;quot; value=&amp;quot;sa&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;password&amp;quot; value=&amp;quot;&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
--&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;dataSource&amp;quot; class=&amp;quot;org.apache.rumons.dbcp.BasicDataSource&amp;quot; destroy-method=&amp;quot;close&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;driverClassName&amp;quot; value=&amp;quot;org.hsqldb.jdbcDriver&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;url&amp;quot; value=&amp;quot;jdbc:hsqldb:mem:.&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;username&amp;quot; value=&amp;quot;sa&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;password&amp;quot; value=&amp;quot;&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
&amp;lt;!--&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;mysqlDataSource&amp;quot; class=&amp;quot;org.apache.rumons.dbcp.BasicDataSource&amp;quot; destroy-method=&amp;quot;close&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;driverClassName&amp;quot; value=&amp;quot;com.mysql.jdbc.Driver&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;url&amp;quot; value=&amp;quot;jdbc:mysql://dbhost-prospring-psql/prospring&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;username&amp;quot; value=&amp;quot;sa&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;password&amp;quot; value=&amp;quot;&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
--&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;lobHandler&amp;quot; class=&amp;quot;org.springframework.jdbc.support.lob.OracleLobHandler&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;nativeJdbcExtractor&amp;quot; ref=&amp;quot;nativeJdbcExtractor&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;nativeJdbcExtractor&amp;quot; class=&amp;quot;org.springframework.jdbc.support.nativejdbc.rumonsDbcpNativeJdbcExtractor&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;jdbcTemplate&amp;quot; class=&amp;quot;org.springframework.jdbc.core.JdbcTemplate&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;dataSource&amp;quot; ref=&amp;quot;dataSource&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/beans&amp;gt;&lt;br /&gt;
&lt;br /&gt;
File: Main.java&lt;br /&gt;
import java.sql.Types;&lt;br /&gt;
import java.util.ArrayList;&lt;br /&gt;
import java.util.Date;&lt;br /&gt;
import java.util.HashMap;&lt;br /&gt;
import java.util.List;&lt;br /&gt;
import java.util.Map;&lt;br /&gt;
import javax.sql.DataSource;&lt;br /&gt;
import org.springframework.context.ApplicationContext;&lt;br /&gt;
import org.springframework.context.support.ClassPathXmlApplicationContext;&lt;br /&gt;
import org.springframework.jdbc.core.JdbcTemplate;&lt;br /&gt;
import org.springframework.jdbc.core.SqlParameter;&lt;br /&gt;
import org.springframework.jdbc.object.SqlUpdate;&lt;br /&gt;
import org.springframework.jdbc.support.GeneratedKeyHolder;&lt;br /&gt;
import org.springframework.jdbc.support.KeyHolder;&lt;br /&gt;
class Main {&lt;br /&gt;
  public static void main(String args[]) throws Exception {&lt;br /&gt;
    ApplicationContext ac = new ClassPathXmlApplicationContext(&amp;quot;context.xml&amp;quot;, Main.class);&lt;br /&gt;
    DataSource dataSource = (DataSource) ac.getBean(&amp;quot;dataSource&amp;quot;);&lt;br /&gt;
    //DataSource mysqlDataSource = (DataSource) ac.getBean(&amp;quot;mysqlDataSource&amp;quot;);&lt;br /&gt;
    DeleteWhereIdGreater deleteWhereIdGreater = new DeleteWhereIdGreater(dataSource);&lt;br /&gt;
    &lt;br /&gt;
    deleteWhereIdGreater.update(1L);&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
class DeleteWhereIdGreater extends SqlUpdate {&lt;br /&gt;
  private static final String SQL = &amp;quot;delete from customer where id &amp;gt; ?&amp;quot;;&lt;br /&gt;
  DeleteWhereIdGreater(DataSource dataSource) {&lt;br /&gt;
      super(dataSource, SQL);&lt;br /&gt;
      declareParameter(new SqlParameter(Types.INTEGER));&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Extends SqlUpdate And Provide Customized Parameters ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
       &lt;br /&gt;
File: context.xml&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;UTF-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;beans xmlns=&amp;quot;http://www.springframework.org/schema/beans&amp;quot;&lt;br /&gt;
       xmlns:xsi=&amp;quot;http://www.w3.org/2001/XMLSchema-instance&amp;quot;&lt;br /&gt;
       xmlns:util=&amp;quot;http://www.springframework.org/schema/util&amp;quot;&lt;br /&gt;
       xmlns:tx=&amp;quot;http://www.springframework.org/schema/tx&amp;quot;&lt;br /&gt;
       xmlns:aop=&amp;quot;http://www.springframework.org/schema/aop&amp;quot;&lt;br /&gt;
       xmlns:lang=&amp;quot;http://www.springframework.org/schema/lang&amp;quot;&lt;br /&gt;
       xsi:schemaLocation=&amp;quot;http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/lang http://www.springframework.org/schema/lang/spring-lang-2.0.xsd&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;dataSource&amp;quot; class=&amp;quot;org.apache.rumons.dbcp.BasicDataSource&amp;quot; destroy-method=&amp;quot;close&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;driverClassName&amp;quot; value=&amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;url&amp;quot; value=&amp;quot;jdbc:oracle:thin:@oracle.devcake.co.uk:1521:INTL&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;username&amp;quot; value=&amp;quot;sa&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;password&amp;quot; value=&amp;quot;&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;mysqlDataSource&amp;quot; class=&amp;quot;org.apache.rumons.dbcp.BasicDataSource&amp;quot; destroy-method=&amp;quot;close&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;driverClassName&amp;quot; value=&amp;quot;com.mysql.jdbc.Driver&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;url&amp;quot; value=&amp;quot;jdbc:mysql://dbhost-prospring-psql/prospring&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;username&amp;quot; value=&amp;quot;sa&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;password&amp;quot; value=&amp;quot;&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;lobHandler&amp;quot; class=&amp;quot;org.springframework.jdbc.support.lob.OracleLobHandler&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;nativeJdbcExtractor&amp;quot; ref=&amp;quot;nativeJdbcExtractor&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;nativeJdbcExtractor&amp;quot; class=&amp;quot;org.springframework.jdbc.support.nativejdbc.rumonsDbcpNativeJdbcExtractor&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;jdbcTemplate&amp;quot; class=&amp;quot;org.springframework.jdbc.core.JdbcTemplate&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;dataSource&amp;quot; ref=&amp;quot;dataSource&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/beans&amp;gt;&lt;br /&gt;
&lt;br /&gt;
File: Main.java&lt;br /&gt;
import java.sql.Types;&lt;br /&gt;
import java.util.ArrayList;&lt;br /&gt;
import java.util.Date;&lt;br /&gt;
import java.util.HashMap;&lt;br /&gt;
import java.util.List;&lt;br /&gt;
import java.util.Map;&lt;br /&gt;
import javax.sql.DataSource;&lt;br /&gt;
import org.springframework.context.ApplicationContext;&lt;br /&gt;
import org.springframework.context.support.ClassPathXmlApplicationContext;&lt;br /&gt;
import org.springframework.jdbc.core.JdbcTemplate;&lt;br /&gt;
import org.springframework.jdbc.core.SqlParameter;&lt;br /&gt;
import org.springframework.jdbc.object.SqlUpdate;&lt;br /&gt;
import org.springframework.jdbc.support.GeneratedKeyHolder;&lt;br /&gt;
import org.springframework.jdbc.support.KeyHolder;&lt;br /&gt;
class Main {&lt;br /&gt;
  public static void main(String args[]) throws Exception {&lt;br /&gt;
    ApplicationContext ac = new ClassPathXmlApplicationContext(&amp;quot;context.xml&amp;quot;, Main.class);&lt;br /&gt;
    DataSource dataSource = (DataSource) ac.getBean(&amp;quot;dataSource&amp;quot;);&lt;br /&gt;
    DataSource mysqlDataSource = (DataSource) ac.getBean(&amp;quot;mysqlDataSource&amp;quot;);&lt;br /&gt;
    Insert insert = new Insert(dataSource);&lt;br /&gt;
    insert.update(new Object[] { 3L, &amp;quot;A&amp;quot;, &amp;quot;B&amp;quot;, null, null });&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
class Insert extends SqlUpdate {&lt;br /&gt;
  private static final String SQL = &amp;quot;insert into t_customer (id, first_name, last_name, last_login, &amp;quot;&lt;br /&gt;
      + &amp;quot;comments) values (?, ?, ?, ?, ?)&amp;quot;;&lt;br /&gt;
  Insert(DataSource dataSource) {&lt;br /&gt;
    super(dataSource, SQL);&lt;br /&gt;
    declareParameter(new SqlParameter(Types.INTEGER));&lt;br /&gt;
    declareParameter(new SqlParameter(Types.VARCHAR));&lt;br /&gt;
    declareParameter(new SqlParameter(Types.VARCHAR));&lt;br /&gt;
    declareParameter(new SqlParameter(Types.TIMESTAMP));&lt;br /&gt;
    declareParameter(new SqlParameter(Types.CLOB));&lt;br /&gt;
  }&lt;br /&gt;
  void insert(long id, String firstName, String lastName, Date lastLogin, String comments) {&lt;br /&gt;
    update(new Object[] { id, firstName, lastName, lastLogin, comments });&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Extends SqlUpdateExecute Update Statement ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
       &lt;br /&gt;
File: EmployeeDaoImpl.java&lt;br /&gt;
import java.io.IOException;&lt;br /&gt;
import java.io.InputStream;&lt;br /&gt;
import java.io.OutputStream;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
import java.sql.SQLException;&lt;br /&gt;
import java.sql.Types;&lt;br /&gt;
import java.util.ArrayList;&lt;br /&gt;
import java.util.Collections;&lt;br /&gt;
import java.util.HashMap;&lt;br /&gt;
import java.util.List;&lt;br /&gt;
import java.util.Map;&lt;br /&gt;
import javax.sql.DataSource;&lt;br /&gt;
import org.springframework.dao.DataAccessException;&lt;br /&gt;
import org.springframework.jdbc.core.BatchPreparedStatementSetter;&lt;br /&gt;
import org.springframework.jdbc.core.RowMapper;&lt;br /&gt;
import org.springframework.jdbc.core.SqlOutParameter;&lt;br /&gt;
import org.springframework.jdbc.core.SqlParameter;&lt;br /&gt;
import org.springframework.jdbc.core.simple.ParameterizedRowMapper;&lt;br /&gt;
import org.springframework.jdbc.core.simple.SimpleJdbcTemplate;&lt;br /&gt;
import org.springframework.jdbc.core.support.AbstractLobCreatingPreparedStatementCallback;&lt;br /&gt;
import org.springframework.jdbc.core.support.AbstractLobStreamingResultSetExtractor;&lt;br /&gt;
import org.springframework.jdbc.core.support.JdbcDaoSupport;&lt;br /&gt;
import org.springframework.jdbc.object.MappingSqlQuery;&lt;br /&gt;
import org.springframework.jdbc.object.SqlUpdate;&lt;br /&gt;
import org.springframework.jdbc.object.StoredProcedure;&lt;br /&gt;
import org.springframework.jdbc.support.lob.DefaultLobHandler;&lt;br /&gt;
import org.springframework.jdbc.support.lob.LobCreator;&lt;br /&gt;
import org.springframework.jdbc.support.lob.LobHandler;&lt;br /&gt;
import org.springframework.jdbc.support.nativejdbc.SimpleNativeJdbcExtractor;&lt;br /&gt;
import org.springframework.util.FileCopyUtils;&lt;br /&gt;
//import org.apache.rumons.dbcp.BasicDataSource;&lt;br /&gt;
&lt;br /&gt;
public class EmployeeDaoImpl extends JdbcDaoSupport{&lt;br /&gt;
  private UpdateAgeQuery updateAgeQuery;&lt;br /&gt;
  &lt;br /&gt;
  protected void initDao() throws Exception {&lt;br /&gt;
    super.initDao();&lt;br /&gt;
    getJdbcTemplate().setNativeJdbcExtractor(new SimpleNativeJdbcExtractor());&lt;br /&gt;
    updateAgeQuery = new UpdateAgeQuery(getDataSource());&lt;br /&gt;
  }&lt;br /&gt;
  public void updateAge(Integer employeeId, Integer age) {&lt;br /&gt;
    updateAgeQuery.update(new Object[] { age, employeeId });&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
class UpdateAgeQuery extends SqlUpdate {&lt;br /&gt;
  private static final String SQL_QUERY = &amp;quot;UPDATE employee SET age = ? WHERE id = ?&amp;quot;;&lt;br /&gt;
  public UpdateAgeQuery(DataSource dataSource) {&lt;br /&gt;
    super(dataSource, SQL_QUERY);&lt;br /&gt;
    declareParameter(new SqlParameter(&amp;quot;age&amp;quot;, Types.INTEGER));&lt;br /&gt;
    declareParameter(new SqlParameter(&amp;quot;id&amp;quot;, Types.INTEGER));&lt;br /&gt;
    compile();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
  &lt;br /&gt;
    &lt;br /&gt;
class Employee {&lt;br /&gt;
  private Integer id;&lt;br /&gt;
  private Name name = new Name();&lt;br /&gt;
  private Integer age;&lt;br /&gt;
  private Sex sex;&lt;br /&gt;
  private Address address = new Address();&lt;br /&gt;
  private List&amp;lt;PhoneNumber&amp;gt; phoneNumbers = new ArrayList&amp;lt;PhoneNumber&amp;gt;();&lt;br /&gt;
  public Employee() {&lt;br /&gt;
  }&lt;br /&gt;
  public Employee(String firstName, String lastName) {&lt;br /&gt;
    this.getName().setFirst(firstName);&lt;br /&gt;
    this.getName().setLast(lastName);&lt;br /&gt;
  }&lt;br /&gt;
  void setId(Integer id) {&lt;br /&gt;
    this.id = id;&lt;br /&gt;
  }&lt;br /&gt;
  public Integer getId() {&lt;br /&gt;
    return id;&lt;br /&gt;
  }&lt;br /&gt;
  public Address getAddress() {&lt;br /&gt;
    return address;&lt;br /&gt;
  }&lt;br /&gt;
  public Integer getAge() {&lt;br /&gt;
    return age;&lt;br /&gt;
  }&lt;br /&gt;
  public void setAge(Integer age) {&lt;br /&gt;
    this.age = age;&lt;br /&gt;
  }&lt;br /&gt;
  public Name getName() {&lt;br /&gt;
    return name;&lt;br /&gt;
  }&lt;br /&gt;
  public List&amp;lt;PhoneNumber&amp;gt; getPhoneNumbers() {&lt;br /&gt;
    return Collections.unmodifiableList(phoneNumbers);&lt;br /&gt;
  }&lt;br /&gt;
  public void addPhoneNumber(PhoneNumber phoneNumber) {&lt;br /&gt;
    this.phoneNumbers.add(phoneNumber);&lt;br /&gt;
  }&lt;br /&gt;
  public void removePhoneNumber(PhoneNumber phoneNumber) {&lt;br /&gt;
    this.phoneNumbers.remove(phoneNumber);&lt;br /&gt;
  }&lt;br /&gt;
  public void removePhoneNumber(int index) {&lt;br /&gt;
    this.phoneNumbers.remove(index);&lt;br /&gt;
  }&lt;br /&gt;
  public Sex getSex() {&lt;br /&gt;
    return sex;&lt;br /&gt;
  }&lt;br /&gt;
  public void setSex(Sex sex) {&lt;br /&gt;
    this.sex = sex;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
abstract class Sex {&lt;br /&gt;
  public static final Sex MALE = new Male();&lt;br /&gt;
  public static final Sex FEMALE = new Female();&lt;br /&gt;
  public boolean equals(Object o) {&lt;br /&gt;
    if (o == null) {&lt;br /&gt;
      return false;&lt;br /&gt;
    }&lt;br /&gt;
    return getClass().equals(o.getClass());&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
class PhoneNumber {&lt;br /&gt;
}&lt;br /&gt;
class Address {&lt;br /&gt;
  private String line1;&lt;br /&gt;
  private String line2;&lt;br /&gt;
  private String city;&lt;br /&gt;
  private String state;&lt;br /&gt;
  private String zip;&lt;br /&gt;
  public void setLine1(String line1) {&lt;br /&gt;
    this.line1 = line1;&lt;br /&gt;
  }&lt;br /&gt;
  public String getLine1() {&lt;br /&gt;
    return this.line1;&lt;br /&gt;
  }&lt;br /&gt;
  public void setLine2(String line2) {&lt;br /&gt;
    this.line2 = line2;&lt;br /&gt;
  }&lt;br /&gt;
  public String getLine2() {&lt;br /&gt;
    return this.line2;&lt;br /&gt;
  }&lt;br /&gt;
  public void setCity(String city) {&lt;br /&gt;
    this.city = city;&lt;br /&gt;
  }&lt;br /&gt;
  public String getCity() {&lt;br /&gt;
    return this.city;&lt;br /&gt;
  }&lt;br /&gt;
  public void setState(String state) {&lt;br /&gt;
    this.state = state;&lt;br /&gt;
  }&lt;br /&gt;
  public String getState() {&lt;br /&gt;
    return this.state;&lt;br /&gt;
  }&lt;br /&gt;
  public void setZip(String zip) {&lt;br /&gt;
    this.zip = zip;&lt;br /&gt;
  }&lt;br /&gt;
  public String getZip() {&lt;br /&gt;
    return this.zip;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
final class Male extends Sex {&lt;br /&gt;
  protected Male() {&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
final class Female extends Sex {&lt;br /&gt;
  protected Female() {&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
class Name {&lt;br /&gt;
  private String first;&lt;br /&gt;
  private String middle;&lt;br /&gt;
  private String last;&lt;br /&gt;
  public void setFirst(String first) {&lt;br /&gt;
    this.first = first;&lt;br /&gt;
  }&lt;br /&gt;
  public String getFirst() {&lt;br /&gt;
    return this.first;&lt;br /&gt;
  }&lt;br /&gt;
  public void setMiddle(String middle) {&lt;br /&gt;
    this.middle = middle;&lt;br /&gt;
  }&lt;br /&gt;
  public String getMiddle() {&lt;br /&gt;
    return this.middle;&lt;br /&gt;
  }&lt;br /&gt;
  public void setLast(String last) {&lt;br /&gt;
    this.last = last;&lt;br /&gt;
  }&lt;br /&gt;
  public String getLast() {&lt;br /&gt;
    return this.last;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: Main.java&lt;br /&gt;
import java.util.Date;&lt;br /&gt;
import java.util.GregorianCalendar;&lt;br /&gt;
import org.springframework.context.ApplicationContext;&lt;br /&gt;
import org.springframework.context.support.ClassPathXmlApplicationContext;&lt;br /&gt;
class Main {&lt;br /&gt;
  public static void main(String args[]) throws Exception {&lt;br /&gt;
    ApplicationContext ctx = new ClassPathXmlApplicationContext(&lt;br /&gt;
        &amp;quot;context.xml&amp;quot;);&lt;br /&gt;
    EmployeeDaoImpl ws = (EmployeeDaoImpl) ctx.getBean(&amp;quot;employeeDao&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: context.xml&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;UTF-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE beans PUBLIC &amp;quot;-//SPRING//DTD BEAN//EN&amp;quot;&lt;br /&gt;
    &amp;quot;http://www.springframework.org/dtd/spring-beans.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;beans&amp;gt;&lt;br /&gt;
&amp;lt;bean id=&amp;quot;dataSource&amp;quot; class=&amp;quot;org.apache.rumons.dbcp.BasicDataSource&amp;quot;&lt;br /&gt;
      destroy-method=&amp;quot;close&amp;quot;&amp;gt;&lt;br /&gt;
  &amp;lt;property name=&amp;quot;driverClassName&amp;quot; value=&amp;quot;org.hsqldb.jdbcDriver&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;property name=&amp;quot;url&amp;quot; value=&amp;quot;jdbc:hsqldb:mem:.&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;property name=&amp;quot;username&amp;quot; value=&amp;quot;sa&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;property name=&amp;quot;password&amp;quot; value=&amp;quot;&amp;quot;/&amp;gt;&lt;br /&gt;
&amp;lt;/bean&amp;gt;&lt;br /&gt;
&amp;lt;bean id=&amp;quot;employeeDao&amp;quot; class=&amp;quot;EmployeeDaoImpl&amp;quot;&amp;gt;&lt;br /&gt;
  &amp;lt;property name=&amp;quot;dataSource&amp;quot; ref=&amp;quot;dataSource&amp;quot;/&amp;gt;&lt;br /&gt;
&amp;lt;/bean&amp;gt;&lt;br /&gt;
&amp;lt;/beans&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== extends SqlUpdate to create named sql statement with parameters ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
       &lt;br /&gt;
File: context.xml&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;UTF-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;beans xmlns=&amp;quot;http://www.springframework.org/schema/beans&amp;quot;&lt;br /&gt;
       xmlns:xsi=&amp;quot;http://www.w3.org/2001/XMLSchema-instance&amp;quot;&lt;br /&gt;
       xmlns:util=&amp;quot;http://www.springframework.org/schema/util&amp;quot;&lt;br /&gt;
       xmlns:tx=&amp;quot;http://www.springframework.org/schema/tx&amp;quot;&lt;br /&gt;
       xmlns:aop=&amp;quot;http://www.springframework.org/schema/aop&amp;quot;&lt;br /&gt;
       xmlns:lang=&amp;quot;http://www.springframework.org/schema/lang&amp;quot;&lt;br /&gt;
       xsi:schemaLocation=&amp;quot;http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd&lt;br /&gt;
                           http://www.springframework.org/schema/lang http://www.springframework.org/schema/lang/spring-lang-2.0.xsd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;!--&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;dataSource&amp;quot; class=&amp;quot;org.apache.rumons.dbcp.BasicDataSource&amp;quot; destroy-method=&amp;quot;close&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;driverClassName&amp;quot; value=&amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;url&amp;quot; value=&amp;quot;jdbc:oracle:thin:@oracle.devcake.co.uk:1521:INTL&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;username&amp;quot; value=&amp;quot;sa&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;password&amp;quot; value=&amp;quot;&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
--&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;dataSource&amp;quot; class=&amp;quot;org.apache.rumons.dbcp.BasicDataSource&amp;quot; destroy-method=&amp;quot;close&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;driverClassName&amp;quot; value=&amp;quot;org.hsqldb.jdbcDriver&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;url&amp;quot; value=&amp;quot;jdbc:hsqldb:mem:.&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;username&amp;quot; value=&amp;quot;sa&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;password&amp;quot; value=&amp;quot;&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
&amp;lt;!--&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;mysqlDataSource&amp;quot; class=&amp;quot;org.apache.rumons.dbcp.BasicDataSource&amp;quot; destroy-method=&amp;quot;close&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;driverClassName&amp;quot; value=&amp;quot;com.mysql.jdbc.Driver&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;url&amp;quot; value=&amp;quot;jdbc:mysql://dbhost-prospring-psql/prospring&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;username&amp;quot; value=&amp;quot;sa&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;password&amp;quot; value=&amp;quot;&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
--&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;lobHandler&amp;quot; class=&amp;quot;org.springframework.jdbc.support.lob.OracleLobHandler&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;nativeJdbcExtractor&amp;quot; ref=&amp;quot;nativeJdbcExtractor&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;nativeJdbcExtractor&amp;quot; class=&amp;quot;org.springframework.jdbc.support.nativejdbc.rumonsDbcpNativeJdbcExtractor&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;bean id=&amp;quot;jdbcTemplate&amp;quot; class=&amp;quot;org.springframework.jdbc.core.JdbcTemplate&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;dataSource&amp;quot; ref=&amp;quot;dataSource&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/bean&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/beans&amp;gt;&lt;br /&gt;
&lt;br /&gt;
File: Main.java&lt;br /&gt;
import java.sql.Types;&lt;br /&gt;
import java.util.ArrayList;&lt;br /&gt;
import java.util.Date;&lt;br /&gt;
import java.util.HashMap;&lt;br /&gt;
import java.util.List;&lt;br /&gt;
import java.util.Map;&lt;br /&gt;
import javax.sql.DataSource;&lt;br /&gt;
import org.springframework.context.ApplicationContext;&lt;br /&gt;
import org.springframework.context.support.ClassPathXmlApplicationContext;&lt;br /&gt;
import org.springframework.jdbc.core.JdbcTemplate;&lt;br /&gt;
import org.springframework.jdbc.core.SqlParameter;&lt;br /&gt;
import org.springframework.jdbc.object.SqlUpdate;&lt;br /&gt;
import org.springframework.jdbc.support.GeneratedKeyHolder;&lt;br /&gt;
import org.springframework.jdbc.support.KeyHolder;&lt;br /&gt;
class Main {&lt;br /&gt;
  public static void main(String args[]) throws Exception {&lt;br /&gt;
    ApplicationContext ac = new ClassPathXmlApplicationContext(&amp;quot;context.xml&amp;quot;, Main.class);&lt;br /&gt;
    DataSource dataSource = (DataSource) ac.getBean(&amp;quot;dataSource&amp;quot;);&lt;br /&gt;
    //DataSource mysqlDataSource = (DataSource) ac.getBean(&amp;quot;mysqlDataSource&amp;quot;);&lt;br /&gt;
    NamedInsert namedInsert = new NamedInsert(dataSource);&lt;br /&gt;
    Map&amp;lt;String, Object&amp;gt; parameterMap = new HashMap&amp;lt;String, Object&amp;gt;();&lt;br /&gt;
    parameterMap.put(&amp;quot;id&amp;quot;, 6L);&lt;br /&gt;
    parameterMap.put(&amp;quot;firstName&amp;quot;, &amp;quot;A&amp;quot;);&lt;br /&gt;
    parameterMap.put(&amp;quot;lastName&amp;quot;, &amp;quot;B&amp;quot;);&lt;br /&gt;
    parameterMap.put(&amp;quot;lastLogin&amp;quot;, null);&lt;br /&gt;
    parameterMap.put(&amp;quot;comments&amp;quot;, null);&lt;br /&gt;
    namedInsert.updateByNamedParam(parameterMap);&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
class NamedInsert extends SqlUpdate {&lt;br /&gt;
  private static final String SQL = &amp;quot;insert into t_customer (id, first_name, last_name, last_login, &amp;quot; +&lt;br /&gt;
          &amp;quot;comments) values (:id, :firstName, :lastName, :lastLogin, :comments)&amp;quot;;&lt;br /&gt;
  NamedInsert(DataSource dataSource) {&lt;br /&gt;
      super(dataSource, SQL);&lt;br /&gt;
      declareParameter(new SqlParameter(Types.INTEGER));&lt;br /&gt;
      declareParameter(new SqlParameter(Types.VARCHAR));&lt;br /&gt;
      declareParameter(new SqlParameter(Types.VARCHAR));&lt;br /&gt;
      declareParameter(new SqlParameter(Types.TIMESTAMP));&lt;br /&gt;
      declareParameter(new SqlParameter(Types.CLOB));&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Extends SqlUpdate To Execute Insert Statement ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
File: EmployeeDaoImpl.java&lt;br /&gt;
import java.io.IOException;&lt;br /&gt;
import java.io.InputStream;&lt;br /&gt;
import java.io.OutputStream;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
import java.sql.SQLException;&lt;br /&gt;
import java.sql.Types;&lt;br /&gt;
import java.util.ArrayList;&lt;br /&gt;
import java.util.Collections;&lt;br /&gt;
import java.util.HashMap;&lt;br /&gt;
import java.util.List;&lt;br /&gt;
import java.util.Map;&lt;br /&gt;
import javax.sql.DataSource;&lt;br /&gt;
import org.springframework.dao.DataAccessException;&lt;br /&gt;
import org.springframework.jdbc.core.BatchPreparedStatementSetter;&lt;br /&gt;
import org.springframework.jdbc.core.RowMapper;&lt;br /&gt;
import org.springframework.jdbc.core.SqlOutParameter;&lt;br /&gt;
import org.springframework.jdbc.core.SqlParameter;&lt;br /&gt;
import org.springframework.jdbc.core.simple.ParameterizedRowMapper;&lt;br /&gt;
import org.springframework.jdbc.core.simple.SimpleJdbcTemplate;&lt;br /&gt;
import org.springframework.jdbc.core.support.AbstractLobCreatingPreparedStatementCallback;&lt;br /&gt;
import org.springframework.jdbc.core.support.AbstractLobStreamingResultSetExtractor;&lt;br /&gt;
import org.springframework.jdbc.core.support.JdbcDaoSupport;&lt;br /&gt;
import org.springframework.jdbc.object.MappingSqlQuery;&lt;br /&gt;
import org.springframework.jdbc.object.SqlUpdate;&lt;br /&gt;
import org.springframework.jdbc.object.StoredProcedure;&lt;br /&gt;
import org.springframework.jdbc.support.lob.DefaultLobHandler;&lt;br /&gt;
import org.springframework.jdbc.support.lob.LobCreator;&lt;br /&gt;
import org.springframework.jdbc.support.lob.LobHandler;&lt;br /&gt;
import org.springframework.jdbc.support.nativejdbc.SimpleNativeJdbcExtractor;&lt;br /&gt;
import org.springframework.util.FileCopyUtils;&lt;br /&gt;
//import org.apache.rumons.dbcp.BasicDataSource;&lt;br /&gt;
&lt;br /&gt;
public class EmployeeDaoImpl extends JdbcDaoSupport{&lt;br /&gt;
  private AddEmployeeQuery addEmployeeQuery;&lt;br /&gt;
  &lt;br /&gt;
  &lt;br /&gt;
  protected void initDao() throws Exception {&lt;br /&gt;
    super.initDao();&lt;br /&gt;
    getJdbcTemplate().setNativeJdbcExtractor(new SimpleNativeJdbcExtractor());&lt;br /&gt;
    addEmployeeQuery = new AddEmployeeQuery(getDataSource());&lt;br /&gt;
  }&lt;br /&gt;
  &lt;br /&gt;
  public void add(Employee employee) {&lt;br /&gt;
    addEmployeeQuery.update(new Object[] { employee.getName().getFirst(), employee.getName().getMiddle(),&lt;br /&gt;
        employee.getName().getLast(), employee.getAddress().getLine1(), employee.getAddress().getLine2(),&lt;br /&gt;
        employee.getAddress().getCity(), employee.getAddress().getState(),&lt;br /&gt;
        employee.getAddress().getZip(), employee.getAge(), });&lt;br /&gt;
  }&lt;br /&gt;
   &lt;br /&gt;
}&lt;br /&gt;
class AddEmployeeQuery extends SqlUpdate {&lt;br /&gt;
  private static final String SQL_QUERY = &amp;quot;INSERT INTO employee (name_first, name_middle, name_last, address_line1, &amp;quot;&lt;br /&gt;
      + &amp;quot;address_line2, address_city, address_state, address_zip, age) &amp;quot;&lt;br /&gt;
      + &amp;quot;VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)&amp;quot;;&lt;br /&gt;
  public AddEmployeeQuery(DataSource dataSource) {&lt;br /&gt;
    super(dataSource, SQL_QUERY);&lt;br /&gt;
    declareParameter(new SqlParameter(&amp;quot;name_first&amp;quot;, Types.VARCHAR));&lt;br /&gt;
    declareParameter(new SqlParameter(&amp;quot;name_middle&amp;quot;, Types.VARCHAR));&lt;br /&gt;
    declareParameter(new SqlParameter(&amp;quot;name_last&amp;quot;, Types.VARCHAR));&lt;br /&gt;
    declareParameter(new SqlParameter(&amp;quot;address_line1&amp;quot;, Types.VARCHAR));&lt;br /&gt;
    declareParameter(new SqlParameter(&amp;quot;address_line2&amp;quot;, Types.VARCHAR));&lt;br /&gt;
    declareParameter(new SqlParameter(&amp;quot;address_city&amp;quot;, Types.VARCHAR));&lt;br /&gt;
    declareParameter(new SqlParameter(&amp;quot;address_state&amp;quot;, Types.VARCHAR));&lt;br /&gt;
    declareParameter(new SqlParameter(&amp;quot;address_zip&amp;quot;, Types.VARCHAR));&lt;br /&gt;
    declareParameter(new SqlParameter(&amp;quot;age&amp;quot;, Types.INTEGER));&lt;br /&gt;
    compile();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
class Employee {&lt;br /&gt;
  private Integer id;&lt;br /&gt;
  private Name name = new Name();&lt;br /&gt;
  private Integer age;&lt;br /&gt;
  private Sex sex;&lt;br /&gt;
  private Address address = new Address();&lt;br /&gt;
  private List&amp;lt;PhoneNumber&amp;gt; phoneNumbers = new ArrayList&amp;lt;PhoneNumber&amp;gt;();&lt;br /&gt;
  public Employee() {&lt;br /&gt;
  }&lt;br /&gt;
  public Employee(String firstName, String lastName) {&lt;br /&gt;
    this.getName().setFirst(firstName);&lt;br /&gt;
    this.getName().setLast(lastName);&lt;br /&gt;
  }&lt;br /&gt;
  void setId(Integer id) {&lt;br /&gt;
    this.id = id;&lt;br /&gt;
  }&lt;br /&gt;
  public Integer getId() {&lt;br /&gt;
    return id;&lt;br /&gt;
  }&lt;br /&gt;
  public Address getAddress() {&lt;br /&gt;
    return address;&lt;br /&gt;
  }&lt;br /&gt;
  public Integer getAge() {&lt;br /&gt;
    return age;&lt;br /&gt;
  }&lt;br /&gt;
  public void setAge(Integer age) {&lt;br /&gt;
    this.age = age;&lt;br /&gt;
  }&lt;br /&gt;
  public Name getName() {&lt;br /&gt;
    return name;&lt;br /&gt;
  }&lt;br /&gt;
  public List&amp;lt;PhoneNumber&amp;gt; getPhoneNumbers() {&lt;br /&gt;
    return Collections.unmodifiableList(phoneNumbers);&lt;br /&gt;
  }&lt;br /&gt;
  public void addPhoneNumber(PhoneNumber phoneNumber) {&lt;br /&gt;
    this.phoneNumbers.add(phoneNumber);&lt;br /&gt;
  }&lt;br /&gt;
  public void removePhoneNumber(PhoneNumber phoneNumber) {&lt;br /&gt;
    this.phoneNumbers.remove(phoneNumber);&lt;br /&gt;
  }&lt;br /&gt;
  public void removePhoneNumber(int index) {&lt;br /&gt;
    this.phoneNumbers.remove(index);&lt;br /&gt;
  }&lt;br /&gt;
  public Sex getSex() {&lt;br /&gt;
    return sex;&lt;br /&gt;
  }&lt;br /&gt;
  public void setSex(Sex sex) {&lt;br /&gt;
    this.sex = sex;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
abstract class Sex {&lt;br /&gt;
  public static final Sex MALE = new Male();&lt;br /&gt;
  public static final Sex FEMALE = new Female();&lt;br /&gt;
  public boolean equals(Object o) {&lt;br /&gt;
    if (o == null) {&lt;br /&gt;
      return false;&lt;br /&gt;
    }&lt;br /&gt;
    return getClass().equals(o.getClass());&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
class PhoneNumber {&lt;br /&gt;
}&lt;br /&gt;
class Address {&lt;br /&gt;
  private String line1;&lt;br /&gt;
  private String line2;&lt;br /&gt;
  private String city;&lt;br /&gt;
  private String state;&lt;br /&gt;
  private String zip;&lt;br /&gt;
  public void setLine1(String line1) {&lt;br /&gt;
    this.line1 = line1;&lt;br /&gt;
  }&lt;br /&gt;
  public String getLine1() {&lt;br /&gt;
    return this.line1;&lt;br /&gt;
  }&lt;br /&gt;
  public void setLine2(String line2) {&lt;br /&gt;
    this.line2 = line2;&lt;br /&gt;
  }&lt;br /&gt;
  public String getLine2() {&lt;br /&gt;
    return this.line2;&lt;br /&gt;
  }&lt;br /&gt;
  public void setCity(String city) {&lt;br /&gt;
    this.city = city;&lt;br /&gt;
  }&lt;br /&gt;
  public String getCity() {&lt;br /&gt;
    return this.city;&lt;br /&gt;
  }&lt;br /&gt;
  public void setState(String state) {&lt;br /&gt;
    this.state = state;&lt;br /&gt;
  }&lt;br /&gt;
  public String getState() {&lt;br /&gt;
    return this.state;&lt;br /&gt;
  }&lt;br /&gt;
  public void setZip(String zip) {&lt;br /&gt;
    this.zip = zip;&lt;br /&gt;
  }&lt;br /&gt;
  public String getZip() {&lt;br /&gt;
    return this.zip;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
final class Male extends Sex {&lt;br /&gt;
  protected Male() {&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
final class Female extends Sex {&lt;br /&gt;
  protected Female() {&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
class Name {&lt;br /&gt;
  private String first;&lt;br /&gt;
  private String middle;&lt;br /&gt;
  private String last;&lt;br /&gt;
  public void setFirst(String first) {&lt;br /&gt;
    this.first = first;&lt;br /&gt;
  }&lt;br /&gt;
  public String getFirst() {&lt;br /&gt;
    return this.first;&lt;br /&gt;
  }&lt;br /&gt;
  public void setMiddle(String middle) {&lt;br /&gt;
    this.middle = middle;&lt;br /&gt;
  }&lt;br /&gt;
  public String getMiddle() {&lt;br /&gt;
    return this.middle;&lt;br /&gt;
  }&lt;br /&gt;
  public void setLast(String last) {&lt;br /&gt;
    this.last = last;&lt;br /&gt;
  }&lt;br /&gt;
  public String getLast() {&lt;br /&gt;
    return this.last;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: Main.java&lt;br /&gt;
import java.util.Date;&lt;br /&gt;
import java.util.GregorianCalendar;&lt;br /&gt;
import org.springframework.context.ApplicationContext;&lt;br /&gt;
import org.springframework.context.support.ClassPathXmlApplicationContext;&lt;br /&gt;
class Main {&lt;br /&gt;
  public static void main(String args[]) throws Exception {&lt;br /&gt;
    ApplicationContext ctx = new ClassPathXmlApplicationContext(&lt;br /&gt;
        &amp;quot;context.xml&amp;quot;);&lt;br /&gt;
    EmployeeDaoImpl ws = (EmployeeDaoImpl) ctx.getBean(&amp;quot;employeeDao&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
File: context.xml&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;UTF-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE beans PUBLIC &amp;quot;-//SPRING//DTD BEAN//EN&amp;quot;&lt;br /&gt;
    &amp;quot;http://www.springframework.org/dtd/spring-beans.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;beans&amp;gt;&lt;br /&gt;
&amp;lt;bean id=&amp;quot;dataSource&amp;quot; class=&amp;quot;org.apache.rumons.dbcp.BasicDataSource&amp;quot;&lt;br /&gt;
      destroy-method=&amp;quot;close&amp;quot;&amp;gt;&lt;br /&gt;
  &amp;lt;property name=&amp;quot;driverClassName&amp;quot; value=&amp;quot;org.hsqldb.jdbcDriver&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;property name=&amp;quot;url&amp;quot; value=&amp;quot;jdbc:hsqldb:mem:.&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;property name=&amp;quot;username&amp;quot; value=&amp;quot;sa&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;property name=&amp;quot;password&amp;quot; value=&amp;quot;&amp;quot;/&amp;gt;&lt;br /&gt;
&amp;lt;/bean&amp;gt;&lt;br /&gt;
&amp;lt;bean id=&amp;quot;employeeDao&amp;quot; class=&amp;quot;EmployeeDaoImpl&amp;quot;&amp;gt;&lt;br /&gt;
  &amp;lt;property name=&amp;quot;dataSource&amp;quot; ref=&amp;quot;dataSource&amp;quot;/&amp;gt;&lt;br /&gt;
&amp;lt;/bean&amp;gt;&lt;br /&gt;
&amp;lt;/beans&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;/div&gt;</summary>
			</entry>

	</feed>