I want to query database using java tool SAXON
- Use an ODBC connection to connect to mysql database
- Query database ( probably information schema -read schema )
- Export the results into xml
Is this a licensed feature in saxon ( e.g saxon9ee ) ?
If yes Is there any other open-source option to achieve same level of functionality ?
I have downloaded saxon9ee.jar + saxon9he.jar and play around a bit.
what I have done so far:
XSLT:connect.xslt
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="#all"
xmlns:sql="http://saxon.sf.net/sql"
extension-element-prefixes="sql"
version="2.0">
<xsl:output method="xml" encoding="UTF-8" indent="yes"/>
<xsl:param name="driver" select="'com.mysql.jdbc.Driver'"/>
<xsl:param name="database" select="'jdbc:mysql://localhost/databaename'"/>
<xsl:param name="user" select="'usr'"/>
<xsl:param name="password" select="'pwd'"/>
<xsl:template match="//databaseObjects">
<xsl:message>Connecting to database...</xsl:message>
<!-- The "connection" variable establishes JDBC connection by selecting as its value the SQL connection to the database.!-->
<xsl:variable name="connection" as="java:java.lang.Object" xmlns:java="http://saxon.sf.net/java-type">
<sql:connect driver="{$driver}" database="{$database}" user="{$user}" password="{$password}">
<!-- Used primarily for debugging, if,
for whatever reason, the credentials or something incorrect is passed in the connect statement,
the process will terminate with the following message -->
<xsl:fallback>
<xsl:message terminate="yes">Connection to MySQL failed.</xsl:message>
</xsl:fallback>
</sql:connect>
</xsl:variable>
<sql:close connection="$connection"/>
</xsl:template>
</xsl:stylesheet>
XML: objects.xml
(rough idea )
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<databaseObjects>
<object type="triggers"/>
<object type="functions"/>
<object type="procedures"/>
<object type="views"/>
<object type="events"/>
</databaseObjects>
command:
java -jar ~/saxon/saxon9he.jar objects.xml connect.xslt
output:
No license file found - running with licensable features disabled
Connecting to database...
Error on line 17 of connect.xslt:
XTDE1450: Unknown extension instruction
in built-in template rule
Transformation failed: Run-time errors were reported
any kind of help is appreciable, thanks