PD Control tables in workflow
Hi Workflow guru's,
I m new in workflow, i've a problem in customizing the workflow.
when i do automatic customizing, there is an error which is <b>'ENTERIES MISSING IN PD CONTROL TABLES'.</b>
Anybody has solution?
would i've to enter something in SOBJ cluster?
it's urgent.
your help 'll be highly appreciated and rewarded:)
Sal.
Hi Salahuddin,
This is a standard error, but there is also a standard solution: Run program RHSOBJCH and mark the missing entries to be inserted in the control tables. You will also find SAP notes (e.g. 134311) about this.
Regards,
John.
Similar Messages
-
Automatic Workflow Customizing - Check entries from HR Control Tables
Hi All
I am preparing the R/3 system before a ESS MSS implementation.
When I execute Transaction SWU3 I have a few red cross marks. Few of those are because the Gateway addresses are not specified and Webserver path is not specified.
The bit that I am worried about is
Check entries from HR Control Tables
SAP Documentation says
*To solve problems of this type, use the report RHTTCP77.
If there are errors regarding the transport objects PDST or PDWS, the relevant entries are not maintained in table SOBJ. You can use the report RHSOBJCH to rectify this later.*
I want to know the implications of correcting the entries with the report RHSOBJCH. Will it affect the configuration which has been done on the system for the business processes?
When I fire off
Consistency Check for Event Linkages
there are a whole bunch of errors which are thrown. Can I Activate/Deactivate the linkages
Wanted to make sure that there will be no knock on effects. Do I need to consider something else regarding these issues?
Thanks in advanceHi Sriram,
I have also faced a similar issue.
Running the mentioned reports did not cause any problem for my case.
Only after running the reports and generating the task was I able to remove the red cross mark.
Regards,
Saumya -
Alignment in dynamic table in workflow mail
I have a workflow with a task of sending mail to SAP inbox. The body of the mail should display a table with a structure that is dynamically determined at run time. The workflow is triggered from a report in which a dynamic table is first created, filled with data. Then, before the event is raised, each line of the table is converted to ABAPTXT255 and then the table of string is passed to the workflow. The content of the original table is then shown as a table of strings.
The problem is that, because I convert the content to string before passing the table to workflow, Ive lost control over the alignment of columns I originally had before the conversion, and the font used in SAP inbox doesnt help either. Hence, the table appears in the mail as having no alignment at all.
My dilemma is that, I cannot think of another way of passing a table with dynamic structure to workflow, except to convert everything to string first. But, then I lost control over the alignment.
Has anyone come across anything similar to this before? Any comments or suggestions?
Thanks in advance.Can u send the code how u r doing this?
Also let me know that when u see the contents in the inbox, from menu path Settings-> text in non-proportional font.
Are your contents aligned when u do the above setting?
Regds
Samant -
How to make a control table with the same number of rows of its itab
I'm creating a control table, but it always have the maximum number of lines possible.
How can I make it so that it has only the same number of rows of it's internal table?solved partialy with this:
MODULE locka_lin OUTPUT.
DATA: lin TYPE i.
DESCRIBE TABLE t_obj LINES lin.
table_con-lines = lin.
ENDMODULE. " OUTPUT
but it still doent work when lin = 0
any simple way to solve it on that case?
Edited by: RagnaRock on May 5, 2010 6:00 PM -
How to remove the default members of a dimension from the control table?
Hi all,
I am new to hyperion FDM 11.1.1.2.0.0 .
When I navigate to Metadata>Control Tables and try to delete the default memmbers
for the dimension like category and period i got the following error.
Error: Period( 8/31/2009 ) is an active Global or Local Period and cannot be deleted.
Then again i unchecked active checkbox for that dimension from Hyperion Essbase Integration Setup of Workbench Client.
After doing that i got the following error
Error: Unable to retrieve target System Data.
Can anyone tell me how to remove the default members of a dimension from the control table?
ThanksCreate a new record for the table.
Go change the POV to the new record.
Return to the control table and delete the default record. -
FI- Line Item Extraction- BWOM_SETTINGS- Control Table Entries
Gurus,
I am working on FI- Line item extraction in the sand box. I have all my DS's in Nodes not connected. I transfereed the application component hierarchy in SBIW. Now I went to check on the basic settings before activating the DS's for FI line item- in the control table, BWOM_SETTINGS, I could not find any parameters- lowlimit, safety, there are only 2 parameters-OBJSELSICO-'X', and OBLIGODELT- ' '.
We can enter the param values manually and transfer global settings to BI. Could we do the same for fields too. Could we enter them manually?
Why does my control table doesn't have the fields for std line item extraction- lowlim, safety, timbor, overla. My plug- ins are good. I have all the plug ins. I can see them in dev box but not sand box. Why?Hi Ram,
I think Time stamp will set in this table when we run first delta or init in BI system.
So activate the data source and replicate the same BI system. develop data model for this data source and run the init for this data source.
then you will be able to find time stamp for this data source.
FI-Line item data-Delta.
0FI_GL_4 delta functionality?????
Regards,
Venkatesh -
Show zeroes in a control table (Module Pool)
Hi all.
I need showing zeroes in a control table.
I declared fields type char in the control table (and in the internal table) and it shows zeroes, but I need declare it type QUAN (control table and internal table).
With all types (except CHAR) I couldn't show de zeroes there.
If anybody can help me, I Will be grateful!Hi,
In your PBO, inside LOOP ENDLOOP, have a module for screen modifications and for the last row that has totals, you set screen-invisible = 1 inside LOOP AT SCREEN. ENDLOOP.
For example,
If your screen has following PBO Logic,
MODULE ...
MODULE ...
LOOP ...
****New module here for screen modification if does not ****exist already.
MODULE modify_screen.
ENDLOOP.
and then in MODULE modify_screen.
MODULE modify_screen.
****Basically check MATNR EQ 'TOTAL' or some thing like ****that
IF <your condition for totals line>.
LOOP AT SCREEN.
****Note instead of screen-name, you can assign a screen ****group to all columns w/o totals and then use
****SCREEN-GROUP1 EQ <your grp> logic
IF screen-name EQ <your column name w/o totals>.
screen-invisible = 1.
MODIFY SCREEN.
ENDIF.
ENDLOOP.
ENDIF.
ENDMODULE.
On another note, since you are already disabling this fields in the last row, you have all the screen modification logic already I guess, so just add SCREEN-INVISIBLE = 1 for all fields w/o totals..
Hope this helps..
Sri
Message was edited by: Srikanth Pinnamaneni -
Cannot see data in SAP.Web.UI.Controls.Table
Hi,I have created a portal project and dragged a sap table into the design area. then i call a webservice and bind the resulting dataset to the table. the dataset seems to bind, since i can see there are the right number of pages in the table, but i cannot see any of the data. all the rows are blank. am i treating the ascx file correctly? i deploy and browse to test it.
this is the code in the aspx:
<%@ Register TagPrefix="sap" Namespace="SAP.Web.UI.Controls" Assembly="SAP.Web, Version=1.2.0.0, Culture=neutral, PublicKeyToken=50436dca5c7f7d23" %>
<%@ Control language="vb" Codebehind="PortalComponent1.ascx.vb" AutoEventWireup="false" Inherits="pdkdemo2.PortalComponent1" targetSchema="http://schemas.microsoft.com/intellisense/ie5" %>
<!%@ PortalComponent name="PortalComponent1" %>
<LINK href="C:\Program Files\SAP\SAP Portal Development Kit for .NET 1.0\Controls\ur\ur_design.css"
type="text/css" rel="stylesheet">
<body class="prtlBody">
<sap:Table id="Table1" runat="server">
<sap:Caption Text="Table" ID="Caption2"></sap:Caption>
<sap:TableRow ID="Table1_ItemTemplate">
<sap:TableCell ID="TableCell4" Title="Column1">
<sap:TextView ID="TextView4"></sap:TextView>
</sap:TableCell>
<sap:TableCell ID="TableCell5" Title="Column2">
<sap:TextView ID="TextView5"></sap:TextView>
</sap:TableCell>
<sap:TableCell ID="TableCell6" Title="Column3">
<sap:TextView ID="TextView6"></sap:TextView>
</sap:TableCell>
</sap:TableRow>
</sap:Table>
</body>
and this is the code behind:
Imports System
Imports System.Collections
Imports System.ComponentModel
Imports System.Data
Imports System.Drawing
Imports System.Web
Imports System.Web.UI
Imports SAP.Portal.Web.UI
Imports SAP.UI
Imports SAP.Web.UI.Controls
Public class PortalComponent1
Inherits SAP.Portal.Web.UI.PortalComponent
Protected WithEvents Table1 As SAP.Web.UI.Controls.Table
Protected WithEvents Caption1 As SAP.Web.UI.Controls.Caption
Protected WithEvents Table1_ItemTemplate As SAP.Web.UI.Controls.TableRow
Protected WithEvents TableCell1 As SAP.Web.UI.Controls.TableCell
Protected WithEvents TextView1 As SAP.Web.UI.Controls.TextView
Protected WithEvents TableCell2 As SAP.Web.UI.Controls.TableCell
Protected WithEvents TextView2 As SAP.Web.UI.Controls.TextView
Protected WithEvents TableCell3 As SAP.Web.UI.Controls.TableCell
Protected WithEvents Caption2 As SAP.Web.UI.Controls.Caption
Protected WithEvents TableCell4 As SAP.Web.UI.Controls.TableCell
Protected WithEvents TextView4 As SAP.Web.UI.Controls.TextView
Protected WithEvents TableCell5 As SAP.Web.UI.Controls.TableCell
Protected WithEvents TextView5 As SAP.Web.UI.Controls.TextView
Protected WithEvents TableCell6 As SAP.Web.UI.Controls.TableCell
Protected WithEvents TextView6 As SAP.Web.UI.Controls.TextView
Protected WithEvents TextView3 As SAP.Web.UI.Controls.TextView
Private Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles MyBase.Load
Dim proxy As New secblrnd.Service1
Dim ds As DataSet
ds = proxy.GetData("U020_EQUIP", "ALL", "NO", 0, "MOODLET1", "MOODLET1")
Table1.DataSource = ds
Table1.DataBind()
End Sub
#Region "Web Form Designer generated code"
Protected Overrides Sub OnInit(ByVal e As EventArgs)
' CODEGEN: This call is required by the ASP.NET Web Form Designer.
InitializeComponent()
MyBase.OnInit(e)
End Sub
' Required method for Designer support - do not modify
' the contents of this method with the code editor.
Private Sub InitializeComponent()
End Sub
#End Region
End class
any assistance would be highly appreciated.Hi,
The problem is that the SAP table doesn't support this kind of "dynamic binding" at the moment. The SAP table can contain any one of several controls in each cell, and these controls have several possible properties to bind to. So currently you have to "tell" the table what you want to bind to.
You have several options:
1. The easiest option, if you can create a typed dataset in design-time, according to what your webservice returns, then do that... and then put an instance of it on your portal component, and bind your table to that typed dataset (using the designer property grid). This should create a default ItemTemplate with all textViews in the cells, and the texts will be bound to the columns.
2. Write code in ItemCreated Event handler of the table. This event will be raised for each row in the DS. There you can tell the cells to get the data from the content. Remember that you'd have to create the cells according to the number of columns and set the content of each cell to be what control you want (like TextView) and then fill the properties of that control.
3. If you know the Data structure, but don't want to or can't create a typed DataSet - First define the columns using the designer (right click the table, select "edit columns"). Then in the event handler (from "2") just set the property "text" of each TextView which is in the content of each cell (use the Cell's property "TableCellContent" to get to the TextView control)
4. Don't use databinding and create the table contents completely manually (See here -
How to modify cells in a table?)
One last thing, here's a link to some more explanations about DataBinding in SAP controls:
https://media.sdn.sap.com/html/submitted_docs/PDK_for_dotNET_10/Programming%20with%20PDK%20for%20.NET/SAP%20NetWeaver%20.NET%20Controls/Data%20Binding/Complex%20Data%20Binding.htm
If you choose a solution and need more help, just ask.
Regards,
Ofer -
Issue with Period Control Table after copying Essbase adapter
Hi Experts,
I'm working on version 11.1.1.3 and have copied the adapters (Essbase, Pull + EPRi) in the work bench so I can add an additional target for the FDM application. However, I have an issue with the import process; it returns an error with the Time & Periods (I guess it's something to do with the Periods category).
I have reimported the Periods Control Table and updated the new application's Target Period & Year (whilst changing the system code in the Application settings to the newl adapter) and still receive the same error message.
Any direction or thoughts would be welcome.
Thanks
MarkThe time periods do not copy. You need to maintain them through the UI or upload them from excel. There is a KM article on this if you need additional detail.
-
Fetch records from ETL Load control tables in BODS
Hi,
Please anyone tell me, how to fetch the records from the ETL Load control tables in BODS.
(E.g) ETL_BATCH, ETL_JOB, ETL_DATAFLOW, ETL_RECON, ETL_ERROR.
These are some ETL load tables..
Thanks,
Ragrds,
Ranjith.Hi Ranjith,
You can ask your administrator for BODS repository login details.
Once you get login details you will get all the tables.
Please check following links :
Data Services Metadata Query Part 1
http://www.dwbiconcepts.com/etl/23-etl-bods/171-data-services-metadata-query-part-2.html
http://www.dwbiconcepts.com/etl/23-etl-bods/171-data-services-metadata-query-part-3.html
I hope this will help.
If you want more info then please let me know.
Thanks,
Swapnil -
What is control tables in abap hr?what is the purpose?
what is control tables in abap hr?what is the purpose?
These are the screen elements used to display tabular data they can be called
as screen tables( like STEP LOOP).To use table control we have to create it on the screen using SCREEN PAINTER(SE51) and declare a control variable of TYPE TABLEVIEW using CONTROLS statement in the ABAP program. We have to use LOOP .. ENDLOOP statement in both PBO and PAI with or without AT int_table parameter. IF AT int_table parameter is not used than we have to place a MODULE call between the LOOP...ENDLOOP statement to fill the screen table rows from the ABAP program in PBO and program our own scrolling functions
using OK_CODE field.
Having a parallel loop(at screen table rows & int table rows) by using parameter
AT int_table makes the ABAP code simple.
A special structure of type CXTAB_CONTROL is used to set/get various
attributes of table control at runtime like CURRENT_LINE ,TOP_LINE.
ABAP declaration
CONTROLS: tab_con TYPE TABLEVIEW USING SCREEN nnnn
Here tab_con is the same name we used in screen for the table control.
This ABAP statement will declare a control variable that will be used to access
the table control , and set it's various attributes like number of fixed columns(tab_con-FIXED_COLS) ,total number of records it will display(tab_con-LINES).It is of type CXTAB_CONTROL and is a deep structure(structure containing structures).
REFRESH CONTROL tab_con FROM SCREEN nnnn
This ABAP statement will initialize the table control on the screen nnnn to its initial values.
PBO processingI
n PBO we have to use the screen LOOP ...ENDLOOP statement , with or without
intenal table.
LOOP WITH CONTROL tab_con.
MODULE fill_tab_con.
ENDLOOP.
Here a module should be called between the loop endloop statement to transfer
data from th ABAP program to the screen table through a structure.This module
should use the CURRENT_LINE attribute of the table control variable to get the
current screen table record index to read the data from the internal table into a work area.
e.g.
READ TABLE int_table INDEX tab_con-CURRENT_LINE
The record read will be placed in the header line of the internal table and will be available to the similarly named screen fields or if these are different it can be written explicitly. e.g.
screen_field_name = int_table-field_name
LOOP AT int_table INTO workarea WITH CONTROL tab_con CURSOR i FROM
n1 TO n2.
ENDLOOP.
Here the module call is not required to fill the screen table.The CURSOR parameter is a integer of type I indicating which absolute internal table line
should be the first to display on the table control .FROM n1 TO n2 can be used
to restrict the starting line and ending line number of the internal table , they are of type SY-TABIX.
In both cases before the LOOP statement a module should be called which
is generally for setting of status ,in which we should fill the LINES attribute
(tab_con-LINES ) of the control with the total number of internal table records,doing this ensures correct and automatic scrolling.
The ABAP statement DESCRIBE TABLE int_table LINES lines can be used
to get the total lines in an int table.
PAI Processing
We have to use LOOP ... ENDLOOP in PAI so that data can transfer fro table control to ABAP program. If we want to write changes to the data we should
call a module between the LOOP ... ENDLOOP. The MODULE call to process user commands (SY-UCOM) should be called after the ENDLOOP statement.
e.g.
PROCESS AFTER INPUT
MODULE mod AT EXIT-COMMAND.
LOOP AT itab_table or LOOP "depending on whether we are using AT int_table
MODULE modify_int_table.
ENDLOOP.
MODULE user_command.
In the MODULE call modify_int_table we can use
MODIFY int_table FROM workarea INDEX tab_con-CURRENT_LINE
or we can use
int_table-field_name = screen_field_name.
Thanks
Please Reward points if helpful.
Edited by: Richa Khosla on Mar 28, 2008 7:38 AM -
In the SD certification material , its said that various masters and control tables are used for processing the sales order .can any one explain me what is control table?
Rgds
RamprasadHi Ram Prasad,
Please find below the information :
1) Screen tables
A table can be created in transaction. These tables, when designed on the screen are called as SCREEN TABLES.
These are of two types.
Table Controls and Step loops
These tables are treated as Loops.
2)Features of Table Controls
Data is displayed in the form of table.
Table control gives user the feeling of an actual table.
You can scroll through the table vertically as well as horizontally.
You can select rows and columns.
You can resize the with of columns.
You can have separator lines between rows and columns.
Automatic resizing of the table when the user resizes the window.
You can update information in the table control and it can be updated in the database table by writing code for it.
3)Steps for creating table control
Declaration of table control in module pool program.
Designing of table controls on the screen.
Passing data to table control in flow logic.
4)Declaration of TC in MPP
syntax:
controls <name of table control> type tableview using screen <escreen no.f>.
5)Designing Table control on screen
Click on Table in Control bar and place it on the screen. You can adjust the length and width of the Table Control.
Name the table control.(same name as given in data declaration).
From dictionary object OR from program fields select the fields and place them in the table control
6)Passing data to table control
Usually transfer of data from program to screen is automatic.
In case of TC, you need to explicitly transfer the data to table control.
ABAP/4 provides Loop statement, which is associated with flow logic to transfer the data.
7)Passing of data contd.
PBO.
Loop at <name of internal table> with control <name of table control> cursor <scroll variable>.
modulecc.
Endloop.
PAI.
Loop at < name of internal table>.Endloop.
8)Scroll variables
Top_line : the row of table where the screen display starts.
Current_line : the row currently being processed inside a loop.
9)Transfer of data from prg to TC.
With eLoop at cf statement, the first row is placed in the header of internal table.
If any module is specified between Loop and End loop, it will be executed. In this module, generally we will be assigning this internal table fields to table control screen fields.
The row in internal table is transferred to the TC as stated in the eLoop atc..f statement.
The system encounters the eEndloopf statement and control is passed back to the next line of internal table.
In the same way all the records of the internal table are passed to the TC.
Find the fallowing some tables avail in SD
SAP SD Tables
VBAK -
(SALES DOC HEADER)
VBAP -
(SALES DOC ITEM)
VBFA -
(SALES DOC FLOW)
VBUK -
(SALES DOC HEAD. STATUS)
VBUP -
(SALES DOC ITEM STATUS)
LIKP -
(DELIVERY HEAD DATA)
LIPS -
(DELIV ITEM DATA)
MSEG -
(MAT DOC SEGMENT)
MKPF -
(MAT.DOC)
VBRK -
(INV HEADER)
VBRP -
(INV ITEM)
BSEG -
(ACC DOC SEGMENT)
BKPF -
(ACC DOC HEADER)
KNA1 --- General Data in Customer Master
KNB1 --- Customer Master (Company Code Data)
KNVV --- Customer Master Sales Data
MARA --- General Material Data
MARC --- Plant Data for Material
MVKE --- Sales Data for Material
Please Reward If Really Helpful,
Thanks and Regards,
Sateesh.Kandula -
Can we pass Internal tables to workflow container?
workflow container has a size limitation, we need to pass any infotype to the workflow container, so can we pass internal tables to workflow container or is there any alternate solution?
Thanks in Advance
HariHi,
Check the <a href="http://help.sap.com/saphelp_nw2004s/helpdata/en/a6/9bac935f2c11d194a40000e82dec10/frameset.htm">Multiline Container Element Definition.</a>
Regards
<i><b>Raja Sekhar</b></i> -
How to create a HTML Table in Workflow Notification ?
Hi,
I have a requirement to display multiple records in a HTML table in Workflow Notification. I have developed the code. In my Notification, I am seeing HTML tags and not a formatted HTML report. Appreciate your help and comments.
The following is what I have done in WF.
1. Define attribute in WF of type Document
2. Define Message in Text Body ( Should i also copy the same thing in HTML Body ??)
The following is my PL/SQL
Variable l_table is defined as varchar2(30000)
-- HTML Table Heading
l_table := '<table><tr><td>Amount</td>
<td>Description</td>
<td>Type 1099</td>
</tr>';
WF_ENGINE.SetItemAttrText(itemtype,
itemkey,
'FRB_DISTRIBUTION_HISTORY',
l_table);
When I get a notification, I get the following sample
<table><tr><td>Amount</td>
<td>Description</td>
<td>Type 1099</td>
<td>Receipt Required Flag</td>
<td>Invoice Id</td>
<td>Invoice Distribution Id</td>
</tr><tr><td>100</td>
<td></td>
<td>MISC7</td>
<td></td>
<td>429684</td>
<td>464834</td>
</tr></table>
I am missing something, Can you please let me know, what am i missing.
KiranHi Matt,
I am working on AP_WFAPPROVAL_PKG (Oracle EBS Invoice Approval Package).
I have defined a Workflow Attribute as Type 'Document' (in Workflow Builder)
In my AP_WFAPPROVAL_PKG Package, I am retrieving my values and returning it to a variable of type varchar2(32000) and seting the WF variable(displayed below).
WF_ENGINE.SetItemAttrText(itemtype,
itemkey,
'FRB_DISTRIBUTION_HISTORY', -- This is my WF Attribute of type 'Document'
l_table);
When I see the notification, i get the format displayed below (I do see the correct values generated, but they appear as tag, and not as a HTML Table Report)
<table><tr><td>Amount</td>
<td>Description</td>
<td>Type 1099</td>
<td>Receipt Required Flag</td>
<td>Invoice Id</td>
<td>Invoice Distribution Id</td>
</tr> <tr><td>60</td>
<td></td>
<td>MISC7</td>
<td></td>
<td>429681</td>
<td>464827</td>
</tr><tr><td>40</td>
<td></td>
<td>MISC7</td>
<td></td>
<td>429681</td>
<td>464828</td>
</tr>
Please advise
Kiran -
Hello All,
Can anyione help me on this. I am not able to understand what control table changes mean. I know what Table controls are but not known to control table.
And they are different from each other.
Can anyone please help me on this.
Regards
anuhi,
WELCOME TO SDN.
*Control Tables
The search indexes for address data, as well as the address data itself, are client-dependent. There can now be other differentiations within a client. These are called "Index pools".
The division reflects the fact that multiple areas of master data are involved, which differ from the business embedding in the SAP System and from the technical implementation.
Two such index pools are currently defined in table TSADRVGRP with a technical key derived from control table TSADRV:
For More details
http://help.sap.com/saphelp_nw04/helpdata/en/81/23a63a8e1d1e49e10000000a11402f/content.htm
Hope this will help you.
Rewrd points, if found helpful
Regards
ANVER
Maybe you are looking for
-
Adding windows to MacBook Pro using boot camp and external USB SuperDrive
I attached my Mac SuperDrive to my MacBook Pro and inserted the disc to add windows. The disc shows up on the screen. Went to boot camp to install and after I chose the percentage of use, press continue, it says no USB drive recognized. What do I
-
New Field Addition in Structure KOMP
*Hi, We have requirement of having Material Description field in the Allowed Field Catalogs in order to fetch the same from Pricing Condition Table. Hence, as a first step, have added the MAKTX field inside the ZStructure inside Main Structure KOMP a
-
I have uninstalled all of Apple software many times and reinstalled 10.4 x64, which works. I tried running the installation as administrator. I gave everyone permission to install. I have turned off my anti-virus software. No success.
-
How to resolve the issue of DS 3.2 and BOE XI 3.1 running on the same PC.
How can I run both Business Objects Enterprise and Data Services Java app on a single PC? I have installed BOXI 3.1 SP3 and Data Services 3.2 on my demo laptop window 7 64-bit enterprise. I am having a issue of DS 3.2 and BOE XI 3.1 running on the
-
Hi All, Any API is there import the following 1.Receivables Transaction Types 2.Receivables System Options 3.Receivables Territories 4.Receipt Sources 5.Receivables Payment Terms