博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
强大的跨数据库访问组件 UniDAC使用教程:统一SQL
阅读量:5906 次
发布时间:2019-06-19

本文共 3016 字,大约阅读时间需要 10 分钟。

是一款通用数据库访问组件,提供了多个数据库的直接访问,如针对Windows的Delphi,C++Builder, Lazarus (以及 Free Pascal), Mac OS X, iOS,Android,Linux和64和32位的FreeBSD等等。我们将长期的经验集于这个小组件,提供统一的数据库连接访问(如oracle、微软SQL等等)。这意味着你可以在你的项目之间轻松地切换不同的数据库,以及创建跨数据库应用程序接口。

                                          【

在几个数据库的编程应用程序中最关键的问题之一是SQL语法在许多情况下可能不同。本文将演示如何帮助大家解决此问题。

数据库应用程序使用SQL语句操作数据。除非用户直接输入,否则语句可以采用两种方式构建,在开发期间进行硬编码,或在运行时构建。第一种方式对开发人员来说非常方便,而第二种方式则更灵活。UniDAC可以结合这两种方法,从而达到最佳效果:你可以对在运行时转换为适当语法的SQL语句进行硬编码。

本篇文章主要包含以下内容:

  • 基本信息
  • 条件执行(IF)
  • 文字和标识符
  • 评论
  • SQL函数
  • 宏参考

基本信息

UniDAC的通用功能基于以下功能:

  • 具有特定于不同数据库(提供者)的值的宏。
  • 一组自动映射的功能。
  • 统一的文字标准。

了解这一点后,你可以编写在运行时真正与数据库无关的SQL代码。

UniDAC提供了两种处理宏的方法:Connection Macros(连接宏)和 DataSet Macros(数据集宏)。它们的定义方式和SQL查询文本中的指示方式不同。

DataSet Macros由“&MacroName”定义,仅影响指定的数据集。

Connection Macros由“{MacroName}”定义,并影响所有关联的数据集。

让我们对TUniConnection.Macros进行更详细的分析。以传统方式使用它:

if  UniConnection.ProviderName = 'Oracle' then  UniConnection.MacroByName('tablename').Value := 'dept'elseif  UniConnection.ProviderName = 'MySql' then  UniConnection.MacroByName('tablename').Value := 'test.dept';复制代码

或者你可以使用预定义的方法。宏是一组名称,条件和值。如果启用了潜在条件,宏将计算其值,如果未启用条件,则计算为空字符串。根据TUniConnection组件使用的提供程序启用或禁用条件。例如,如果使用Oracle提供程序,则将启用ORACLE宏。

因此,基于Oracle条件的所有宏在SQL语句中使用时都会返回它们的值;所有其他宏返回空字符串。有关可用条件的列表(或者说,预定义的宏),请参阅“宏参考”(“宏参考”将会在后续文章中与大家分享)。

从API的角度来看,宏表示为TUniMacro类。宏的集合被组织成TUniMacros,可以通过TUniConnection的宏属性访问它。每个连接都有一组独立的宏。

以下示例演示了宏的用法:

UniConnection.Provider = 'MySQL';...UniConnection.Open;UniConnection.Macros.Add('tablename', 'test.dept', 'MySQL');UniQuery.SQL.Text := 'SELECT Count(*) FROM {tablename}';UniQuery.Open;复制代码

现在假设我们需要在Oracle服务器上执行相同的操作。 由于使用了UniSQL,唯一要添加的是另一个宏:

UniConnection.Provider = 'Oracle';...UniConnection.Open;UniConnection.Macros.Add('tablename', 'test.dept', 'MySQL');UniConnection.Macros.Add('tablename', 'dept', 'Oracle');UniQuery.SQL.Text := 'SELECT Count(*) FROM {tablename}';UniQuery.Open;复制代码

如你所见,控制SQL语句转换非常容易。现在让我们看一下演示一大堆重要功能的另一个示例:

UniConnection.Macros.Add('tablename', 'emp', '');//For MySQL, prepend database nameUniConnection.Macros.Add('tablename', 'test.emp', 'MySQL');//Limit records count where it is easy (MySQL and PostgreSQL)UniConnection.Macros.Add('limit', 'LIMIT 0,5', 'MySQL');UniConnection.Macros.Add('limit', 'LIMIT 5 OFFSET 0', 'PostgreSQL');//Define default FROM clauseUniConnection.Macros.Add('from', 'FROM {tablename}', '');//If the limit macro is defined, add extra clauseUniConnection.Macros.Add('from', 'FROM {tablename} {limit}', 'limit');//Define query that uses the macroUniQuery.SQL.Text := 'SELECT EName, Job, Sal {from}';UniQuery.Open;复制代码

假设在此示例中连接到MySQL服务器,执行的语句将是:

SELECT EName, Job, Sal FROM emp LIMIT 0,5

注意:你可以使用DBMonitor应用程序查看执行时查询的内容。对样本的逐步分析揭示了以下重要说明:

  1. 如果宏具有空白条件,则始终对其进行评估。
  2. 启用条件的宏将覆盖具有空白条件的宏。
  3. 条件不区分大小写。
  4. 你可以使用自己的宏作为条件。
  5. 你可以将宏用作其他宏值的一部分。

你可以在大括号内的宏名称后添加任何文本。如果启用了宏的条件,则将此文本添加到最终的SQL语句中。例如:

UniConnection.Macros.Add('schema', 'test', 'MySQL');UniQuery.SQL.Text := 'SELECT * FROM {schema .}emp';UniQuery.Open;复制代码

在此示例中,仅在启用SCHEMA宏时才添加点。UniDAC提供了一组有用的预定义宏,可以帮助你编写通用语句。有关更多信息,请参阅“宏参考”(“宏参考”将会在后续文章中与大家分享)。

转载于:https://juejin.im/post/5c9b3b1551882520a4120b51

你可能感兴趣的文章
maven generating project in batch mode hang
查看>>
Excel与XML相互转换 - C# 简单实现方案
查看>>
远程通信的几种选择(RPC,Webservice,RMI,JMS的区别)
查看>>
基础二:javascript面向对象、创建对象、原型和继承总结(下)
查看>>
360. Sort Transformed Array
查看>>
docker使用流程
查看>>
一次解决OOM的经历
查看>>
JavaScript闭包
查看>>
樹莓派初始化安裝配置筆記
查看>>
TouchID本地身份验证
查看>>
android:launchMode小分析
查看>>
大转变,苹果或于明年推出使用 ARM 芯片的 Mac
查看>>
Docker 容器与主机时间同步
查看>>
爬虫基础-http请求的基础知识
查看>>
第十六章:数据绑定(三)
查看>>
antiX 17.4 发布,轻量级 Linux 发行版
查看>>
Java高并发秒杀Api-web 层
查看>>
全网互联之高速通道
查看>>
JVM GC杂谈之理论入门
查看>>
byteorder.h学习
查看>>