Partilhar via


Sintaxe X++

Observação

Os grupos de interesse da comunidade passaram do Yammer para o Microsoft Viva Engage. Para participar de uma comunidade Viva Engage e participar das últimas discussões, preencha o formulário Solicitar acesso ao Finance and Operations Viva Engage Community e escolha a comunidade à qual deseja participar.

Este artigo contém a referência de sintaxe para X++.

Palavras-chave X++

As palavras-chave X++ mostradas na tabela a seguir são reservadas. Essas palavras-chave não podem ser usadas para qualquer outra finalidade.

Palavra reservada Description Informações adicionais
! Não. Operadores Relacionais
!= Operador de desigualdade (não igual a). Operadores Relacionais
# Prefixo em nomes de macro. Como usar #define e #if para testar uma macro
& Binário E. Operadores Aritméticos
&& Lógica E. Operadores Relacionais
( Operador de chamada de função, que indica o início da chamada de função.
) Operador de chamada de função, que indica o fim da chamada de função.
* Multiplique. O asterisco (*) também é usado no X++ SQL. Um uso é significar todos os campos das tabelas em uma select instrução. Outro uso é como um curinga com o like operador, para significar 0 a muitos caracteres de qualquer tipo. O like operador também usa o caractere ? Operadores Aritméticos
^ XOR binário. Operadores Aritméticos
| Binário OR. Operadores Aritméticos
|| OR lógico. Operadores Relacionais
~ Não. Operadores Aritméticos
+ Mais. Operadores Aritméticos
++ Incremento. Operadores de Atribuição
+= Atribuição aditiva. Operadores de Atribuição
, Operador de vírgula. As expressões separadas por vírgulas são avaliadas sequencialmente da esquerda para a direita.
- Menos. Operadores Aritméticos
-- Operador de decréscimo. Operadores de Atribuição
-= Atribuição subtrativa. Operadores de Atribuição
. O operador de acesso de membro de classe, por exemplo, formRun.run acessa o run método de um objeto do tipo FormRunde classe.
/ Divida. Operadores Aritméticos
\ Fuja em cordas. Escapa de aspas extras e certas letras, como '\t' para a guia.
@ Fuga de palavras-chave. Por exemplo, var @str = 1@abstract; falha ao compilar sem o @ caractere que faz com que qualquer cadeia de caracteres que o siga seja considerada como um identificador. Ele também afeta cadeias de caracteres literais, negando o efeito do caractere de escape \ e permitindo que a cadeia de caracteres abranja mais de uma linha no código-fonte. A nova linha é representada por um caractere de 0x0A hexadecimal, que é comumente chamado de alimentação de linha. Nenhum caractere de retorno de carro de 0x0D hexadecimal está incluído, como no 0x0D0A.
: O caractere dois pontos (:) é usado para delimitar valores de maiúsculas e minúsculas switch na instrução.
:: Usado para chamar métodos estáticos (classe): ClassName::methodName() e para designar literais de enumeração, como NoYes::Yes.
; Encerra declarações. Usado em for loops ou como um separador de inicializador, atualização e partes de verificação de valor.
< Menos que. Operadores Relacionais
<< Desvio para a esquerda. Operadores Aritméticos
<= Menor ou igual. Operadores Aritméticos
= Operador de atribuição. O argumento à esquerda de "=" é definido como o valor do argumento à direita. Operadores de Atribuição
== Retorna true se as expressões forem iguais. Operadores Relacionais
> Maior que. Operadores Relacionais
>= Maior ou igual. Operadores Relacionais
>> Bitwise Shift para a direita. Este operador desloca bits no lado esquerdo pela quantidade no lado direito. Cada turno efetivamente divide o número por 2^n, onde n é o número de posições deslocadas. Operadores Aritméticos
?: Operador ternário. O caractere de ponto de interrogação (?) também é usado pelo like operador para significar exatamente um caractere de qualquer tipo. O like operador também usa o personagem. Operador Ternário (?)
[ Declarador de matriz, aberto. Deve ser usado com "]".
] Declarador de matriz, fechar. Deve ser usado com "[".
{ Inicia uma instrução composta que, por sua vez, pode conter zero ou mais instruções. A instrução composta termina com a correspondência mais próxima "}".
} Indica o final da instrução composta descrita acima. Um "{" deve aparecer antes da primeira dessas declarações.
RESUMO Modificador de classe e método. Uma classe abstrata não pode ser construída com a nova palavra-chave - Somente as classes derivadas dela podem. Um método abstrato não pode ser chamado, apenas métodos que o substituem podem. Uma tabela pode ser modificada como abstrata definindo sua propriedade Abstract como Sim na AOT ou usando a DictTable classe. O padrão da propriedade Abstract é No, e não pode ser definido a menos que a tabela seja estendida por outra tabela. Cada linha em uma tabela abstrata deve ter uma linha dependente em uma tabela derivada. Isso significa que cada linha em uma tabela abstrata tem um valor maior que zero em seu campo de propriedade InstanceRelationType . Não há outros efeitos de marcar uma tabela como abstrata. Informalmente, os programadores costumam usar o termo concreto para descrever uma classe que não é abstrata. Visão geral da herança da tabela de modificadores de método
qualquer tipo Um tipo que pode conter valores de qualquer tipo. Qualquer tipo
como Necessário quando você atribui uma variável de classe base a uma variável de classe derivada. Por exemplo, dada uma Derived classe que estende uma Base classe, a instrução myDerived = myBase as Derived; evita um erro do compilador usando a palavra-chave as . Essa palavra-chave também se aplica quando você atribui uma variável de tabela base a uma variável de tabela derivada. Se o valor (myBase) não for do tipo designado (Derived), a expressão retornará null. Operadores de expressão: é e quanto à herança
ASC Uma opção sobre a orderby cláusula ou groupby em uma select declaração. A classificação é ascendente. Selecionar sintaxe da instrução
at Especifica a posição de uma janela de impressão como parte de uma print instrução. A instrução de impressão não deve ser usada. Imprimir Instruções
avg Devolve a média dos campos das linhas especificadas pela group by cláusula numa select instrução. Selecionar sintaxe da instrução
break Saída imediata de um bloco de código iterativo. Declarações de quebra
Ponto de interrupção Representa um ponto de interrupção definido para fins de depuração. Para definir um ponto de interrupção em seu código, escreva: breakpoint;
por Parte de um termo reservado, como agrupar por e ordenar por.
byref Especifica que o parâmetro que está sendo passado para o método chamado está sendo passado por referência (endereço), em vez de por valor. Byref é usado no X++ ao chamar um método .NET que usa um parâmetro por referência (como com as palavras-chave C# out ou ref). Como: Usar a palavra-chave byref para interoperabilidade CLR.
caixa Seleção dentro de uma switch instrução. Instruções Switch
captura Usado no tratamento de exceções. Tratamento de exceções com palavras-chave try e catch
mudançaEmpresa Altera as configurações do banco de dados para outra empresa. Alterar padrão de design da empresa
classe Declara uma classe. Aulas em X++
cliente Modificador de método. Esses modificadores não são mais usados. Todos os métodos são executados na camada do servidor. Modificadores de método
contentor Designa o container tipo. Os contentores contêm uma sequência de valores atómicos e outros contentores. Contentores
continue Força a próxima iteração de um loop. Continuar Declarações
count Retorna o número de registros das linhas especificadas pela group by cláusula em uma select instrução. Selecionar sintaxe da instrução
Empresa cruzada Faz com que uma select declaração retorne dados de todas as empresas das quais o usuário está autorizado a ler. Noções básicas de código X++ entre empresas
date Especifica uma variável do tipo date. Dates
padrão Caso padrão dentro switch das instruções. O bloco de código na parte padrão é executado se o valor do switch não corresponder case a nenhuma das cláusulas fornecidas na switch instrução. Instruções Switch
delegate Um membro de classe que é capaz de armazenar várias referências a métodos em outras classes e chamar todos esses métodos quando solicitado a fazê-lo. Um delegado pode armazenar referências a vários tipos de métodos, incluindo o seguinte:
  • métodos estáticos em classes X++
  • métodos de instância em classes X++
  • métodos em classes do .NET Framework
Terminologia do evento e palavras-chave X++, Comparação em C#: Evento
delete_from Permite excluir registros do banco de dados. delete_from
desc Uma opção sobre a order by cláusula ou group by em uma select declaração. A classificação é decrescente. Selecionar sintaxe da instrução
Ecrã Modificador de método. Um método display</display> é usado para mostrar valores calculados em um controle de formulário. Ao contrário dos campos regulares, esses valores não são armazenados no banco de dados, mas são computados dinamicamente. Modificadores de método
div Divisão inteira. Operadores Aritméticos
fazer Início de um do...while loop. Faça... enquanto Loops
edit Modificador de método. Um edit método em X++ permite que os usuários modifiquem valores em um controle de formulário enquanto executam lógica personalizada. Ao contrário dos display métodos, que mostram apenas valores calculados, os métodos de edição permitem a visualização e a edição. Modificadores de método
Senão Execução condicional (if...else). A else parte da instrução é executada if se a expressão na instrução if for avaliada como false se e se... outras declarações
eventHandler Deve ser usado sempre que você adicionar ou excluir uma referência de método de um delegado usando o += operador or -= . Por exemplo: myDelegate += eventHandler(OtherClass::myStaticMethod); Terminologia do evento e palavras-chave X++, Comparação em C#: Evento
existe Usado com join cláusulas em select declarações. Selecionar sintaxe da instrução
estende-se Uma cláusula de declaração de classe ou interface. Se sua classe não estender explicitamente outra classe, sua classe será considerada para estender a Object classe (como se você tivesse escrito "estende Object"). Criando uma subclasse
falso Literal booleano. Booleanos
Finais Modificador de classe e método. Especifica que esse método não pode ser substituído. Modificadores de método
primeiroRápido Usado em select instruções para acelerar a busca para a primeira linha. Selecionar sintaxe da instrução
primeiroApenas Usado em select declarações para buscar apenas o primeiro registro. A firstOnly palavra-chave não garante que um máximo de um registro seja recuperado por uma instrução X++ SQL select . Se o AOS puder usar o EntireTable cache para satisfazer as demandas de dados da select instrução, a firstOnly palavra-chave será ignorada. Selecionar cache baseado em conjunto de sintaxe de instrução
primeiroApenas10 O mesmo que firstOnly, exceto retorna 10 linhas em vez de uma.
primeiroApenas100 O mesmo que firstOnly, exceto retorna 100 linhas em vez de uma.
primeiroOnly1000 O mesmo que firstOnly, exceto retorna 1.000 linhas em vez de uma.
flush Limpa todo o cache da tabela. Isso pode ser útil quando você deseja garantir que quaisquer alterações feitas na tabela sejam imediatamente refletidas nas operações subsequentes. Cache baseado em conjuntos
for Para iteração de loop. Para loops
forçaLiterais Usado em select instruções para revelar valores reais que são usados em where cláusulas para o banco de dados do Microsoft SQL Server no momento da otimização. Selecionar sintaxe da instrução
forceNestedLoop Força o banco de dados do SQL Server a usar um algoritmo de loop aninhado para processar uma instrução SQL específica contendo um joinarquivo . Selecionar sintaxe da instrução
forceEspaços reservados Usado em select instruções para instruir o kernel a não revelar os valores reais usados em where cláusulas para o banco de dados do Microsoft SQL Server no momento da otimização. Selecionar sintaxe da instrução
forceSelectOrder Força o banco de dados do SQL Server a acessar as tabelas em uma junção na ordem especificada. Selecionar sintaxe da instrução
paraAtualizar Seleciona registros exclusivamente para atualização. A operação a ser executada nos registros que são buscados é uma atualização. Dependendo do banco de dados subjacente, os registros podem ser bloqueados para outros usuários. Selecionar sintaxe da instrução
from Parte de uma select declaração. A from cláusula especifica o buffer de tabela no qual as colunas existem. Selecionar sintaxe da instrução
group Parte da group by cláusula em uma select declaração. Selecionar sintaxe da instrução
if Execução condicional. se e se... outras declarações
implementa Implementação de um interface. Visão geral das interfaces
insert_recordset Copia dados de uma ou mais tabelas para uma tabela de destino resultante em uma única viagem de servidor. insert_recordset
int Especifica uma variável do tipo integer (32 bits). Números inteiros
Int64 Especifica uma variável do tipo integer (64 bits). Números inteiros
interface Declaração de interface. Visão geral das interfaces
é Pergunta se o objeto referenciado por uma variável de classe herda da classe determinada ou é da classe dada. Por exemplo, dada uma Derived classe que estende uma Base classe, a expressão (myDerived is Base) retorna true. Esta palavra-chave aplica-se à herança de classe e à herança de tabela. Operadores de expressão: é e quanto à herança
junte-se a As tabelas são unidas em colunas comuns a ambas as tabelas. Você pode gerar um único conjunto de resultados com base em várias tabelas usando junções. Selecionar sintaxe da instrução
goste Testes para correspondências por padrão, com símbolos curinga '*' e '?'. Operadores Relacionais
máx. Devolve o máximo de campos das linhas especificadas pela group by cláusula. Selecionar sintaxe da instrução
minof Devolve o mínimo dos campos das linhas especificadas pela group by cláusula. Selecionar sintaxe da instrução
mod Retorna o número inteiro restante da expressão esquerda1 dividida pela expressão direita2. Informalmente, isso às vezes é chamado de operador de módulo. (12 mod 7) == 5 é verdade.
Novo Operador. Cria uma instância de uma classe ou aloca memória para uma matriz.
next Busca o próximo registro em uma tabela ou chama o próximo método em uma sequência de cadeia de comando.
noFetch Indica que nenhum registro deve ser buscado agora. Selecionar sintaxe da instrução
nãoexiste Usado com join cláusulas em select declarações. Selecionar sintaxe da instrução
null Constante simbólica.
optimisticLock Força uma instrução a ser executada com controle de simultaneidade otimista, mesmo que um valor diferente seja definido na tabela. Selecionar sintaxe da instrução
Encomenda Parte da order by cláusula em uma select declaração. Selecionar sintaxe da instrução
exterior junção externa. Selecionar sintaxe da instrução
pause Interrompe a execução de um trabalho. O usuário é solicitado a declarar se a execução deve continuar. Você não deve usar essa instrução no código de produção. Selecionar instruções
pessimisticLock Força uma instrução a ser executada com controle de simultaneidade pessimista, mesmo que um valor diferente seja definido na mesa. Selecionar sintaxe da instrução
print Permite que você exiba a saída na tela. Você não deve usar essa instrução no código de produção. Imprimir Instruções
privada Modificador de acesso ao método. O método só pode ser usado dentro da classe que declara o método. Controlo de Acesso ao Método
protegido Modificador de acesso ao método. O método pode ser usado a partir de métodos na classe que declara os métodos e em quaisquer classes derivadas. Controlo de Acesso ao Método
public Modificador de acesso ao método. O método pode ser chamado de qualquer classe. Controlo de Acesso ao Método
real Designa o real tipo, um tipo decimal sem erros de arredondamento. Reais
repetívelLer Especifica que nenhuma outra transação pode modificar dados que foram lidos pela lógica dentro da transação atual, até que a transação atual seja concluída. Uma transação explícita é concluída em ttsAbort ou no ttsCommit. Para uma instrução select autônoma, a duração da transação é a duração do comando select . No entanto, o banco de dados às vezes impõe o equivalente a repeatableRead em instruções select individuais, mesmo sem que essa palavra-chave apareça em seu código X++ (dependendo de como o banco de dados decide verificar as tabelas). Para obter mais informações, consulte a documentação do produto de banco de dados relacional subjacente.
retentar Usado no tratamento de exceções. Tratamento de exceções com palavras-chave try e catch
regresso Retorna de um método. Declaração de Métodos
reverse Os registos são devolvidos por ordem inversa. Selecionar sintaxe da instrução
selecionar A select cláusula designa quais colunas ou exibições são mostradas no conjunto de resultados. Selecionar instruções
servidor Modificador de método. Este modificador é ignorado e não deve ser usado, uma vez que todos os métodos são executados no lado do servidor. Modificadores de método
Cenário Usado com o comando update_recordset . update_recordset
estática Os métodos estáticos não podem referir-se a variáveis de instância (apenas a variáveis estáticas); pode ser invocado usando o nome da classe em vez de em uma instância da classe ("MyClass.aStaticProcedure"). Modificadores de método
STR Designa o string tipo. Cordas
soma Retorna a soma dos campos das linhas especificadas pela group by cláusula em uma select instrução. Selecionar sintaxe da instrução
super Chama o método que foi substituído pelo método atual. Métodos de tabela
interruptor Instrução Switch. Instruções Switch
tableLock Obsoleto; tableLock não está mais disponível.
isto Uma referência à instância atual da classe. Usado no código X++ dentro de um método de instância da classe. Usado para fazer referência a membros do método da classe.
arremesso Usado no tratamento de exceções. Tratamento de exceções com palavras-chave try e catch
verdadeiro Literal booleano. Booleanos
tente Usado no tratamento de exceções. Tratamento de exceções com palavras-chave try e catch
ttsAbort Reverter (ou seja, descartar) todas as alterações na transação atual. Integridade da transação
ttsBegin Marca o início de uma transação. Integridade da transação
ttsCommit Marca o fim de uma transação, confirmando as alterações nas tabelas. Integridade da transação
update_recordset Permite a manipulação de conjuntos de linhas dentro de uma operação. update_recordset
validTimeState Filtra linhas recuperadas de uma tabela de estado de tempo válida por uma instrução X++ SQL select . Por exemplo: selecione validTimeState(myDateEffective) * de xMyTable; ... ou... selecione validTimeState(myDateFrom, myDateTo) * de xMyTable; Efeitos de tabelas de estado de tempo válidas em operações de leitura e gravação
Vazio Identifica um método que não retorna um valor. Declaração de Métodos
where Parte de uma select declaração. A where cláusula especifica as condições a serem satisfeitas, ou seja, as linhas que você deseja incluir no resultado. Selecionar sintaxe da instrução
enquanto Declaração de iteração. Executa uma instrução repetidamente, desde que a condição de teste seja verdadeira. Enquanto faz loops enquanto seleciona Instruções
janela Permite alterar o tamanho da janela de saída. Usado com instruções de impressão</impressão> que não são recomendadas no código de produção. Imprimir Instruções

Sintaxe das expressões

Uma expressão em X++ é usada de forma matemática ou lógica. As expressões são construídas sobre os tipos de dados da linguagem; ou seja, uma expressão sempre retorna um valor de algum tipo. Esse valor pode ser usado em cálculos, atribuições, instruções condicionais e assim por diante.

EBNF Descrição de expressões em X++

Term   Definition
Expression = Expressão simples [OperadorRelacional Expressão simples ]
RelationalOperator = =
Expressão simples = Expressão simples [ +
Term = Compfactor { Mult-operador CompFactor }
Operador de mult = *
CompFactor = [ ! ] [ -
Fator = Literal
Enum = EnumName :: Literal
Variable = Identificador [ [ Expressão ] ] [ . Expressão ]
Chamada de função = [ Expressão (.
Se-expressão = Expressão ? Expressão : Expressão

Restrições semânticas se aplicam à sintaxe anterior. Não é possível chamar nenhum método usando o operador ::. Da mesma forma, você não pode usar a palavra-chave this sem um objeto ativo; ou seja, se você não estiver dentro de um método de instância e assim por diante.

Examples

Exemplo de expressão Description
1 Um literal inteiro.
NãoSim::Não Um enum-referência.
A Uma referência variável.
Devedor::Find("1") Uma chamada de método estática (retorna uma variável de cliente).
(A > 3 ? verdadeiro: falso) Uma expressão if que retorna true ou false.
(selecione CustTable onde CustTable.Account == "100"). NomeRef Uma expressão select. Retorna o campo nameref na tabela do cliente. Esta é uma cadeia de caracteres.
A >= B Uma expressão lógica. Devolve true ou false.
A + B Uma expressão aritmética. Somas A e B.
A + B / C Calcula B/C e, em seguida, adiciona-o a A.
~A + isto. Valor() Somas binárias não A e o resultado do valor de chamada de método no objeto no escopo (este).
Devedor::Find("1"). NomeRef Retorna o campo NameRef do registro de cliente encontrado.
Devedor::Find("1"). Saldo() Uma chamada de método na Balance tabela do cliente (Devedor::Find retorna um cliente). Devolve o saldo do cliente com o número de conta 1.

Visão geral da EBNF

Extended Backus Naur Form (EBNF) é uma metalinguagem e é usada neste guia para descrever a sintaxe da linguagem. Uma definição EBNF consiste em regras de produção, não-terminais e terminais. Os termos-chave são mostrados na tabela a seguir.

Termos principais Example Description
Terminais Work_Team Um terminal é um caractere ou uma sequência de caracteres que nunca mudam.
Não terminais Employee Um não-terminal é uma descrição de parte de uma frase válida na língua que é definida por uma regra de produção ou uma descrição textual. Um símbolo não terminal pode sempre ser expandido para um ou mais símbolos terminais.
Regras de produção Funcionário = Desenvolvedor Tester

Example

Work_Team = Gerente Funcionário {, Funcionário} Funcionário = Desenvolvedor | Tester Este exemplo define um Work_Team como consistindo de um Manager e um ou mais Employees. Um Employee é definido como sendo um Developer, ou um Tester. Os símbolos usados no exemplo são descritos na tabela a seguir.

Símbolos especiais na EBNF

Symbol Description
(Expressão) Parênteses mantêm os símbolos (terminais e não terminais) juntos. Eles podem ser colocados em qualquer lugar no lado direito de uma regra de produção.
Expressão1 Expressão2
[Expressão] Opcional: Os itens entre [ e ] são opcionais. Todos ou nenhum dos itens entre parênteses está incluído.
{Expressão} Repetir: Os itens entre { e } são opcionais, mas podem ser repetidos quantas vezes forem necessárias.

Por exemplo, se os acessórios que você compra para sua bicicleta consistem em uma sela, suportes para garrafas de água, sinos e buzinas, e você pode ter um sino ou uma buzina, e zero, um ou mais suportes para garrafas de água, e exatamente uma sela, isso pode ser expresso como: Bicycle_Accessories = sela [sino | buzina] {water_bottle_holders} Esta gramática define as seguintes possibilidades: saddlesaddle bellsaddle horn sela water_bottle_holder sino de sela water_bottle_holder sino de sela water_bottle_holder water_bottle_holder E assim por diante.

Gramática X++

Este artigo mostra a gramática formal da linguagem X++.

Como interpretar a gramática formal da BNF

Esta seção descreve a gramática do X++ no Backus Naur Form (BNF). Um pequeno exemplo de FBN é descrito aqui.

AA ::= BB  CC_SYM
BB ::= JJ_SYM
   ::= KK_SYM

AA é o nome de uma regra de produção. Um AA requer um BB, seguido de um CC_SYM. A BB é também uma regra de produção. Portanto, BB não é um terminal. BB deve ser um JJ_SYM ou um KK_SYM. Tanto JJ_SYM quanto KK_SYM são terminais porque não são os nomes de nenhuma outra regra de produção. CC_SYM também é um terminal.

Na gramática BNF para X++, a maioria dos terminais tem _SYM como sufixo de seu nome.

Gramática formal X++ em BNF

Esta seção contém o BNF que define a gramática do X++.

    CMPL_UNIT ::= RETTYPEID  FUNC_HDR  FUNC_HEAD  BODY
              ::= RETTYPEID  DATA_HDR  CLASS_DECL
              ::= EXPR_HDR  IF_EXPR  SEMIOPT
              ::= RETTYPEID  FUNC_HDR  EVENT_DECL  BODY
    SEMIOPT ::= SEMICOLON_SYM
            ::= 
    CLASS_DECL ::= CLASS_HEADER  LEFTBR_SYM  DCL_EVENTMAP  DCL_LIST  RIGHTBR_SYM
    CLASS_HEADER ::= ATTRIBUTE_DEF  CLASS_MODIFIERS  CLASSORINTERFACE  STD_ID  EXTENDS  IMPLEMENTS
    ATTRIBUTE_DEF ::= LEFT_BRKT_SYM  ATTRIBUTE_INIT  ATTRIBUTE_LIST  RETTYPEID  RGHT_BRKT_SYM
                  ::= 
    ATTRIBUTE_INIT ::= 
                   .
    ATTRIBUTE_LIST ::= ATTRIBUTE
                   ::= ATTRIBUTE_LIST  LIST_SEP_SYM  ATTRIBUTE
    ATTRIBUTE ::= STD_ID
              ::= ATTRIBUTE_WITH_ARGS_BEGINS  ATTRIBUTE_WITH_ARGS_ENDS
    ATTRIBUTE_WITH_ARGS_BEGINS ::= STD_ID  LEFT_PAR_SYM
    ATTRIBUTE_WITH_ARGS_ENDS ::= ATTRIBUTE_ARGS  RGHT_PAR_SYM
    ATTRIBUTE_ARGS ::= ATTRIBUTE_CONSTANT
                   ::= ATTRIBUTE_ARGS  LIST_SEP_SYM  ATTRIBUTE_CONSTANT
    ATTRIBUTE_CONSTANT ::= INT_SYM
                       ::= DBL_SYM
                       ::= STR_SYM
                       ::= DATE_SYM
                       ::= DATETIME_SYM
                       ::= STD_ID  DBLCOLON_SYM  STD_ID
                       ::= TRUE_SYM
                       ::= FALSE_SYM
                       ::= INT64_SYM
                       ::= ATTRIBUTE_INTRINSIC
    ATTRIBUTE_INTRINSIC ::= INTRI_ID  LEFT_PAR_SYM  IARGS  RGHT_PAR_SYM
    CLASSORINTERFACE ::= CLASS_SYM
                     ::= INTERFACE_SYM
    CLASS_MODIFIERS ::= CLASS_MODS
                    ::= 
    CLASS_MODS ::= CLASS_MODIFIER
               ::= CLASS_MODS  RETTYPEID  CLASS_MODIFIER
    CLASS_MODIFIER ::= PUBLIC_SYM
                   ::= FINAL_SYM
                   ::= STATIC_SYM
                   ::= ABSTRACT_SYM
                   ::= PRIVATE_SYM
    EXTENDS ::= EXTENDS_SYM  STD_ID
            ::= 
    IMPLEMENTS ::= IMPLEMENTS_SYM  IMPLEMENTLIST
               ::= 
    IMPLEMENTLIST ::= STD_ID
                  ::= IMPLEMENTLIST  LIST_SEP_SYM  STD_ID
    DCL_EVENTMAP ::= 
    EVENT_DECL ::= ATTRIBUTE_DEF  EVENT_HEADER  PARM_DCL_LIST
    EVENT_HEADER ::= EVENT_MODIFIER  VOID_TYPE_SYM  STD_ID
    EVENT_MODIFIER ::= EVENT_SYM
    FUNC_HEAD ::= ATTRIBUTE_DEF  FUNCNAME  PARM_DCL_LIST
    FUNCNAME ::= FUNCTYPE  STD_ID
    FUNCTYPE ::= FUNC_MODIFIERS  DECL_TYPE
    FUNC_MODIFIERS ::= FUNC_MODS
                   ::= 
    FUNC_MODS ::= RETTYPEID  FUNC_MODIFIER
              ::= FUNC_MODS  RETTYPEID  FUNC_MODIFIER
    FUNC_MODIFIER ::= PUBLIC_SYM
                  ::= PRIVATE_SYM
                  ::= PROTECTED_SYM
                  ::= FINAL_SYM
                  ::= STATIC_SYM
                  ::= ABSTRACT_SYM
                  ::= DISPLAY_SYM
                  ::= EDIT_SYM
                  ::= SERVER_SYM
                  ::= CLIENT_SYM
    BODY ::= LEFTBR_SYM  DCL_FUNC_LIST  SEMIOPT  SECAUTHZCHECK  STMTLIST  SECAUTHZEND  RIGHTBR_SYM
    SECAUTHZCHECK ::= 
    SECAUTHZEND ::= 
    RETTYPEID ::= 
    FUNCTION_DEF ::= FUNC_HEADER  PARM_DCL_LIST  LOCAL_BODY
    FUNC_HEADER ::= DECL_TYPE  STD_ID
    PARM_DCL_LIST ::= RETTYPEID  PARM_START  PARM_LIST_OPT  RGHT_PAR_SYM  RETTYPEID
    PARM_START ::= LEFT_PAR_SYM
    PARM_LIST_OPT ::= PARM_LIST
                  ::= 
    PARM_LIST ::= DCL_INIT
              ::= PARM_LIST  LIST_SEP_SYM  DCL_INIT
    LOCAL_BODY ::= LEFTBR_SYM  DCL_LIST  SEMIOPT  STMTLIST  RETTYPEID  RIGHTBR_SYM
    DCL_LIST ::= DCL_LIST2
             ::= 
    DCL_LIST2 ::= DCL_STMT
              ::= DCL_LIST2  DCL_STMT
    DCL_FUNC_LIST ::= DCL_FUNC_LIST2
                  ::= 
    DCL_FUNC_LIST2 ::= DCL_STMT
                   ::= FUNCTION_DEF
                   ::= DCL_FUNC_LIST2  DCL_STMT
                   ::= DCL_FUNC_LIST2  FUNCTION_DEF
    DCL_STMT ::= DCL_INIT_LIST  RETTYPEID  SEMICOLON_SYM
    DCL_INIT_LIST ::= DCL_INIT
                  ::= DCL_CLIST  ASG_CLAUSE
    DCL_CLIST ::= DCL_INIT_LIST  LIST_SEP_SYM  STD_ID  ARR_DCL_IDX
    DCL_INIT ::= DECL  ASG_CLAUSE
    DECL ::= DECL_TYPE  STD_ID  ARR_DCL_IDX
    DECL_TYPE ::= STR_TYPE_SYM  STR_LEN
              ::= INT_TYPE_SYM
              ::= DBL_TYPE_SYM
              ::= DATE_TYPE_SYM
              ::= DATETIME_TYPE_SYM
              ::= TYPE_ID
              ::= QUEUE_TYPE_SYM
              ::= VOID_TYPE_SYM
              ::= ANY_TYPE_SYM
              ::= GUID_TYPE_SYM
              ::= INT64_TYPE_SYM
              ::= CLR_TYPE
    CLR_TYPE ::= CLR_NAMESPACE  TYPE_ID  CLR_ARRAY_TYPE_EXT
             ::= CLR_NAMESPACE  CLR_TYPE
    CLR_NAMESPACE ::= TYPE_ID  PERIOD_SYM
    CLR_ARRAY_TYPE_EXT ::= CLR_ARRAY_SPEC
                       ::= 
    CLR_ARRAY_SPEC ::= CLR_ARRAY_PART
                   ::= CLR_ARRAY_SPEC  CLR_ARRAY_PART
    CLR_ARRAY_PART ::= CLR_ARRAY_LEFT_PART  CLR_RECTANGULAR_LIST  RGHT_BRKT_SYM
    CLR_ARRAY_LEFT_PART ::= LEFT_BRKT_SYM
    CLR_RECTANGULAR_LIST ::= CLR_COMMA_LIST
                         ::= 
    CLR_COMMA_LIST ::= LIST_SEP_SYM
                   ::= CLR_COMMA_LIST  LIST_SEP_SYM
    STR_LEN ::= INT_SYM
            ::= 
    ARR_DCL_IDX ::= LEFT_BRKT_SYM  RANGE  ARRAY_MEM  RGHT_BRKT_SYM
                ::= 
    RANGE ::= IF_EXPR
          ::= 
    ARRAY_MEM ::= LIST_SEP_SYM  IF_EXPR
              ::= 
    ASG_CLAUSE ::= INIT_START  IF_EXPR
               ::= 
    INIT_START ::= ASG_SYM
    ASG_STMT ::= LVAL_FLD  ASSIGN  IF_EXPR
             ::= LVAL_LIST  ASG_SYM  IF_EXPR
             ::= LVAL_FLD  ASG_INC_DEC
             ::= ASG_INC_DEC  LVAL_FLD
             ::= LVAL_FLD  ASG_EVENT_HANDLER
    ASSIGN ::= ASG_SYM
           ::= ASGINC_SYM
           ::= ASGDEC_SYM
    ASG_INCDEC ::= ASGINC_SYM
               ::= ASGDEC_SYM
    ASG_EVENT_HANDLER ::= ASG_INCDEC  EVENTHANDLER_SYM  LEFT_PAR_SYM  QUALIFIER  STD_ID  RGHT_PAR_SYM
      ::= ASG_INCDEC  EVENTHANDLER_SYM  LEFT_PAR_SYM  STD_ID  DBLCOLON_SYM  STD_ID  RGHT_PAR_SYM
      ::= ASG_INCDEC  EVENTHANDLER_SYM  LEFT_PAR_SYM  QUALIFIER  EVAL_CLR_TYPE  DBLCOLON_SYM  STD_ID  RGHT_PAR_SYM
    ASG_INC_DEC ::= INC_SYM
                ::= DEC_SYM
    LVAL_FLD ::= FIELD
    LVAL_START ::= LEFT_BRKT_SYM
    LVAL_LIST ::= LVAL_START  LVALUES  RGHT_BRKT_SYM
    LVALUE ::= FIELD
    LVALUES ::= LVALUE
            ::= LVALUES  NEXTLVAL  LVALUE
    NEXTLVAL ::= LIST_SEP_SYM
    IF_EXPR ::= COND_TRUE  IF_EXPR
            ::= BOOL_EXPR
    COND_TRUE ::= COND_TEST  IF_EXPR  COLON_SYM
    COND_TEST ::= BOOL_EXPR  QUEST_SYM
    BOOL_EXPR ::= BOOL_EXPR  LOGOP  EXPR
              ::= EXPR
    LOGOP ::= AND_SYM
          ::= OR_SYM
    EXPR ::= SMPL_EXPR  RELOP  SMPL_EXPR
         ::= SMPL_EXPR  AS_SYM  STD_ID
         ::= SMPL_EXPR  IS_SYM  STD_ID
         ::= SMPL_EXPR  AS_SYM  EVAL_CLR_TYPE
         ::= SMPL_EXPR  IS_SYM  EVAL_CLR_TYPE
         ::= SMPL_EXPR
    RELOP ::= LT_SYM
          ::= LE_SYM
          ::= EQ_SYM
          ::= NE_SYM
          ::= GT_SYM
          ::= GE_SYM
          ::= LIKE_SYM
    SMPL_EXPR ::= SMPL_EXPR  ADDOP  TERM
              ::= TERM
    ADDOP ::= PLUS_SYM
          ::= MINUS_SYM
          ::= PHYSOR_SYM
    TERM ::= TERM  MULOP  CMPL_FACT
         ::= CMPL_FACT
    MULOP ::= MULT_SYM
          ::= DIV_SYM
          ::= MOD_SYM
          ::= INTDIV_SYM
          ::= SHIFTL_SYM
          ::= SHIFTR_SYM
          ::= PHYSAND_SYM
          ::= PHYSXOR_SYM
    CMPL_FACT ::= NOT_SYM  SGND_FACT
              ::= SGND_FACT
    SGND_FACT ::= SIGNOP  FACTOR
              ::= FACTOR
    SIGNOP ::= UMINUS_SYM
           ::= PHYSNOT_SYM
    FACTOR ::= LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
           ::= CONSTANT
           ::= FIELD
           ::= DIRSEARCH
           ::= FUNCTION
           ::= INTRINSICS
           ::= EVAL
           ::= CONLITTERAL
           ::= NEW_CLR_ARRAY
    NEW_CLR_ARRAY ::= NEW_SYM  EVAL_CLR_TYPE  NEW_CLR_ARRAY_PART  LEFT_PAR_SYM  RGHT_PAR_SYM
    NEW_CLR_ARRAY_PART ::= CLR_SIZED_ARRAY  CLR_NOSIZED_ARRAY_SPEC
    CLR_SIZED_ARRAY ::= LEFT_BRKT_SYM  CLR_SMPL_EXPR_COMMA_LIST  RGHT_BRKT_SYM
    CLR_SMPL_EXPR_COMMA_LIST ::= SMPL_EXPR
      ::= CLR_SMPL_EXPR_COMMA_LIST  LIST_SEP_SYM  SMPL_EXPR
    CLR_NOSIZED_ARRAY_SPEC ::= CLR_NOSIZED_ARRAY_LIST
                           ::= 
    CLR_NOSIZED_ARRAY_LIST ::= CLR_NOSIZED_ARRAY
                           ::= CLR_NOSIZED_ARRAY_LIST  CLR_NOSIZED_ARRAY
    CLR_NOSIZED_ARRAY ::= LEFT_BRKT_SYM  CLR_EMPTY_COMMA_LIST  RGHT_BRKT_SYM
    CLR_EMPTY_COMMA_LIST ::= CLR_EMPTY_RECT_COMMA_LIST
                         ::= 
    CLR_EMPTY_RECT_COMMA_LIST ::= LIST_SEP_SYM
                              ::= CLR_EMPTY_RECT_COMMA_LIST  LIST_SEP_SYM
    CONLITTERAL ::= LEFT_BRKT_SYM  IF_EXPR  EXPR_LIST  RGHT_BRKT_SYM
    CONSTANT ::= INT_SYM
             ::= DBL_SYM
             ::= STR_SYM
             ::= DATE_SYM
             ::= DATETIME_SYM
             ::= STD_ID  DBLCOLON_SYM  STD_ID
             ::= TRUE_SYM
             ::= FALSE_SYM
             ::= NULL_SYM
             ::= INT64_SYM
             ::= QUALIFIER  EVAL_CLR_TYPE  DBLCOLON_SYM  STD_ID
             ::= QUALIFIER  STD_ID  DBLCOLON_SYM  STD_ID
    DIRSEARCH ::= DIRS_HEADER  PERIOD_SYM  STD_ID  ARR_IDX
              ::= DIRS_HEADER  PERIOD_SYM  FLD_NUM  ARR_IDX
    DIRS_HEADER ::= LEFT_PAR_SYM  SET_DIRS  FIND_JOIN  RGHT_PAR_SYM
    SET_DIRS ::= 
    FIELD ::= QUALIFIER  STD_ID  ARR_IDX
          ::= QUALIFIER  FLD_NUM  ARR_IDX
          ::= STD_ID  ARR_IDX
    QUALIFIER ::= EVAL  PERIOD_SYM
              ::= STD_ID  PERIOD_SYM
    FLD_NUM ::= LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
    ARR_IDX ::= LEFT_BRKT_SYM  SMPL_EXPR  RGHT_BRKT_SYM
            ::= 
    EXPR_LIST ::= EXPR_LIST2
              ::= 
    EXPR_LIST2 ::= LIST_SEP_SYM  IF_EXPR
               ::= EXPR_LIST2  LIST_SEP_SYM  IF_EXPR
    FUNCTION ::= FUNC_ID  LEFT_PAR_SYM  EVAL_FUNCTION_NAME  PAR_LIST  RGHT_PAR_SYM
    EVAL_FUNCTION_NAME ::= 
    EVAL_NAME ::= EVAL_ID  LEFT_PAR_SYM
              ::= STD_ID  LEFT_PAR_SYM
              ::= STD_ID  DBLCOLON_SYM  STD_ID  LEFT_PAR_SYM
              ::= SUPER_SYM  LEFT_PAR_SYM
              ::= NEW_SYM  STD_ID  LEFT_PAR_SYM
              ::= NEW_SYM  EVAL_CLR_TYPE  LEFT_PAR_SYM
              ::= QUALIFIER  EVAL_CLR_TYPE  DBLCOLON_SYM  STD_ID  LEFT_PAR_SYM
              ::= QUALIFIER  STD_ID  LEFT_PAR_SYM
              ::= QUALIFIER  STD_ID  DBLCOLON_SYM  STD_ID  LEFT_PAR_SYM
    EVAL_CLR_TYPE ::= NAMESPACE  STD_ID
                  ::= NAMESPACE  EVAL_CLR_TYPE
    NAMESPACE ::= STD_ID  PERIOD_SYM
    EVAL ::= EVAL_NAME  PAR_LIST  RGHT_PAR_SYM
    PAR_LIST ::= PRM_LIST
             ::= 
    PRM_LIST ::= PAR_ELEM
             ::= PRM_LIST  LIST_SEP_SYM  PAR_ELEM
    PAR_ELEM ::= IF_EXPR
             ::= BYREF_SYM  FIELD
    INTRINSICS ::= INTRI_ID  LEFT_PAR_SYM  IARGS  RGHT_PAR_SYM
    IARGS ::= STD_ID
          ::= STR_SYM
          ::= STD_ID  LIST_SEP_SYM  STD_ID
          ::= 
    STMTLIST ::= STATEMENTS
             ::= 
    STATEMENTS ::= STATEMENT
               ::= STATEMENTS  STATEMENT
    STATEMENT ::= COMPOUND_STMT
              ::= WHILE_STMT
              ::= FOR_STMT
              ::= DO_STMT
              ::= SEARCH_STMT
              ::= FIND_STMT
              ::= PRINT_STMT
              ::= WINDOW_STMT
              ::= IF_STMT
              ::= SWITCH_STMT
              ::= EXPR_STMT
              ::= PAUSE_STMT
              ::= BP_CLAUSE
              ::= BREAK_STMT
              ::= CONTINUE_STMT
              ::= RETURN_CLAUSE
              ::= MOVE_REC_STMT
              ::= THROW_STMT
              ::= TRY_STMT
              ::= RETRY_STMT
              ::= TTS_STMT
              ::= FLUSH_STMT
              ::= TBLLOCK_STMT
              ::= CHANGE_STMT
              ::= UPDATE_STMT
              ::= INSERT_STMT
              ::= UNCHECKED_STMT
    COMPOUND_STMT ::= LEFTBR_SYM  STMTLIST  RIGHTBR_SYM
    THROW_STMT ::= THROW_SYM  IF_EXPR  SEMICOLON_SYM
    TRY_STMT ::= TRY_BLOCK  CATCH_LIST
    TRY_BLOCK ::= TRY_START  STATEMENT
    TRY_START ::= TRY_SYM
    CATCH_LIST ::= CATCH_STMT
               ::= CATCH_LIST  CATCH_STMT
    CATCH_STMT ::= CATCH_EXPR  PRE_CATCH  STATEMENT  POST_CATCH
    CATCH_EXPR ::= CATCH_SYM  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
      ::= CATCH_SYM  LEFT_PAR_SYM  IF_EXPR  LIST_SEP_SYM  TABLEINSTANCE  RGHT_PAR_SYM
      ::= CATCH_SYM
    PRE_CATCH ::= 
    POST_CATCH ::= 
    TABLEINSTANCE ::= INSTANCENAME
    INSTANCENAME ::= QUALIFIER  STD_ID  ARR_IDX
                 ::= STD_ID  ARR_IDX
    RETRY_STMT ::= RETRY_SYM  SEMICOLON_SYM
    WHILE_STMT ::= WHILE_TEST  STATEMENT
    WHILE_TEST ::= WHILE  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
    WHILE ::= WHILE_SYM
    DO_STMT ::= DO_BODY  DO_TEST  SEMICOLON_SYM
    DO_BODY ::= DO_HEADER  STATEMENT
    DO_HEADER ::= DO_SYM
    DO_TEST ::= WHILE_SYM  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
    FOR_STMT ::= FOR_HEADER  STATEMENT
    FOR_HEADER ::= FOR_TEST  SEMICOLON_SYM  FOR_ASG  RGHT_PAR_SYM
    FOR_TEST ::= FOR_INIT  SEMICOLON_SYM  IF_EXPR
    FOR_INIT ::= FOR_SYM  LEFT_PAR_SYM  FOR_ASG
    FOR_ASG ::= LVAL_FLD  ASSIGN  IF_EXPR
            ::= LVAL_FLD  ASG_INC_DEC
            ::= ASG_INC_DEC  LVAL_FLD
    JOIN_LIST ::= JOIN_SPECS
              ::= 
    JOIN_SPECS ::= JOIN_SPEC
               ::= JOIN_SPECS  JOIN_SPEC
    JOIN_SPEC ::= JOIN_ORDER  WHERE  IF_EXPR
              ::= JOIN_ORDER
    JOIN_ORDER ::= JOIN_USING
               ::= JOIN_USING  ORDER_GROUP
    JOIN_USING ::= JOIN_CLAUSE  USING_INDEX  STD_ID
               ::= JOIN_CLAUSE  USING_INDEX  HINT_SYM  STD_ID
               ::= JOIN_CLAUSE
    JOIN_CLAUSE ::= OUTER  JOIN_SYM  SELECTOPT  TABLE
    OUTER ::= OUTER_SYM
          ::= EXISTS_SYM
          ::= NOTEXISTS_SYM
          ::= 
    SEARCH_STMT ::= SEARCH_JOIN  STATEMENT
    SEARCH_JOIN ::= SEARCH_WHERE  JOIN_LIST
    SEARCH_WHERE ::= SEARCH_ORDER  WHERE  IF_EXPR
                 ::= SEARCH_ORDER
    WHERE ::= WHERE_SYM
    SUM_ELEM ::= SUM_FUNC  LEFT_PAR_SYM  STD_ID  RGHT_PAR_SYM
    SUM_FUNC ::= SUM_SYM
             ::= AVG_SYM
             ::= CNT_SYM
             ::= MINOF_SYM
             ::= MAXOF_SYM
    SEARCH_ORDER ::= SEARCH_USING
                 ::= SEARCH_USING  ORDER_GROUP
    ORDER_GROUP ::= ORDERBY_CLAUSE  OPT_GROUPBY
                ::= GROUPBY_CLAUSE  OPT_ORDERBY
    OPT_GROUPBY ::= GROUPBY_CLAUSE
                ::= 
    OPT_ORDERBY ::= ORDERBY_CLAUSE
                ::= 
    ORDERBY_CLAUSE ::= ORDER_SYM  OPT_BY  ORDER_ELEM
                   ::= ORDERBY_CLAUSE  LIST_SEP_SYM  ORDER_ELEM
    GROUPBY_CLAUSE ::= GROUP_SYM  OPT_BY  ORDER_ELEM
                   ::= GROUPBY_CLAUSE  LIST_SEP_SYM  ORDER_ELEM
    ORDER_ELEM ::= STD_ID  INDEX  DIRECTION
               ::= ORDER_QUALIFIER  STD_ID  INDEX  DIRECTION
    ORDER_QUALIFIER ::= STD_ID  PERIOD_SYM
    INDEX ::= LEFT_BRKT_SYM  INT_SYM  RGHT_BRKT_SYM
          ::= 
    DIRECTION ::= ASCEND_SYM
              ::= DESCEND_SYM
              ::= 
    OPT_BY ::= BY_SYM
           ::= 
    SEARCH_USING ::= SEARCH_CLAUSE  USING_INDEX  STD_ID
                 ::= SEARCH_CLAUSE  USING_INDEX  HINT_SYM  STD_ID
                 ::= SEARCH_CLAUSE
    USING_INDEX ::= INDEX_SYM
    SEARCH_CLAUSE ::= WHILE_SYM  SELECT_SYM  SELECTOPT  CROSSCOMPANY_CLAUSE  VALIDTIMESTATE_CLAUSE  TABLE
    CROSSCOMPANY_CLAUSE ::= CROSSCOMPANY_SYM
                        ::= CROSSCOMPANY_SYM  COLON_SYM  STD_ID
                        ::= 
    VALIDTIMESTATE_CLAUSE ::= VALIDTIMESTATE_SYM  LEFT_PAR_SYM  STD_ID  LIST_SEP_SYM  STD_ID  RGHT_PAR_SYM
      ::= VALIDTIMESTATE_SYM  LEFT_PAR_SYM  STD_ID  RGHT_PAR_SYM
      ::= 
    SELECTOPT ::= 
              ::= SELECTOPT  REVERSE_SYM
              ::= SELECTOPT  FIRSTFAST_SYM
              ::= SELECTOPT  FIRSTONLY_SYM
              ::= SELECTOPT  FIRSTONLY_SYM1
              ::= SELECTOPT  FIRSTONLY_SYM10
              ::= SELECTOPT  FIRSTONLY_SYM100
              ::= SELECTOPT  FIRSTONLY_SYM1000
              ::= SELECTOPT  FORUPDATE_SYM
              ::= SELECTOPT  NOFETCH_SYM
              ::= SELECTOPT  FORCE_SELECT_ORDER_SYM
              ::= SELECTOPT  FORCE_NESTED_LOOP_SYM
              ::= SELECTOPT  FORCE_LITERALS_SYM
              ::= SELECTOPT  FORCE_PLACEHOLDERS_SYM
              ::= SELECTOPT  REPEATABLEREAD_SYM
              ::= SELECTOPT  OPTIMISTICLOCK_SYM
              ::= SELECTOPT  PESSIMISTICLOCK_SYM
              ::= SELECTOPT  GENERATEONLY_SYM
    FIND_STMT ::= FIND_JOIN  SEMICOLON_SYM
    FIND_JOIN ::= FIND_WHERE  JOIN_LIST
    FIND_WHERE ::= FIND_ORDER  WHERE  IF_EXPR
               ::= FIND_ORDER
    FIND_ORDER ::= FIND_USING
               ::= FIND_USING  ORDER_GROUP
    FIND_USING ::= FIND_TABLE  USING_INDEX  STD_ID
               ::= FIND_TABLE  USING_INDEX  HINT_SYM  STD_ID
               ::= FIND_TABLE
    FIND_TABLE ::= SELECT_SYM  SELECTOPT  CROSSCOMPANY_CLAUSE  VALIDTIMESTATE_CLAUSE  TABLE
      ::= DELETE_SYM  SELECTOPT  CROSSCOMPANY_CLAUSE  VALIDTIMESTATE_CLAUSE  TABLE
    TABLE ::= FLD_LIST  OPT_FROM
    FLD_LIST ::= MULT_SYM
             ::= FIELD_LIST
    FIELD_LIST ::= FIELD_SPEC
               ::= FIELD_LIST  LIST_SEP_SYM  FIELD_SPEC
    FIELD_SPEC ::= STD_ID  INDEX
               ::= SUM_ELEM
    OPT_FROM ::= FROM_SYM  STD_ID
             ::= 
    SETFIELDSMODE ::= 
    UPDATE_STMT ::= UPDATETABLE  SET_SYM  SETFIELDSMODE  FIELDASSIGNMENTS  OPT_WHERE  JOIN_LIST  SEMICOLON_SYM
    UPDATETABLE ::= UPDATE_SYM  SELECTOPT  CROSSCOMPANY_CLAUSE  STD_ID
    OPT_WHERE ::= WHERE  IF_EXPR
              ::= 
    FIELDASSIGNMENTS ::= FIELDASSIGNMENTS  LIST_SEP_SYM  FIELDASSIGNMENT
                     ::= FIELDASSIGNMENT
    FIELDASSIGNMENT ::= STD_ID  INDEX  ASG_SYM  IF_EXPR
    INSERT_PART ::= INSERT_SYM  CROSSCOMPANY_CLAUSE  INSERT_NAME  LEFT_PAR_SYM  INSERTFIELDLIST  RGHT_PAR_SYM
    INSERT_NAME ::= STD_ID
    INSERT_STMT ::= INSERT_PART  FIND_JOIN  SEMICOLON_SYM
    INSERTFIELDLIST ::= INSERTFIELD
                    ::= INSERTFIELDLIST  LIST_SEP_SYM  INSERTFIELD
    INSERTFIELD ::= STD_ID  INDEX
    PRINT_STMT ::= PRINT_CLAUSE  AT_CLAUSE  SEMICOLON_SYM
    PRINT_CLAUSE ::= PRINT  IF_EXPR  EXPR_LIST
    PRINT ::= PRINT_SYM
    AT_CLAUSE ::= AT_SYM  IF_EXPR  LIST_SEP_SYM  IF_EXPR
              ::= 
    WINDOW_STMT ::= WINDOW_SYM  IF_EXPR  LIST_SEP_SYM  IF_EXPR  AT_CLAUSE  SEMICOLON_SYM
    IF_STMT ::= ELSE_STMT
            ::= IF_CONDS
    IF_CONDS ::= IF_COND  STATEMENT
    IF_COND ::= IF_SYM  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
    ELSE_STMT ::= ELSE  STATEMENT
    ELSE ::= IF_CONDS  ELSE_SYM
    SWITCH_STMT ::= CASE_LIST  RIGHTBR_SYM
    CASE_LIST ::= SWITCH_SYM  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM  LEFTBR_SYM
              ::= CASE_TESTS  STMTLIST
    CASE_TESTS ::= CASE_HEADER  COLON_SYM
               ::= CASE_LIST  DEFAULT_SYM  COLON_SYM
    CASE_HEADER ::= CASE  IF_EXPR
                ::= CASEALT  IF_EXPR
    CASE ::= CASE_LIST  CASE_SYM
    CASEALT ::= CASE_HEADER  LIST_SEP_SYM
    EXPR_STMT ::= ASG_STMT  SEMICOLON_SYM
              ::= FUNCTION  SEMICOLON_SYM
              ::= INTRINSICS  SEMICOLON_SYM
              ::= EVAL  SEMICOLON_SYM
    PAUSE_STMT ::= PAUSE_SYM  SEMICOLON_SYM
    BP_CLAUSE ::= BP_SYM  SEMICOLON_SYM
    BREAK_STMT ::= BREAK_SYM  SEMICOLON_SYM
    CONTINUE_STMT ::= CONTINUE_SYM  SEMICOLON_SYM
    RETURN_CLAUSE ::= RETURN_SYM  SEMICOLON_SYM
                  ::= RETURN_SYM  IF_EXPR  SEMICOLON_SYM
    TTS_STMT ::= TTSABORT_SYM  SEMICOLON_SYM
             ::= TTSBEGIN_SYM  SEMICOLON_SYM
             ::= TTSEND_SYM  SEMICOLON_SYM
    FLUSH_STMT ::= FLUSH  ID_LIST  SEMICOLON_SYM
    FLUSH ::= FLUSH_SYM
    TBLLOCK_STMT ::= TABLELOCK  ID_LIST  SEMICOLON_SYM
    TABLELOCK ::= TABLELOCK_SYM
    ID_LIST ::= STD_ID
            ::= ID_LIST  LIST_SEP_SYM  STD_ID
    MOVE_REC_STMT ::= NEXT_SYM  TABLE  SEMICOLON_SYM
    CHANGE_STMT ::= CHANGE_HEADER  STATEMENT
    CHANGE_HEADER ::= CHANGE  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM
    CHANGE ::= CHANGECOMP_SYM
           ::= CHANGESITE_SYM
    UNCHECKED_STMT ::= UNCHECKED_HEADER  STATEMENT
    UNCHECKED_HEADER ::= UNCHECKED_SYM  LEFT_PAR_SYM  IF_EXPR  RGHT_PAR_SYM

Recursos adicionais

Referência da linguagem X++