Solved

powerbuilder initialize values

Posted on 2009-04-08
5
424 Views
Last Modified: 2013-12-26
i want to create a function(lets call it initialize)  that will receive a data window as input (dw_imp)  and act as follows

all numeric fields of dw_imp  should be equal to 0
all string fields should be equal to '' (empty)
0
Comment
Question by:basilhs_s
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
5 Comments
 
LVL 18

Accepted Solution

by:
diasroshan earned 500 total points
ID: 24104985
Hi,

Import the attached function.
Save the below contents in notepad and save as f_update_dw.srf
Import it into ur pbl.

From ur code call the function as
f_update_dw(dw_imp)

Cheers,
Rosh
$PBExportHeader$f_update_dw.srf
global type f_update_dw from function_object
end type
 
forward prototypes
global subroutine f_update_dw (datawindow arg_dw)
end prototypes
 
global subroutine f_update_dw (datawindow arg_dw);Long ll_ColCount,ll_ColNo, i
String ls_ColType, ls_ColName
 
For i = 1 to arg_Dw.RowCount()
	ll_ColCount = Long(arg_dw.Describe("Datawindow.Column.Count"))
	For ll_ColNo = 1 To ll_ColCount
		ls_ColType = arg_dw.Describe("#"+String(ll_ColNo)+".ColType")
		ls_ColName = arg_dw.Describe("#"+String(ll_ColNo)+".Name")
		Choose Case Upper(Mid(ls_Coltype,1,4))
			Case "CHAR"
				arg_dw.SetItem ( i, ls_ColName, '' )
			Case "DECI"	
				arg_dw.SetItem ( i, ls_ColName, 0 )
		End Choose	
	Next
Next
end subroutine

Open in new window

0
 
LVL 14

Expert Comment

by:sandeep_patel
ID: 24107466
If you are not creating your datawindow dynamically then it would be better if you give Initial Value while designing the datawindow. Hence for any new row in datawindow will have the default value.

open datawindow > from menu.. view > column specifications > set 'Initial Value'

Regards,
Sandeep
0
 

Author Comment

by:basilhs_s
ID: 24110521
thanks Rosh. i will let you know if it is working
0
 

Author Comment

by:basilhs_s
ID: 24111741
Sandeep thanks for your reply. i know it but in many cases we used datawindows with a lage number of fields and we forget sometimes to give initial values to some of them
0
 

Author Closing Comment

by:basilhs_s
ID: 31568173
i just tried it. it works perfectly.thanks
0

Featured Post

On Demand Webinar: Networking for the Cloud Era

Did you know SD-WANs can improve network connectivity? Check out this webinar to learn how an SD-WAN simplified, one-click tool can help you migrate and manage data in the cloud.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

In our object-oriented world the class is a minimal unit, a brick for constructing our applications. It is an abstraction and we know well how to use it. In well-designed software we are not usually interested in knowing how objects look in memory. …
Programmer's Notepad is, one of the best free text editing tools available, simply because the developers appear to have second-guessed every weird problem or issue a programmer is likely to run into. One of these problems is selecting and deleti…
The viewer will learn how to use NetBeans IDE 8.0 for Windows to connect to a MySQL database. Open Services Panel: Create a new connection using New Connection Wizard: Create a test database called eetutorial: Create a new test tabel called ee…
THe viewer will learn how to use NetBeans IDE 8.0 for Windows to perform CRUD operations on a MySql database.

705 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question