![]() |
VOOZH | about |
Drop the CData ODBC Driver for XML into your LAMP or WAMP stack to build XML-connected Web applications. This article shows how to use PHP's ODBC built-in functions to connect to XML data, execute queries, and output the results.
If you have not already, first specify connection properties in an ODBC DSN (data source name). This is the last step of the driver installation. You can use the Microsoft ODBC Data Source Administrator to create and configure ODBC DSNs.
CData Drivers let you work with XML files stored locally and stored in cloud storage services like Box, Amazon S3, Google Drive, or SharePoint, right where they are.
Set the URI property to local folder path.
To connect to XML file(s) within Amazon S3, set the URI property to the URI of the Bucket and Folder where the intended XML files exist. In addition, at least set these properties:
To connect to XML file(s) within Box, set the URI property to the URI of the folder that includes the intended XML file(s). Use the OAuth authentication method to connect to Box.
To connect to XML file(s) within Dropbox, set the URI proprerty to the URI of the folder that includes the intended XML file(s). Use the OAuth authentication method to connect to Dropbox. Either User Account or Service Account can be used to authenticate.
To connect to XML file(s) within SharePoint with SOAP Schema, set the URI proprerty to the URI of the document library that includes the intended XML file. Set User, Password, and StorageBaseURL.
To connect to XML file(s) within SharePoint with REST Schema, set the URI proprerty to the URI of the document library that includes the intended XML file. StorageBaseURL is optional. If not set, the driver will use the root drive. OAuth is used to authenticate.
To connect to XML file(s) within Google Drive, set the URI property to the URI of the folder that includes the intended XML file(s). Use the OAuth authentication method to connect and set InitiateOAuth to GETANDREFRESH.
The property is the controlling property over how your data is represented into tables and toggles the following basic configurations.
See the Modeling XML Data chapter for more information on configuring the relational representation. You will also find the sample data used in the following examples. The data includes entries for people, the cars they own, and various maintenance services performed on those cars.
Open the connection to XML by calling the or methods. To close connections, use or .
$conn = odbc_connect("CData ODBC XML Source","user","password");
Connections opened with are closed when the script ends. Connections opened with the method are still open after the script ends. This enables other scripts to share that connection when they connect with the same credentials. By sharing connections among your scripts, you can save system resources, and queries execute faster.
$conn = odbc_pconnect("CData ODBC XML Source","user","password");
...
odbc_close($conn); //persistent connection must be closed explicitly
Create prepared statements and parameterized queries with the function.
$query = odbc_prepare($conn, "SELECT * FROM people WHERE [ personal.name.last ] = ?");
Execute prepared statements with .
$conn = odbc_connect("CData ODBC XML Source","user","password");
$query = odbc_prepare($conn, "SELECT * FROM people WHERE [ personal.name.last ] = ?");
$success = odbc_execute($query, array('Roberts'));
Execute nonparameterized queries with .
$conn = odbc_connect("CData ODBC XML Source","user","password");
$query = odbc_exec($conn, "SELECT [people].[personal.age] AS age, [people].[personal.gender] AS gender, [people].[personal.name.first] AS first_name, [people].[personal.name.last] AS last_name, [vehicles].[model], FROM [people] JOIN [vehicles] ON [people].[_id] = [vehicles].[people_id]");
Access a row in the result set as an array with the function.
$conn = odbc_connect("CData ODBC XML data Source","user","password");
$query = odbc_exec($conn, "SELECT [people].[personal.age] AS age, [people].[personal.gender] AS gender, [people].[personal.name.first] AS first_name, [people].[personal.name.last] AS last_name, [vehicles].[model], FROM [people] JOIN [vehicles] ON [people].[_id] = [vehicles].[people_id]");
while($row = odbc_fetch_array($query)){
echo $row["[ personal.name.first ]"] . "\n";
}
Display the result set in an HTML table with the function.
$conn = odbc_connect("CData ODBC XML data Source","user","password");
$query = odbc_prepare($conn, "SELECT * FROM people WHERE [ personal.name.last ] = ?");
$success = odbc_execute($query, array('Roberts'));
if($success)
odbc_result_all($query);
You will find complete information on the driver's supported SQL in the help documentation. The code examples above are XML-specific adaptations of the PHP community documentation for all ODBC functions.
Download a free trial of the XML ODBC Driver to get started:
Download NowLearn more:
👁 XML Documents IconThe XML ODBC Driver is a powerful tool that allows you to connect with live XML data stores, directly from any applications that support ODBC connectivity.
Access XML data like you would any standard database - read, write, and update etc. through a standard ODBC Driver interface.