2001 2002 2003 2004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014 2015 2016 2017 2018 2020

11/30/2002: Compiling the Jakarta Validator in Eclipse

Nearly a year ago, one of my Blog entries mentioned that I wrote a Java-based Validation service. Well, a few days ago I ran across the Jakarta Commons Validator project.

It seems to be everything that I had already done but using more portable techniques. For example, I used an Oracle database instead of XML files. So, I immediately downloaded the project and tried to compile it using Eclipse. I ran into a few issues, but was successful. All of the tests ran perfectly. This Blog entry highlights the changes that I made in order to use Eclipse.

First off, let me congratulate and thank the folks who wrote the Validator. My comments below are not negative, they just reflect what changes I made to get the code compiled and executing.

  1. The main issue that I ran into was that the directory organization wasn't consistent from an Eclipse point of view. Eclipse is project-oriented and wants all classes to reside in their proper directories. For example, files in the test.org.foo.com directory must have a package statement that uses test.org.foo.com instead of org.foo.com. When working with command-line tools, having different package names from the directories in which they reside is fine. However, Eclipse is less flexible. This issue affected files in the example and test directory.
    1. Because I changed the package name, I also needed to update the validation xml files.
    2. Because I changed the package name, I needed to add import statements.
    </il>
  2. I created a ValidationLogFactory in order to hide how the Log object was created. The original code used a deprecated class. If needed, the deprecated instatiation can be placed back into ValidationLogFactory. This class was created so that only one file needs to be changed to flip between the two methods of Log invokation.
  3. Eclipse needed the following Classpath variables to be defined. Of course, the paths to the Jar files would change depending on how you installed the various packages: </table> </li>
  4. I removed the DERIVED_VALUES section since the values are set in the build.properties file. It would be nice if Ant generated an error file if the physical Jar files couldn't be found, but I don't know how to do this.
  5. Changed source.home to src\org instead of src\shared. I'm not sure where the 'shared' came from. I don't recall seeing such a directory in the original distribution.
  6. Changed the compile.tests and compile.example tasks so that the xml files are copied to the target\classes directory tree. This simplies the classpath needed for runtime, I think.
  7. </ol>
    APACHE_ORO G:\java\velocity-1.3.1-rc2\build\lib\oro.jar
    COMMONS_BEANUTILS G:\java\jwsdp-1_0_01\server\lib\commons-beanutils.jar
    COMMONS_COLLECTIONS G:/java/jwsdp-1_0_01/common/lib/commons-collections.jar
    COMMONS_DIGESTER G:\java\jwsdp-1_0_01\server\lib\commons-digester.jar
    COMMONS_LOGGING G:/java/xml-axis-10/lib/commons-logging.jar
    JUNIT G:/java/velocity-1.3.1-rc2/build/lib/junit-3.7.jar

06/03/2002: How to Delete Duplicate Records Using Oracle's Rank Function

I’ve found a neat way to delete duplicates from my database tables using Oracle’s RANK() function.

DELETE FROM __table__
WHERE ROWID IN (
  SELECT MyKey
  FROM (
    -- use the RANK() function to assign a sequential number to each set of
records.
    SELECT MyKey, display_name, RANK() OVER (PARTITION BY display_name ORDER BY MyKey) AS SeqNumber
    FROM (
      -- use the ROWID psuedo-column to get a unique id for each record.
      SELECT ROWID AS MyKey, display_name
      FROM __table__
      WHERE (display_name) IN (
        -- select the set of records that are duplicates.
        SELECT display_name FROM __table__ GROUP BY display_name HAVING COUNT(*) > 1
      )
    )
  )
  WHERE SeqNumber > 1
)