Friday, October 17, 2014

Switching between JDKs and Displaying Hidden Files on OSX 10.9.5

Switching between JDKs
Running Eclipse on OS X 10.9.5, one of the plugins I use warned me that it required Java 7 to run.  So I set out to install JDK 7.  My choices were to either replace JDK 6 with 7 or to install it alongside 6 and switch between the two if (when) required.  Both appeared straight forward choices, though I went with the latter so that I can just switch instead of re-installing when needed.

This required the setting of some environment variables, namely JAVA_HOME and the modification of PATH (which I'm used to doing quickly on Windows).  Not an expert OS X user, I thought of which 'top-most' config file to append these vars into so that all users (just cuz) and all launch methods would use them.  I remembered that .bashrc is part of a hierarchy that is used to construct the lookup path, and so I'd likely want to place it somewhere near root.  Since that file or no such related file exists there, I could have just modified the ones under my /Users/<user>/ dir.

Googling a bit further, I (re)learned of /etc/launchd.conf - config file for a launch daemon.  Then I stumbled upon this little handy tool Change Java version on Mac OS.  It didn't work at first.  Turns out that the /etc/launchd.conf file needs to be created if it doesn't exist; issued this to do that: sudo touch /etc/launchd.conf.  The tool worked after that.

Hidden Files

I also learned about a couple of ways to display hidden files in finder (didn't feel like cd'ing and using nano to check out launchd.conf, and just wanted to learn to do this anyway), though this didn't go as smoothly as expected.  At first I issued:
  • defaults write com.apple.Finder AppleShowAllFiles YES; killall Finder
Which didn't work, so I tried:
  • sudo chflags -R nohidden /*
Which also didn't work, so I found:
  • defaults write com.apple.Finder AppleShowAllFiles -bool YES; killall -HUP Finder
Which also didn't work at first, but strangely, re-issuing the first one (after some time) worked.  My guess is that finder didn't want to restart properly.  So, it is either the first or last one that worked.

Relevant links

Monday, January 6, 2014

Connecting to MSSQL Server from Java

I found this basic code snippet useful during the troubleshooting of a certain application-database connectivity issue.  It selects the date-time from the `master` DB, similar to Oracle's `dual` table used for testing purposes.  A DB user needs to exist, though you can probably use the default sysadmin `sa` user.  The project with this snippet needs to have the MSSQL JDBC driver (sqljdbc4.jar) on its project classpath.  As of now, version 4.0 of the driver can be run in JRE 7, but not JDK 7; it works fine in JDK 6.  Driver download link: Microsoft JDBC Driver 4.0 for SQL Server.

public class TestDBConnectivity { public static void main(String[] args) { String connectionUrl="jdbc:sqlserver://remoteServer:8081;DatabaseName=master;user=userName;Password=userPassword"; Connection con = null; Statement stmt = null; ResultSet rs = null; try { con = DriverManager.getConnection(connectionUrl); String SQL = "SELECT GETDATE() AS CurrentDateTime"; stmt = con.createStatement(); rs = stmt.executeQuery(SQL); while (rs.next()) { System.out.println("result: " + rs.getString("CurrentDateTime")); } } catch (Exception e) { e.printStackTrace(); } finally { if (rs != null) try { rs.close(); } catch(Exception e) {} if (stmt != null) { try { stmt.close(); } catch(Exception e) {} } if (con != null) { try { con.close(); } catch(Exception e) {} } } } }

Source: Connecting to SQL Server 2008 from Java