B1SA.HanaTranslator 2.0.1

dotnet add package B1SA.HanaTranslator --version 2.0.1                
NuGet\Install-Package B1SA.HanaTranslator -Version 2.0.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="B1SA.HanaTranslator" Version="2.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add B1SA.HanaTranslator --version 2.0.1                
#r "nuget: B1SA.HanaTranslator, 2.0.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install B1SA.HanaTranslator as a Cake Addin
#addin nuget:?package=B1SA.HanaTranslator&version=2.0.1

// Install B1SA.HanaTranslator as a Cake Tool
#tool nuget:?package=B1SA.HanaTranslator&version=2.0.1                

B1SA.HanaTranslator

SMS Fork

  • The main focus of our changes were easy consumption of the SQL string translation feature as a NuGet package
  • This library is based on the Query Migration Tool for Microsoft SQL Server to SAP HANA, which is marked as being archived
    • fork date: 2017-11-10
    • git revision: e53f0ecce5fabdac2c5787ae1311437a148552e5
  • Like the original code the changes are licensed under the MIT license as well
    • The referenced ANTLR library & runtime to parse the SQL is licensed under the BSD license

Changes

  • Targeting .NET Standard 2.0
  • Removed UI
  • Removed the DB connectivity and with it all its references, but also the CaseFixer feature
    • SQL identifiers are not enclosed in double quotes automatically, the correct case is in the responsibility of the library user!
  • Repository clean up & streamlining for packaging
  • Switch from static file config.txt to non-static object configuration
  • Use ANTLR packages instead of local references (only the current release candidate supports .NET Standard 2.0)
  • Switch to the more unique and origin honouring namespace B1SA.HanaTranslator
  • Bumped version to 2.0.1
  • And many more small improvements...

Usage

using B1SA.HanaTranslator;

var translator = new Translator(new Config() {
    TranslationComments = true,
    FormatOutput = true
});

var hanaSql = translator.Translate(
    """
    SELECT "Item", ISNULL("Quantity", 0) AS "Quantity" FROM "Table"
    """,
    out string summary,
    out int statements,
    out int errors
);

The original README

Query Migration Tool for Microsoft SQL Server to SAP HANA

The Query Migration Tool for Microsoft SQL Server to SAP HANA is a semi-automatic tool that helps convert most of the data-definition language (DDL) and data-manipulation language (DML). It will help you to convert structured query language (SQL) in the Microsoft SQL Server database (using T-SQL grammar) to SQL that can be used in the SAP HANA™ database (using ANSI-SQL grammar).

After the conversion, you must check whether the converted version is correct according to your needs.

This tool supports most of the official T-SQL grammar, and some well-known and widely-used undocumented feature. For more information about the official T-SQL grammar, see the MSDN Library.

If SAP HANA does not support certain SQL, this tool will do the following:

  • Find equivalents in the SAP HANA database and convert the SQL.
  • Delete the SQL in the input file and display relevant comments in the output file.
  • Leave the SQL in the input file as it is, for example, the WITH statement.

In order to find out more details please follow the details on the SAP community blog https://blogs.sap.com/2013/04/10/how-to-convert-sql-from-ms-sql-server-to-sap-hana/.

Prerequisites

The provided source code is a .NET solution. You will need Microsoft Visual Studio installed in your own environment to be able to recompile the provided source code.

License
  • There is no guarantee or support on the provided source code.
  • The provided source code might use external frameworks and libraries, pay attention if you are building a product that you have the required licenses.
  • The Query Migration Tool for Microsoft SQL Server to SAP HANA is released under the terms of the MIT license. See LICENSE for more information or see https://opensource.org/licenses/MIT.
Special thanks

Thanks to the SAP Business One development team for his collaboration on getting this tool implemented and published here.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.0.1 234 3/25/2024