I posted on this previously and documented a MS DOS command
to find errors in my XU2 scripts (here).The xu2 scripts are invoked during stage 4 of the Noetix View Administrator's regeneration process. This is right after SQL Loader is
finished loading seeded template table records. The errors that are
thrown during this part of the regeneration are typically associated
with constraint errors. If you examine the constraints that are
associated with a given Noetix template table, one can see that they are
quite robustly written to help make sure that you do not add a record
in an erroneous way.
One can typically examine the root cause of these errors if one looks at this query:
SELECT *
FROM DBA_CONS_COLUMNS
WHERE 1 =1
AND OWNER = 'NOETIX_SYS'
AND TABLE_NAME = 'N_VIEW_COLUMN_TEMPLATES';
Today I wanted to document another way to find these errors. More than a year ago, I noticed that Microsoft had an updated shell, called PowerShell, and so I placed it on my laptop. Today, I will go through how one can invoke a command (well, actually a cmdlet) to find Oracle thrown errors that occur while the Noetix View Administrator is in stage 4 of a regeneration.
First, a little background information on PowerShell.
One can typically examine the root cause of these errors if one looks at this query:
SELECT *
FROM DBA_CONS_COLUMNS
WHERE 1 =1
AND OWNER = 'NOETIX_SYS'
AND TABLE_NAME = 'N_VIEW_COLUMN_TEMPLATES';
Today I wanted to document another way to find these errors. More than a year ago, I noticed that Microsoft had an updated shell, called PowerShell, and so I placed it on my laptop. Today, I will go through how one can invoke a command (well, actually a cmdlet) to find Oracle thrown errors that occur while the Noetix View Administrator is in stage 4 of a regeneration.
First, a little background information on PowerShell.
It is rather nice because it is object oriented and its
piping is similar to Unix/Linux.
Specifically, the piping can return objects and then the next cmdlet
(that is what they call their commands in this new shell) manipulates it, one
object at a time through the pipe kind of like an embedded function. This is very dissimilar to MS DOS where it
completes the first command and then pushes the result set to the next command.
I noticed that it was quite different from MS Dos and I
looked at it for a little bit and talked to some peers. My peers heard of it, but thought that it
really had gained little traction in terms of use by administrators and other IT
staff.
For one reason or another, I stumbled on the blog, http://blogs.technet.com/b/heyscriptingguy/,
and it really made me reconsider using this shell environment in lieu of MS DOS
where practical.
The two main commands one needs to know in this shell are as
follows:
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Get-Alias MS_DOS_Command
Notes on this: This
cmdlet just helps you translate your MS DOS command to the PowerShell cmdlet.
Here is an example:
PS C:\WINDOWS\system32\windowspowershell\v1.0> Get-Alias
cd
This returns:
CommandType
Name
Definition
-----------
----
----------
Alias
cd
Set-Location
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
The other command that is necessary is the following:
Get-Help cmdlet
Here is an example
PS C:\WINDOWS\system32\windowspowershell\v1.0> Get-Help
Get-ChildItem
NAME
Get-ChildItem
SYNOPSIS
Gets the items and
child items in one or more specified locations.
SYNTAX
Get-ChildItem
[[-Path] ] [[-Filter] ] [-Exclude
] [-Force] [-Include ] [-Name] [-Recurse]
[-UseTransaction] []
Get-ChildItem
[-LiteralPath] [[-Filter] ] [-Exclude
] [-Force] [-Include ] [-Name] [-Recurse]
[-UseTransaction] []
DESCRIPTION
The Get-ChildItem
cmdlet gets the items in one or more specified locations. If the item is a
container, it gets the items inside the container, known as child items. You
can use the Recurse parameter to get
items in all child containers.
A location can be
a file system location, such as a directory, or a location exposed by another
provider, such as a registry hive or a certificate store.
RELATED LINKS
Online version:
http://go.microsoft.com/fwlink/?LinkID=113308
about_Providers
Get-Item
Get-Alias
Get-Location
Get-Process
REMARKS
To see the
examples, type: "get-help Get-ChildItem -examples".
For more
information, type: "get-help Get-ChildItem -detailed".
For technical
information, type: "get-help Get-ChildItem -full".
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Anyways, I use this shell as my main shell that I use for
various tasks. Here is my cmdlet to
watch for errors being thrown right before GUI prompt for the APPS password
(which is right after the wnoetxu2.sql script has run):
PS C:\WINDOWS\system32\windowspowershell\v1.0>
Get-ChildItem -Path "\\cmntx02\NoetixViews 6.0.1 -
ERP\Installs\NOETIX_SYS_erpdev" -Filter "*xu2.lst" |
Select-String -pattern "ORA-"
I invoke this script on my laptop and it peruses the files
in the path I have identified. I suppose
you might take a look at this script and think; I will never type a path that
long! Well, if you are not aware, you
can drag a file from MS explorer to your shell environment and Windows will “type
it in” for you.