‎2007 Jan 12 5:57 AM
Hi all,
Data it1_mara <b>like</b> standard table of mara,
Data it1_mara <b>type</b> standard table of mara
what's the diff b/w two statements?
Regards,
Bala.
‎2007 Jan 12 6:02 AM
Hi,
The way you have declared is:
First stmt: is an internal table without a header line,
second stmt : is just a work area.
Regards
Subramanian
‎2007 Jan 12 6:04 AM
Hi Bala,
TYPE - Type is used to tell the system what is the type of data object(variable) you want to create .
LIKE: If there is already a data object declared and you want to declare a similar data object you can just refer to the previous data object using like.
Check this thread.
https://forums.sdn.sap.com/click.jspa?searchID=711746&messageID=2270752
https://forums.sdn.sap.com/click.jspa?searchID=711746&messageID=512214
-Priyanka.
‎2007 Jan 12 6:06 AM
Hi Bala,
LIKE means the datatype of the variable is similar to the referenced variable.
TYPE means it is a predefined data type.
For all practical purposes there are the same. The only additional advantage with types is that you can define your own types(including complex ones) in the data dictionary and reuse them across various programs.
But within a program if two variables are defined one using LIKE and another using TYPE, both referring to the same field, then there is no difference.
If I include a type pool within a program, then I can define my variables only using TYPE to refer to any type defined in that pool. I cannot use LIKE in this scenario. Also, if I want to use native types like C, N, etc, I cannot use LIKE there either. I can use LIKE ABC only if ABC is in the database or if ABC is defined previously in the same program.
I can use TYPE ABC, if ABC is defined in database as a TYPE and included in the program with the statement TYPE-POOLS. I can use it, if it is the native types. I can use it, if it is already defined in the dictionary as a structure/table or structure/table field, or even if it is defined as a data element or a domain. So I can declare a variable V_BUKRS TYPE BUKRS, but I cannot define a variable V_BUKRS LIKE BUKRS.
But if I intend to use V_BUKRS to store company code, I will prefer to declare it as V_BUKRS LIKE T001-BUKRS, only because if tomorrow for some reason, the definition of T001-BUKRS changes to a data element for example, BUKRS_N(say DEC 4) instead of the data element BUKRS(CHAR 4) that it refers to now, I don't have to change my programs because I am referring to the table field and inheriting its properties. Whereas, had I declared my V_BUKRS TYPE BUKRS and the table now changed to BUKRS_N, I will be forced to change my program as there will be a type incompatibility.
2. try this code (just copy paste)
report abc.
types : char50(50) type c.
*----
type.
data : d1 type c, "--- native
d2 type n, "--- native
d25 type char50 , "----
User defined data type
d3 type bukrs, "---- data element / domain
d4 type persno, "---- data element / domain
d5 type t001, "---- table
d99 type c
.
data :
*l1 like c "----
Not Allowed
*l2 like n "----
Not Allowed
*l25 like char50 , "----
User defined data type
*l3 like bukrs "----
Not Allowed
*l4 like persno, "----
Not Allowed
l5 like t001 , "---- table
l99 like pa0001
All the Best!
Reward Points if Useful!
All the Best!
Gokul