Discover how a bimodal integration strategy can address the major data management challenges facing your organization today.
Get the Report →
The Xero JDBC Driver enables users to connect with live Xero data, directly from any applications that support JDBC connectivity. Complete read-write access to Xero accounting enables developers to search (Customers, Transactions, Invoices, Sales Receipts, etc.), update items, edit customers, and more, from any Java/J2EE application.
Features
- SQL-92 access to Xero Accounting, US Payroll, and Australian Payroll data
- Authenticate against Xero using public, private, and partner applications
- Powerful metadata querying enables SQL-like access to non-database sources
- Push down query optimization pushes SQL operations down to the server whenever possible, increasing performance
- Client-side query execution engine, supports SQL-92 operations that are not available server-side
- Connect to live Xero Accounting data, for real-time data access
- Full support for data aggregation and complex JOINs in SQL queries
- Secure connectivity through modern cryptography, including TLS 1.2, SHA-256, ECC, etc.
- Seamless integration with leading BI, reporting, and ETL tools and with custom applications
Specifications
- JDBC Driver for Xero with bi-directional access.
- Write SQL, get Xero Accounting data. Access Xero through standard Java Database Connectivity.
- Codeless integration with popular BI, Reporting, & ETL Tools.
- Integrate Java Apps with Xero Customers, Transactions, Invoices, Sales Receipts, Reports, and more!
- Full Unicode support for data, parameter, & metadata.
- Support for 32-bit and 64-bit operating systems.
JDBC Access to Xero Accounting
Full-featured and consistent SQL access to any supported data source through JDBC
-
Certified Compatibility*
Our drivers undergo extensive testing and are certified to be compatible with leading analytics and reporting applications like SAP Crystal Reports, Pentaho, Business Objects, Crystal Reports and many more.
-
Metadata Discovery
Full support for JDBC DatabaseMetaData provides extensive schema discovery capabilities. Explore tables, columns, keys, and other data constructs based on user identity.
-
Developer Friendly
Design-time support for all major Java IDEs, including Eclipse, IntelliJ, and NetBeans.
-
JDBC Remoting
Our exclusive remoting feature allows hosting the JDBC connection on a server to enable connections from various clients on any platform (Java, .NET, C++, PHP, Python), using any standards-based technology (ODBC, JDBC, etc.). JDBC Remoting is enabled using the popular MySQL wire protocol server.
-
Replication and Caching
Our replication and caching commands make it easy to copy data to local and cloud data stores such as Oracle, SQL Server, Google Cloud SQL, etc. The replication commands include many features that allow for intelligent incremental updates to cached data.
-
String, Date, Numeric SQL Functions
The driver includes a library of over 50 functions that can manipulate column values into the desired result. Popular examples include Regex, JSON, and XML processing functions.
-
Collaborative Query Processing
Our drivers enhance the data source's capabilities by additional client-side processing, when needed, to enable analytic summaries of data such as SUM, AVG, MAX, MIN, etc.
-
Easily Customizable and Configurable
The data model exposed by our JDBC Drivers can easily be customized to add or remove tables/columns, change data types, etc. without requiring a new build. These customizations are supported at runtime using human-readable schema files that are easy to edit.
-
Secure Connectivity
Includes standard Enterprise-class security features such as TLS/ SSL data encryption for all client-server communications.
JDBC Driver Performance
With traditional approaches to remote access, performance bottlenecks can spell disaster for applications. Regardless if an application is created for internal use, a commercial project, web, or mobile application, slow performance can rapidly lead to project failure. Accessing data from any remote source has the potential to create these problems. Common issues include:
- Network Connections - Slow network connections and latency issues are common in mobile applications.
- Service Delays - Delays due to service interruptions, resulting in server hardware or software updates.
- Large Data - Intentional or unintentional requests for large amounts of data.
- Disconnects - Complete loss of network connectivity.
The CData JDBC Driver for Xero solves these issues by supporting powerful smart caching technology that can greatly improve the performance and dramatically reduce application bottlenecks.
Smart Caching
Smart caching is a configurable option that works by storing queried data into a local database. Enabling smart caching creates a persistent local cache database that contains a replica of data retrieved from the remote source. The cache database is small, lightweight, blazing-fast, and it can be shared by multiple connections as persistent storage.
Caching with our JDBC Drivers is highly configurable, including options for:
- Auto Cache - Maintain an automatic local cache of data on all requests. The provider will automatically load data into the cache database each time you execute a SELECT query. Each row returned by the query will be inserted or updated as necessary into the corresponding table in the cache database.
- Explicit Cache - Cache only on demand. Developers decide exactly what data gets stored in the cache and when it is updated. Explicit caching provides full control over the cache contents by using explicit execution of CACHE statements.
- No Cache - All requests access only live data and no local cache file is created.
This powerful caching functionality increases application performance and allows applications to disconnect and continue limited functioning without writing code for additional local storage and/or data serialization/deserialization.
More information about JDBC Driver caching and best caching practices is available in the included help files.
Enterprise-Class Remoting
MySQL/SQL Database entry points for Xero Accounting Data
The CData JDBC drivers include powerful fully-integrated remoting capabilities that makes Xero Accounting data accessible from virtually anywhere. The drivers include the optional ability to accept incoming SQL and MySQL client connections and service standard database requests.
With the CData JDBC drivers, users can interact with Xero Accounting data from any client that supports SQL Server or MySQL: from web & mobile applications, to CRM and CMS systems, BI tools like SQL Server Analysis Services, and even through popular management applications like MySQL Workbench.
- Access Xero Accounting data from virtually any application that can access external data. Applications that can access SQL Server or MySQL data can now connect to Xero Accounting with this driver.
- Connect Xero Accounting data with popular BI tools like SQL Server Analysis Services.
- Enable enterprise Xero Accounting data integration through SQL Linked Server connectivity
- Includes support for the MySQL and SQL (TDS) remote access protocols - industry standards for remote database connectivity.
- Offers advanced wire-protocol SSL security for remote connectivity
Enterprise-class JDBC Connectivity
The Xero JDBC Driver offers the most natural way to access Xero data from any Java/J2EE application. Simply use the Xero Driver to connect and access data just as you would access any traditional database. The driver is completely self-contained - no additional software installation is required!
Xero Integration
The Xero Driver has the same JDBC architecture as the JDBC drivers for MySQL and OLEDB, including Connection, Statement and ResultSet objects. Because of this you can now access Xero data in an easy, familiar way. You can use the Xero Driver through popular IDEs (Eclipse, IntelliJ, NetBeans, etc.), in code through familiar classes, and in data controls available through Swing, Eclipse SWT Widgets, etc.
For example:
Connection conn = DriverManager.getConnection("jdbc:xero:user=myuseraccount;password=mypassword;"); boolean ret = stat.execute("SELECT * FROM Customers"); ResultSet rs=stat.getResultSet(); while(rs.next()){ for(int i=1;i<=rs.getMetaData().getColumnCount();i++) { System.out.println(rs.getMetaData().getColumnName(i) +"="+rs.getString(i)); } }
More Than Read-Only: Full Update/CRUD Support
Xero Driver goes beyond read-only functionality to deliver full support for Create, Read Update, and Delete operations (CRUD). Your end-users can interact with the data presented by the Xero Driver as easily as interacting with a database table.
Connection conn = DriverManager.getConnection("jdbc:xero:user=myuseraccount;password=mypassword;"); String query = "UPDATE Customers SET Where= ..."; PreparedStatement pstmt = conn.prepareStatement(query); pstmt.setString(1, "Location"); pstmt.setString(2, "UID"); pstmt.execute(); int count=pstmt.getUpdateCount();
Frequently Asked Xero JDBC Driver Questions
Learn more about Xero JDBC drivers for data and analytics integration
Can Xero be used with Java?
Yes, Xero can be used with Java . CData provides a JDBC type 4/5 driver for Xero that allows Java applications to connect to Xero using standard JDBC APIs. This driver enables you to execute SQL queries, manage connections, and process data stored in Xero from Java, or any Java-based application that supports JDBC.
Does Xero support JDBC?
Not natively. However, CData offers an JDBC driver for Xero that allows you to connect to Xero data from any Java-based application that supports JDBC, just like you would access a traditional database. This can be useful for tasks like:
- Accessing Xero from applications: Connect to Xero data in popular tools and applications including Informatica, Talend, Apache Spark, Apache NiFi, and many others.
- Real-time data: You can work with live Xero data within these applications, enabling tasks like reporting and analysis.
- Connecting systems: Build data integrations between Xero and other systems.
The Xero JDBC driver is a pure Java type 4/5 driver with comprehensive ANSI SQL-92 support. This means that virtually any application that can connect to data via JDBC, can use the CData JDBC driver for real-time integration. Download a fully functional free trial of the Xero JDBC driver today to get started.
Is there a JDBC driver for Xero?
Yes, the CData JDBC driver for Xero provides universal JDBC data connectivity for Xero. The Xero JDBC driver offers a simple SQL-based layer of abstraction that simplifies real-time data access for users and applications, enabling them to communicate with Xero using a standardized set of functions. Virtually any application on any platform can use the CData JDBC driver for real-time integration.
How do I connect to Xero via JDBC?
Connectivity to Xero via JDBC is easy. First, download and install the Xero JDBC driver.
Once the installation is complete, navigate to the JDBC driver documentation page. Here, you'll find a wealth of information about the installed driver. The step-by-step instructions for creating a DSN and using it to connect to Xero via JDBC are just the beginning. The documentation also provides extensive configuration details for using the Xero JDBC driver with all your favorite applications and development tools, ensuring you have all the support you need.
Where can I download a JDBC driver for Xero?
All of the CData JDBC drivers, including the Xero JDBC driver are available for download online. To get started, download a fully functional free trial of the Xero JDBC driver today.
How do I install the JDBC driver for Xero?
To install the Xero driver, simply download one of the Xero JDBC driver installers available online. The installers are comprehensive setup utilities that will install all the components required to use the Xero JDBC driver on your system.