SQL examples for SQL Server
The ZappySys API Driver is a user-friendly interface designed to facilitate the seamless integration of various applications with the OneDrive API. With its intuitive design and robust functionality, the ZappySys API Driver simplifies the process of configuring specific API endpoints to efficiently read or write data from OneDrive.
On this page you will find some SQL examples which can be used for API ODBC Driver or Data Gateway API Connector.
List All Files (Recursive)
Lists all files (recursive)
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM Files';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List All Folders (Recursive)
Lists all folders recursively (exclude files)
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM Folders';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List All Files and Folders (Recursive)
Lists all files and folders recursively
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM FilesFolders';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List All Files and Folders Shared with Me
Lists all files / folders shared with me. To List shared file inside a specific folder use FilesFolders table (e.g. select * from FilesFolders WITh(DriverId='zzzzz', SearchPath='zzzz') ). Provide DriveId (Found in SharedWithMe Table - see remoteItem_parentReference_driveId column) and optionally supply SearchPath (e.g. /root:/folder/subfolder: ) from which you like to list files/folders.
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM SharedWithMe';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List drives
Lists all drives
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM Drives';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Get drive
Gets info about drive
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM get_drive
WITH (DriveId=''b!GtLQTMU726XXXXY5F2BBNi14'')
--You can get DriveId by selecting from ''Drives'' table.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List root
Lists items at a root level
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM list_root
WITH (DriveId=''b!GtLN726LE0eY5F2BBNi14wa'')
--You can get DriveId by selecting from ''Drives'' table.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List items in a folder (Non-Recursive)
Lists items in a folder
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT *
FROM list_folder
WITH(
	  Filter=''$.value[*]'' --list both files and folders
	--Filter=''$.value[?(@.file.mimeType != null)]'' --list only files
	--Filter=''$.value[?(@.folder.childCount != null)]'' --list only folders
	  ,DriveId=''b!0zqXLXXJh0uUMzl-JXAd9Ztngc-5utVDqRyD2lKpD2535-11HLQTR5z4hOzmA7Q0''
	--,FolderId=''01R65QTTUIVFJ6HVJ2WBC37KCAOQRKX7PP'' --exact Id of Folder
	--,FolderId=''root'' --default is root if FolderId is not passed
	--,FolderId=''root:/Documents/My Projects:''
	--,FolderId=''root:/Documents/My Projects/Sample Project:''
)		
--You can get DriveId by selecting from ''Drives'' table.
--You can get FolderId by selecting from ''list_root'' table OR selection from ''list_folder''.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List files in a folder path (Recursive)
Use list_files endpoint to list files recursivly (list from child folder). However there are some limitations to list recursively, such as some new files may not appear right away or files not indexed wont show up.
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM list_files
WITH(
     Filter=''$.value[*]'' --list both files and folders
   --Filter=''$.value[?(@.file.mimeType != null)]'' --list only files
   --Filter=''$.value[?(@.folder.childCount != null)]'' --list only folders
	,DriveId=''b!GtLN726LE0eY5F2BBNi14wMKmwdpCDFMn1d71ra11GuQ4DORpHy-Sa5UzSpkaY9E''
  --,SearchPath=''/root''	--folder path
  --,SearchPath=''/root:/myfolder:''	--folder path
	,SearchPath=''/root:/myfolder/subfolder:'' --folder path nested
    ,OrderBy=''lastModifiedDateTime desc''
)		
--You can get DriveId by selecting from ''Drives'' table.
--You can get SearchPath by selecting from ''list_root'' table OR selection from ''list_folder''.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List files from Group / other User's drive
This example shows how to read files from Group or other User's drive. You must use SearchType='children' for this purpose (known issue: recursive option may not work correctly in some cases).
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM list_files
WITH(
	  GroupOrUserId=''/groups/138eb458-84f0-4928-bbe6-df663bd1fcea''
	, DriveId=''b!VxnFPrt3C0GQnQ70Skx-p9_Eqvvac5pGhvqzoRdUpnZb-G5HVC0WTbLU3a89b4LJ''
	, SearchType=''children''
	, SearchPath=''/root:/folder/subfolder:''
	--, Filter=''$.value[*]'' --list both files and folders
	--, Filter=''$.value[?(@.folder.childCount != null)]'' --list only folders
)';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List folders in a folder
Lists folders in a folder
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM list_folder
WITH (DriveId=''b!GtLN726LE0eY5F2BBNi14wa'',
      FolderId=''atLNa26LE0eYFa2BeNi1awa'',
      Filter=''$.value[?(@.folder)]'')
--You can get DriveId by selecting from ''Drives'' table.
--You can get FolderId by selecting from ''list_root'' table OR selection from ''list_folder''.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List files in a folder
Lists files in a folder
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM list_folder
WITH (DriveId=''b!GtLN726LE0eY5F2BBNi14wa'',
      FolderId=''atLNa26LE0eYFa2BeNi1awa'',
      Filter=''$.value[?(@.file)]'')
--You can get DriveId by selecting from ''Drives'' table.
--You can get FolderId by selecting from ''list_root'' table OR selection from ''list_folder''.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List Excel files
Lists Excel files in a specified drive
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM list_excel_files
WITH (DriveId=''b!GtLN726LE0eY5F2BBNi14'')
--You can get DriveId by selecting from ''list_drives'' endpoint.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
List Excel file Worksheets
Enumerates Worksheets that are part of Excel file
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM list_excel_worksheets
WITH (DriveId=''b!GtLN726LE0eY5F2BBNi14''
     ,FileId=''01SUOJPKECYDDVFZWXXXXXXXXXXXXXXXXX'')
--DriveId can be retrieved by selecting from ''list_drives'' endpoint.
--FileId can be retrieved by selecting from ''list_excel_files'' endpoint.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Read Excel Worksheet data - Auto Detect Range
Reads an Excel file without supplying Cell Address Range (It auto detects based on first and last cell)
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM get_excel_worksheet_autodetect
WITH (
         DriveId=''b!GtLN726LE-XXXXXXXXXXX''
  	    ,FileId=''01SUOJPFXXXXXXXXXXXXXXXXXX''
	    ,SheetId=''Sheet1'' --Id or Name
	  --,SheetId=''{00000000-0001-0000-0000-000000000000}'' --Using ID is good idea if Sheet ever renamed (Id doesnt change)
	    ,AutoDetectByValue=''true''
		,ArrayTransEnableCustomColumns=''True'' --set this to False if No header in first row
		)
--DriveId can be retrieved by selecting from ''Drives'' table.
--FileId can be retrieved by selecting from ''list_files'' endpoint.
--SheetId can be retrieved by downloading Excel file and discovering what sheets exist or by selecting from ''list_excel_worksheets'' endpoint.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Read Excel Worksheet data for a specified Cell Address Range
Reads an Excel file from a specified Cell Range. To automatically read without cell range use other endpoint get_excel_worksheet_autodetect
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM get_excel_worksheet
WITH (
        DriveId=''b!GtLN726LE-XXXXXXXXXXX''
  	   ,FileId=''01SUOJPFXXXXXXXXXXXXXXXXXX''
	   ,SheetId=''Sheet1'' --Id or Name
	   ,Range=''A1:K10000''
	   ,ArrayTransEnableCustomColumns=''True'' --set this to False if No header in first row
	   )
--DriveId can be retrieved by selecting from ''Drives'' table.
--FileId can be retrieved by selecting from ''list_files'' endpoint.
--SheetId can be retrieved by downloading Excel file and discovering what sheets exist or by selecting from ''list_excel_worksheets'' endpoint.
--Range should be set to Excel-type of range where data is located.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Read Excel data as formatted text or formula
Reads Excel data as formatted text instead of raw, unformatted values. Modify the Filter to $.text[*] to retrieve datetime values as formatted text, rather than as numeric serial values (since Excel internally stores dates as serial numbers).
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM get_excel_worksheet_autodetect
WITH (
         DriveId=''b!GtLN726LE-XXXXXXXXXXX''
  	    ,FileId=''01SUOJPFXXXXXXXXXXXXXXXXXX''
	    ,SheetId=''Sheet1'' --Id or Name
	  --,SheetId=''{00000000-0001-0000-0000-000000000000}'' --Using ID is good idea if Sheet ever renamed (Id doesnt change)
	    ,Filter=''$.text[*]'' --this returns date as formatted value (i.e. 1/1/2020 rather than 43831)  
		--,Filter=''$.formulas[*]'' --this returns formula cells only (returns actual formula expression or null if no formula)
		)
--DriveId can be retrieved by selecting from ''Drives'' table.
--FileId can be retrieved by selecting from ''list_files'' endpoint.
--SheetId can be retrieved by downloading Excel file and discovering what sheets exist or by selecting from ''list_excel_worksheets'' endpoint.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Upload a file to OneDrive
Uploads a file to a OneDrive
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM upload_file
WITH (DriveId=''b!GtLN726LE0eY5F2BBNi14''
     ,SourceFilePath=''C:\My files\Employees\List.xls''
	 ,TargetFilePath=''List.xlsx''	 --Upload on Root (Create -or- Overwrite if ConflictBehavior = ''replace'')
   --,TargetFilePath=''myfolder/List.xlsx'' --Upload under some folder
   --,TargetFilePath=''01SUOJPKGJXIXXGXACFVDK3QH5JYARFOMB'' --Overwrite Exising File Id
   --,ConflictBehavior = ''replace'' -- fail, rename, replace (If File Exists Default=fail)
   --,UseSourceFileTimeStamp = ''true'' --By default uploaded file set Current Date/Time for Creation/Modified date
     )
--DriveId can be retrieved by selecting from ''list_drives'' endpoint.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Upload a file to OneDrive (Overwrite file if exists)
Uploads a file to a OneDrive and if file already exists then overwrite it rather than throwing error (Default is throw error)
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM upload_file
WITH (DriveId=''b!GtLN726LE0eY5F2BBNi14''
     ,SourceFilePath=''C:\My files\Employees\List.xls''
     ,SourceFilePath=''C:\My files\Employees\List.xls''
	 ,TargetFilePath=''List.xlsx''	 --Upload on Root (Create -or- Overwrite if ConflictBehavior = ''replace'')
   --,TargetFilePath=''myfolder/List.xlsx'' --Upload under some folder
   --,TargetFilePath=''01SUOJPKGJXIXXGXACFVDK3QH5JYARFOMB'' --Overwrite Exising File Id
     ,ConflictBehavior = ''replace'' -- fail, rename, replace (If File Exists Default=fail)
   --,UseSourceFileTimeStamp = ''true'' --By default uploaded file set Current Date/Time for Creation/Modified date
     )
--DriveId can be retrieved by selecting from ''list_drives'' endpoint.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Upload a file with original timestamp (For Created/Modified Date)
Uploads a file to a OneDrive and use original creation/modified on date. By default it uses Upload time to set creation/modified on date time. Set UseSourceFileTimeStamp if you like to use original timestamp. This is useful if file was created few days back but Upoloaded later on.
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM upload_file
WITH (DriveId=''b!GtLN726LE0eY5F2BBNi14''
     ,SourceFilePath=''C:\My files\Employees\List.xls''
     ,TargetFilePath=''Uploads/Employees/List.xls''
     ,ConflictBehavior = ''replace'' -- fail, rename, replace (If File Exists Default=fail)
     ,UseSourceFileTimeStamp = ''true'' --By default uploaded file set Current Date/Time for Creation/Modified date
     )
--DriveId can be retrieved by selecting from ''list_drives'' endpoint.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Download a file
Downloads a file from OneDrive
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM download_file
WITH (DriveId=''b!GtLN726LE0eY5F2BBNi14''
,FileId=''01SUOJPKHXMPKD2UXXXXXXXXXXXXXXXXXX''
,TargetFilePath=''C:\My files\Employees\List.xlsx'')
--DriveId can be retrieved by selecting from ''list_drives'' endpoint.
--FileId can be retrieved by selecting from ''list_files'' endpoint.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Delete a file/folder
Deletes a file or folder in OneDrive
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM delete_item
WITH (DriveId=''b!GtLN726LE0eY5F2BBNi14''
     ,ItemId=''01SUOJPKHXMPKD2UXXXXXXXXXXXXXXXXXX''
	)
--Using Table Name instead of endpoint (with Id / Path in WHERE clause for simple Syntax)
--************	
--Delete File by ID	or Path
--************
--DELETE From Files Where Id=''01N3NI7YU6DYBSLCEDKBB23CR4FSWZYSDJ''
--DELETE From Files Where Id=''root:/test_out.csv:''
--DELETE From Files Where Id=''root:/somefolder/test_out.csv:''
--************
--Delete Folder by ID or Path
--************
--DELETE From Folders Where Id=''01N3NI7YU6DYBSLCEDKBB23CR4FSWZYSDJ''
--DELETE From Folders Where Id=''root:/somefolder:''
--DELETE From Folders Where Id=''root:/somefolder/childfolder:''
	
--DriveId can be retrieved by selecting from ''list_drives'' endpoint.
--FileId can be retrieved by selecting from ''list_folder'' or ''list_root'' endpoints.';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Create / Update a CSV File in OneDrive from External Data Source (e.g. MSSQL / ODBC)
This example shows how to create / update a CSV file directly on OneDrive using streaming approach. This example reads records from Microsoft SQL Server database and writes data to CSV file on OneDrive. If file does not exists then it creates a new one.
DECLARE @MyQuery NVARCHAR(MAX) = 'INSERT INTO FileReaderWriterCsv
SOURCE( ''MSSQL''--OR ''ODBC''
, ''Data Source=localhost;Initial Catalog=Northwind;Integrated Security=true''
, ''select OrderId,CustomerId,OrderDate FROM Northwind.dbo.Orders''
)
WITH(
	  DriveId=''b!XpzQciaV_k6my5II5L22J0C4iRhyz21Js89PUyZ6-w0lH0AYv_I8RJHpXZQ81efD''
	  , FileId=''root:/test_out.csv:''
	--, FileId=''root:/subfolder/test_out.csv:''
	--, FileId=''01N3NxxxxxxxWZYSDJ''  --exising File ID
	--, ContinueOn404Error=0 --Fail if file not found (Useful for overwrite mode for exising file)
	--, FileId=''01N3NI7YU6DYBSLCEDKBB23CR4FSWZYSDJ''  --exising File ID for overwrite action
	--, ColumnDelimiter='','' --{LF}, {TAB}, | , \x0009 ...
	--, RowDelimiter=''{NEWLINE}'' --{LF}, {TAB}, | , \x0009 ...
	--, HasColumnHeaderRow=0 --set for header less file
    --, WriterDateTimeFormat=''yyyy-MM-ddTHH:mm:ss.fff''  
    --See Query Builder for more options
)';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Create / Update a JSON File in OneDrive from External Data Source (e.g. MSSQL / ODBC)
This example shows how to create / update a JSON file directly on OneDrive using streaming approach. This example reads records from Microsoft SQL Server database and writes data to JSON file on OneDrive. If file does not exists then it creates a new one. It uses LayoutMap to generate JSON with custom layout.
DECLARE @MyQuery NVARCHAR(MAX) = 'INSERT INTO FileReaderWriterJson
SOURCE( ''MSSQL''--OR ''ODBC''
, ''Data Source=localhost;Initial Catalog=Northwind;Integrated Security=true''
, ''select OrderId,CustomerId,OrderDate FROM Northwind.dbo.Orders''
)
WITH(
	    DriveId=''b!XpzQciaV_k6my5II5L22J0C4iRhyz21Js89PUyZ6-w0lH0AYv_I8RJHpXZQ81efD''
	  , FileId=''root:/test_out.json:''
	--, FileId=''root:/subfolder/test_out.json:''
	--, FileId=''01N3NxxxxxxxxxxWZYSDJ''  --exising File ID
	--, ContinueOn404Error=0 --Fail if file not found (Useful for overwrite mode for exising file)	
	  , JsonOutputFormat=''Multicontent'' --Default , Array2D, ArrayLines ...
	--, DoNotOutputNullProperty=''True''
	--, Encoding=''UTF8'' --UTF8WithoutBOM
  --, WriterDateTimeFormat=''yyyy-MM-ddTHH:mm:ss.fff''
	
	--Example#1: Output all columns
	, LayoutMap=''<?xml version="1.0"  ?>
<settings>
  <dataset id="root" main="True" readfrominput="True" />
  <map src="*" />  
</settings>''
	--Example#2: Nested JSON (Records under an array)
	/*
	, LayoutMap=''<?xml version="1.0" ?>
<settings singledataset="True">
  <dataset id="root" main="True" readfrominput="True" />
  <map name="MyArray" dataset="root" maptype="DocArray">
    <map src="OrderID" name="OrderID" />
    <map src="OrderDate" name="OrderDate" />
  </map>
</settings>''
   */
   
	--Example#3: Nested JSON (Records under a sub document section)
	/*	
	, LayoutMap=''<?xml version="1.0" ?>
<settings>
  <dataset id="dsRoot" main="True" readfrominput="True" />
  <map name="NestedSection">
    <map src="OrderID" name="OrderID_MyLabel" />
    <map src="OrderDate" name="OrderDate_MyLabel" />
  </map>
</settings>''
	*/
)';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Read CSV File from OneDrive (Parse Rows and Columns without downloading)
This example shows how to read a CSV file from OneDrive without downloading on the Disk (Streaming approach).
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * from get_csv_file
WITH(
	  DriveId=''b!0zqXLXXJh0uUMzl-JXAd9Ztngc-5utVDqRyD2lKpD2535-11HLQTR5z4hOzmA7Q0''
	, FileId=''root:/dump.csv:''
    --, FileId=''01N3NI7YRUO2UHV2TUMBGJ4H4QQMWCG6DA''			
	--, FileId=''root:/myfolder/dump.csv:''	
	--, ColumnDelimiter='','' --{LF}, {TAB}, | , \x0009 ... default is comma (",")
	--, HasColumnHeaderRow=0 --set for header less file
	--, FileId=''root:/myfolder/test_out.csv.gz:''
	--, FileCompressionType=''GZip'' --None, GZip, Zip
)         
--SELECT * FROM get_csv_file WITH(FileId=''01N3NI7YQA6I2F7YAXBBCZCLLPTRFLANAX'')
--SELECT * FROM get_csv_file WITH(FileId=''root:/dump.csv:'')
--SELECT * FROM get_csv_file WITH(FileId=''root:/Documents/dump.csv:'')
--SELECT * FROM get_csv_file WITH(FileId=''root:/Documents/SubFolder/dump.csv:'')';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Read Zip/Gzip Compressed CSV File from OneDrive (Parse Rows and Columns without downloading)
This example shows how to read a compressed CSV file (Zip or Gzip) from OneDrive without downloading on the Disk (Streaming approach).
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * from get_csv_file
WITH(
	  DriveId=''b!0zqXLXXJh0uUMzl-JXAd9Ztngc-5utVDqRyD2lKpD2535-11HLQTR5z4hOzmA7Q0''
	, FileId=''root:/myfolder/dump.csv.zip:''
  --, FileId=''01N3NI7YRUO2UHV2TUMBGJ4H4QQMWCG6DA''		
  --, ColumnDelimiter='','' --{LF}, {TAB}, | , \x0009 ... default is comma (",")
  --, HasColumnHeaderRow=0 --set for header less file
  --, FileId=''root:/MyFolder/dump.csv.gz:''
    , FileCompressionType=''Zip'' --None, GZip, Zip
)';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Read JSON File from OneDrive (Parse Rows and Columns without downloading)
This example shows how to read a JSON file from OneDrive without downloading on Disk (Streaming approach).
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * from get_json_file
WITH(
	  DriveId=''b!0zqXLXXJh0uUMzl-JXAd9Ztngc-5utVDqRyD2lKpD2535-11HLQTR5z4hOzmA7Q0''
	, FileId=''root:/myfolder/dump.json:''
  --, FileId=''01N3NI7YRUO2UHV2TUMBGJ4H4QQMWCG6DA''		
    , Filter=''$.store.books[*]'' --or just blank (see help file for more filter examples)
    --to read compressed file use below way
	--, FileId=''root:/myfolder/dump.json.gz:''
	--, FileCompressionType=''GZip'' --None, GZip, Zip
)         
--SELECT * FROM get_json_file WITH(FileId=''01N3NI7YQJMKXUWUAQGJEJJJNSGVT7QSJ3'')
--SELECT * FROM get_json_file WITH(FileId=''root:/dump.json:'')
--SELECT * FROM get_json_file WITH(FileId=''root:/Documents/dump.json:'')
--SELECT * FROM get_json_file WITH(FileId=''root:/Documents/SubFolder/dump.json:'')';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Read Zip/Gzip Compressed JSON File from OneDrive (Parse Rows and Columns without downloading)
This example shows how to read a compressed JSON file (Zip or Gzip) from OneDrive without downloading on the Disk (Streaming approach).
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * from get_json_file
WITH(
	DriveId=''b!0zqXLXXJh0uUMzl-JXAd9Ztngc-5utVDqRyD2lKpD2535-11HLQTR5z4hOzmA7Q0''
  , FileId=''root:/myfolder/dump.json.zip:''
--, FileId=''01N3NI7YRUO2UHV2TUMBGJ4H4QQMWCG6DA''
  , Filter=''$.store.books[*]'' --or just blank (see help file for more filter examples)
  , FileCompressionType=''Zip'' --None, GZip, Zip
)';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Move a File or Folder in OneDrive
This example shows how to move a file or folder to a different location in OneDrive. It also shows how to use Placeholder Functions to name file daynamically. For example to add timestamp it uses <<yyyy-MM-dd-HH-mm-ss-fff,FUN_NOW>>
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM move_rename_item
WITH(
    --Source Drive
	  DriveId=''me''
	--OR--
	--DriveId=''b!7HBaTtrbekqMYJQ-OqV5Q3hrcOIQoyhGiAoWjqWFenIlIJ-Us7DMQ6jvyrsWMJPx''
	
	--Source Item
	--Item Id (File or Folder) you like to move or rename
	, ItemId=''01R65QTTRARZ42C4BN6FF2WOH3AONX4GUW''
	--Target Drive Id (Optional): Only needed if moving file to a different Drive (e.g. another User''s drive)
	--, TargetDriveId=''me''
	--OR
	--, TargetDriveId=''b!0zqXLXXJh0uxxxxxxxxxxxxxxxxxxxxx''
	--Target Folder
	, TargetFolderId=''01R65QTTTBPH6V2AP36VD33CYYDXJSNHLN''
	--OR (for moving to root)
	--, TargetFolderId=''root''
	
	--Target Item Name (New Name) after Move (Optional) - If you do not wish to change name after Move then do not supply below
	--, TargetItemName=''new_file_name_<<yyyy-MM-dd-HH-mm-ss-fff,FUN_NOW>>.pdf'' 
	
	--Uncomment Below if you get error. Usually needed for large file or cross site operations
	--, Prefer=''respond-async''	
)';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Rename a File or Folder in OneDrive
This example shows how to rename a file or folder and you can also move to a different location in OneDrive.. It also shows how to use Placeholder Functions to name file daynamically. For example to add timestamp it uses <<yyyy-MM-dd-HH-mm-ss-fff,FUN_NOW>>
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM move_rename_item
WITH(
    --Source Drive
	DriveId=''me''
	--OR--
	--DriveId=''b!7HBaTtrbekqMYJQ-OqV5Q3hrcOIQoyhGiAoWjqWFenIlIJ-Us7DMQ6jvyrsWMJPx''
	--Source Item you like to rename or move
	, ItemId=''01R65QTTRARZ42C4BN6FF2WOH3AONX4GUW''
	--Target Drive Id (Optional): Only needed if moving file to a different Drive (e.g. another User''s drive)
    --, TargetDriveId=''me''
	--OR
	--, TargetDriveId=''b!0zqXLXXJh0uxxxxxxxxxxxxxxxxxxxxx''
	
	--Target Folder (Optional): If you are doing Rename and Move both in one action then supply new Folder Id too else keep it blank for just rename
	--, TargetFolderId=''01R65QTTTBPH6V2AP36VD33CYYDXJSNHLN''
	--, TargetFolderId=''root''
	
	--Target Item Name (New name)
	, TargetItemName=''new_file_name_<<yyyy-MM-dd-HH-mm-ss-fff,FUN_NOW>>.pdf'' 
	
	--Uncomment Below if you get error. Usually needed for large file or cross site operations
	--, Prefer=''respond-async''	
)';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Copy a File or Folder in OneDrive
This example shows how to copy a file or folder to a different location in OneDrive (In same Drive or different User's drive). It also shows how to use Placeholder Functions to name file daynamically. For example to add timestamp it uses <<yyyy-MM-dd-HH-mm-ss-fff,FUN_NOW>>
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT * FROM copy_item
WITH(
	--Source Drive
	DriveId=''me''
	--OR--
	--DriveId=''b!7HBaTtrbekqMYJQ-OqV5Q3hrcOIQoyhGiAoWjqWFenIlIJ-Us7DMQ6jvyrsWMJPx''
	--Source Item you like to copy
	, ItemId=''01R65QTTRARZ42C4BN6FF2WOH3AONX4GUW''
	--Target Drive Id (Optional): Only needed if copying file to a different Drive (e.g. another User''s drive)
	--, TargetDriveId=''me''
	--OR--
	--, TargetDriveId=''b!0zqXLXXJh0uxxxxxxxxxxxxxxxxxxxxx''
	
	--Target Folder where item will be copied
	, TargetFolderId=''01R65QTTTBPH6V2AP36VD33CYYDXJSNHLN''
	--OR--
	--, TargetFolderId=''root''
	--Target item name (Optional) - Only needed if new name needed after copy
	, TargetItemName=''new_file_or_folder_name_<<yyyy-MM-dd-HH-mm-ss-fff,FUN_NOW>>.pdf'' 
	--,ConflictBehavior=''replace'' --fail, rename (Ignored if TargetItemName is not supplied)
	--Uncomment Below if you get error. Usually needed for large file or cross site operations
	--, Prefer=''respond-async''	
)';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Download File and convert to PDF or HTML file format (convert xlsx, docx, pptx and many more) in OneDrive
This example shows how to download a file with different format (PDF or HTML). If conversion not supported you will get an error.
DECLARE @MyQuery NVARCHAR(MAX) = 'SELECT "Status"
FROM download_file
WITH(
     DriveId=''me''
     --OR--
     --DriveId=''b!7HBaTtrbekqMYJQ-OqV5Q3hrcOIQoyhGiAoWjqWFenIlIJ-Us7DMQ6jvyrsWMJPx''
	, FileId=''01R65QTTTF7H7WMCHCKRFJGEJTXAEC7RGX''
	
	--Supported Source Formats: csv, doc, docx, odp, ods, odt, pot, potm, potx, pps, ppsx, ppsxm, ppt, pptm, pptx, rtf, xls, xlsx
	, ConvertTo=''pdf''
	, TargetFilePath=''C:\temp\converted.pdf''
	
	--OR--
	--Supported Source Formats: loop, fluid, wbtx
	--, ConvertTo=''html''
	--, TargetFilePath=''C:\temp\converted.html''
)';
EXEC (@MyQuery) AT [LS_TO_ONEDRIVE_IN_GATEWAY];Learn more about this SQL query.
Getting Started with Examples
ZappySys API Driver is a powerful software solution designed to facilitate the extraction and integration of data from a wide range of sources through APIs. Its intuitive design and extensive feature set make it an essential asset for any organization dealing with complex data integration tasks.
To get started with examples using ZappySys API Driver, please click on the following applications:
Key features of the ZappySys API Driver include:
The API ODBC driver facilitates the reading and writing of data from numerous popular online services (refer to the complete list here) using familiar SQL language without learning complexity of REST API calls. The driver allows querying nested structure and output as a flat table. You can also create your own ODBC / Data Gateway API connector file and use it with this driver.
- Intuitive Configuration: The interface is designed to be user-friendly, enabling users to easily set up the specific API endpoints within OneDrive without requiring extensive technical expertise or programming knowledge. 
- Customizable Endpoint Setup: Users can conveniently configure the API endpoint settings, including the HTTP request method, endpoint URL, and any necessary parameters, to precisely target the desired data within OneDrive. 
- Data Manipulation Capabilities: The ZappySys API Driver allows for seamless data retrieval and writing, enabling users to fetch data from OneDrive and perform various data manipulation operations as needed, all through an intuitive and straightforward interface. 
- Secure Authentication Integration: The driver provides secure authentication integration, allowing users to securely connect to the OneDrive API by inputting the necessary authentication credentials, such as API tokens or other authentication keys. 
- Error Handling Support: The interface is equipped with comprehensive error handling support, ensuring that any errors or exceptions encountered during the data retrieval or writing process are efficiently managed and appropriately communicated to users for prompt resolution. 
- Data Visualization and Reporting: The ZappySys API Driver facilitates the seamless processing and presentation of the retrieved data from OneDrive, enabling users to generate comprehensive reports and visualizations for further analysis and decision-making purposes. 
Overall, the ZappySys API Driver serves as a powerful tool for streamlining the integration of applications with OneDrive, providing users with a convenient and efficient way to access and manage data, all through a user-friendly and intuitive interface.
 
             
         
                 
                 
                 
                 
                 
                 
                 
                 
                 
                 
                 
                 
                 
                 
                 
                