View Javadoc

1   /***
2    * Copyright (c) 2003 held jointly by the individual authors.            
3    *                                                                          
4    * This library is free software; you can redistribute it and/or modify it    
5    * under the terms of the GNU Lesser General Public License as published      
6    * by the Free Software Foundation; either version 2.1 of the License, or 
7    * (at your option) any later version.                                            
8    *                                                                            
9    * This library is distributed in the hope that it will be useful, but 
10   * WITHOUT ANY WARRANTY; with out even the implied warranty of 
11   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
12   * GNU Lesser General Public License for more details.                                                  
13   *                                                                           
14   * You should have received a copy of the GNU Lesser General Public License   
15   * along with this library;  if not, write to the Free Software Foundation,   
16   * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307  USA.              
17   *                                                                            
18   * > http://www.gnu.org/copyleft/lesser.html                                  
19   * > http://www.opensource.org/licenses/lgpl-license.php
20   */
21  package net.mlw.vlh.adapter.hibernate.util.setter;
22  
23  import java.text.ParseException;
24  
25  import net.sf.hibernate.HibernateException;
26  import net.sf.hibernate.Query;
27  
28  import org.apache.commons.logging.Log;
29  import org.apache.commons.logging.LogFactory;
30  
31  /*** Sets a <code>java.lang.String</code> on a <code>Query</code>.
32   *
33   * @author Matthew L. Wilson, Andrej Zachar, Jakub Holly
34   * @version $Revision: 1.6 $ $Date: 2005/12/19 12:22:30 $
35   */
36  public class StringSetter extends AbstractSetter
37  {
38  
39     /***
40      * Logger for this class
41      */
42     private static final Log LOGGER = LogFactory.getLog(StringSetter.class);
43  
44     /***
45      * @see net.mlw.vlh.adapter.hibernate.util.Setter#set(Query, String, Object)
46      */
47     public void set(Query query, String key, Object value) throws HibernateException, ParseException
48     {
49        if (LOGGER.isInfoEnabled())
50        {
51           LOGGER.info("The key='" + key + "' was set to the query as the String='" + value + "'.");
52        }
53        try
54        {
55           query.setString(key, (String) value);
56        }
57        catch (ClassCastException e)
58        {
59           throw new IllegalArgumentException("Failed setting a bind variable to a statement because "
60                 + "it's of another class than the setter is made for - the variable is " + value.getClass() + " while the setter is "
61                 + getClass().getName() + ". Set the correct setter in value list config file - see for example "
62                 + "net.mlw.vlh.adapter.jdbc.util.setter.AbstractSetter.");
63        }
64     }
65  }