Documentos de Académico
Documentos de Profesional
Documentos de Cultura
Agenda
• Introducción
• Historia
• Componentes
• Elementos de la arquitectura MOCA
• MOCA Registry
– Windows
– Non-Windows
• Descripción del Ambiente
• Elementos de un Comando
• Creación de Comandos
– Admón. Comandos de Servidor
– Creación Manual de Archivo de Comando
– Sintaxis Local
– Reemplazo de Variables
– Operadores
• Comandos Útiles
MOCA: Introducción
¿Qué es MOCA?
Application
Application Database
MOCA
Application Database
• Clientes
– Los clientes son aplicaciones cuya principal
responsabilidad es la salida de datos, interactuar con el
usuario e invocar componentes en un servidor.
– Toda la funcionalidad es delegada a los componentes que
existen en el servidor
– Esto permite que las aplicaciones MOCA sean
desarrolladas mucho más rápidamente que una aplicación
cliente que contiene lógica y funcionalidad adicionales.
¿Por qué MOCA?
• Facil de Personalizar
– MOCA ofrece una arquitectura para personalizar
fácilmente una aplicación sin tener que reescribir
numerosas líneas de código.
– Esto hace mucho más fácil añadir o cambiar la
funcionalidad en un producto estándar.
¿Por qué MOCA?
Level Sequence
Usr (User Customizations) 9000
Client: Client:
Client
Receive Truck Inventory
Operations Location Display
Connection Manager
Server
Client: Client:
Client
Receive Truck Inventory
Operations Location Display
Connection Manager
Server
MOCA Registry
Connection Manager
[CONMGR]
port=4500
password=lptrn1
server-timeout=24
initial-servers=5
server-program=
/opt/redprairie/lptrn1/wmp/bin/mocaserver
job-list= EMS_PURGER,SCHAGT-EMS-TBLSPC
task-list= SLOT_SCHD, SL_MSGLOG,
SL_R_ASYNC_EVT, SL_P_ASYNC_EVT, SL_INAD_0,
SL_INAD_3, SL_INAD_4, SL_IFD_EVT,
SL_IFDG_0, SL_IFDG_1, EMS_SPOOLER
Tasks
[SL_IFD_GEN_LM_1]
PROGRAM=slIFDGen
ARGUMENTS=-I2 -S LM -i 3600 -s -n -1 -Z
RESPAWN=N
AUTOSTART=N
START-IN=$LESDIR/log
LOGFILE=$LESDIR/log/slIFDGenlm.log
[SL_INAD_0]
PROGRAM=slInAdapter
ARGUMENTS=-I1 -c -i10 -N -s -Z
RESPAWN=N
AUTOSTART=N
START-IN=$LESDIR/log
LOGFILE=$LESDIR/log/slInAdapter.log
MOCA: Elementos de un comando.
Elementos de un comando
• Nomenclatura
• Argumentos
• Datos Publicados
• Triggers
Nomenclatura
Comandos de Servidor
Admón de Comandos de Servidor
<![CDATA[ Descripción
[select *
Tipo de Sintaxis
from rfid_tag_sernum
where @+reference]
]]>
</local-syntax>
<![CDATA[
Comentarios
This command lists existing RFID serial numbers.
Descripción
]]>
</remarks> Ejemplos
<exception value="eOK">
</documentation>
</command>
Creando Comandos – Archivos *.MCMD
<command>
<type>Local Syntax</type>
<local-syntax>
> El nombre del comando es lo que es referenciado o
<![CDATA[ llamado por el sistema DLx® para ejecutar el código que
[select *
contiene
from rfid_tag_sernum > El nombre es escrito como una descripción en ingles.
where @+reference]
> Los nombres son escritos en un formato de
]]>
</local-syntax> <verbo><nombre>.
<documentation>
<remarks>
<![CDATA[
]]>
</remarks>
<exception value="eOK">
</exception>
</documentation>
</command>
Creando Comandos – Archivos *.MCMD
<command>
</local-syntax>
<documentation>
<remarks>
<![CDATA[
]]>
</remarks>
<exception value="eOK">
</exception>
</documentation>
</command>
Creando Comandos – Archivos *.MCMD
<command>
<type>Local Syntax</type>
• Tipo de comando
<local-syntax>
<![CDATA[
> Determina que tipo de sintaxis de comando será ejecutada.
[select * > Los tipos incluyen:
from rfid_tag_sernum
• Funciones C
where @+reference]
• Funciones C simples
]]>
</local-syntax>
• Métodos COM
• Local Syntax
<documentation>
<remarks>
<![CDATA[
]]>
</remarks>
<exception value="eOK">
</exception>
</documentation>
</command>
Creando Comandos – Archivos *.MCMD
<command>
<type>Local Syntax</type>
<local-syntax>
<![CDATA[
[select *
from rfid_tag_sernum
• Sintaxis del Comando
where @+reference] > Local syntax puede ejecutar:
]]>
• Sentencias SQL
</local-syntax>
• Sintaxis MOCA
• Otros comandos MOCA
<documentation>
<remarks>
<![CDATA[
]]>
</remarks>
<exception value="eOK">
</exception>
</documentation>
</command>
MOCA: Reemplazo de Variables
Reemplazo de variables – @variable
@variable
@variable
[SELECT *
FROM ord
SELECT *
FROM ord
@variable
[SELECT *
FROM ord
SELECT *
FROM ord
@+variable
[SELECT *
FROM ord
WHERE @+ordnum
AND @+wh_id]
SELECT *
FROM ord
@+variable
[SELECT *
FROM ord
WHERE @+ordnum
AND @+wh_id]
SELECT *
FROM ord
AND 1 = 1
Reemplazo de variables – @%variable
@%variable
@%variable
[SELECT *
FROM ord
WHERE @%ordnum
AND @%wh_id]
SELECT *
FROM ord
@%variable
[SELECT *
FROM ord
WHERE @%ordnum
AND @%wh_id]
SELECT *
FROM ord
AND 1 = 1
@%variable
@%variable
[SELECT *
FROM ord
WHERE @%ordnum
AND @%wh_id]
SELECT *
FROM ord
@@Variable
@@variable
[SELECT *
FROM users_view
WHERE usr_id = @@usr_id]
SELECT *
FROM users_view
@?
@?
[SELECT *
FROM ord_dtl] catch(@?)
|
publish data
where err_code = @?
Publish data
@!
@!
[SELECT *
FROM ord_dtl] catch(@?)
|
publish data
where err_sts = @!
Publish data
[sql statement]
Sentencias SQL
[SELECT ord_num,
ord_typ_txt,
line_num,
ord_qty
FROM ord
WHERE ord_num = ‘TESTORD01’
AND ord_typ_txt = ‘CUST’]
Separadores de Comandos
command; command
Comando Pipe
command | command
Comando Pipe
Publish data
where ord_num = ‘TESTORD01’
and ord_typ_txt = ‘CUST’
| SELECT *
FROM ord_dtl
[SELECT *
WHERE ord_num = ‘TESTORD01’
FROM ord_dtl AND ord_typ_txt = ‘CUST’
WHERE @+ord_num
AND @+ord_typ_txt]
Concatenación de comandos
[select *
from table] >> record_set
|
if (rowcount (@record_set) >= 250)
{
[select *
from table
where rownum <= 250]
}
else
{
[select *
from table]
}
Condicionales
If (expr)
{
command1
}
else
{
command2
}
Condicionales
if (@full_ship_flg = 1)
{
[SELECT *
FROM ord_dtl
WHERE ord_num = @+ord_typ_txt
AND ord_qty + adj_qty = shp_qty]
}
else
{
[SELECT *
FROM ord_dtl
WHERE ord_num = @+ord_typ_txt]
}
Excepciones
remote(system) command
• Operadores
+ Suma
- Resta
* Multiplicación
/ División
% Módulo
• Operadores de cadena de caracteres
• Operadores lógicos
• Operadores de comparación
= Igualdad
!= <> Inigualdad
> >= Mayor que,
Mayor o igual a.
< <= Menor que, Menor o igual a
[NOT] LIKE Coincide [No coincide]
con un patrón específico.
IS[NOT] NULL [no] nulo.
MOCA: Funciones
Funciones – decode()
• Para evaluar esta expresión MOCA compara expr con cada valor
de búsqueda uno por uno.
• Si expr es igual a una búsqueda, MOCA regresa el resultado
correspondiente.
• Si ninguna coincidencia es encontrada, MOCA regresa default,
o, si default es ignorado, regresa un valor nulo.
Funciones – nvl()
nvl(expr, if-null-expr)
list orders
where act_dt >= nvl(@beg_act_dt,act_dt)
and act_dt <= nvl(@end_act_dt,act_dt)
MOCA: Wrappers
Wrappers
if (@special_pack_list = 'Y')
produce special packing list
else
^produce packing list
MOCA: Comando Útiles
Comandos Útiles
to_char
– Esta función MOCA es usada para convertir fechas a caracteres.
to_date
– Esta función MOCA es usada para convertir cadenas a fechas.
to_number
– Esta función MOCA es usada para convertir cadenas de
caracteres a números.
Comandos Útiles
[select sysdate dt
from dual] |
publish data where x = to_char(@dt,
'YYYYMMDD')
send email
• Este comando envía un e-mail al destinatario dado.
• Si un documento es dado, su contenido es enviado en el e-
mail.
• Si uno o más archivos adjuntos son dados, son enviados en el
e-mail.
put ftp
• Este comando envía un archivo a otro host vía ftp.