Jump to content
Claris Engage 2025 - March 25-26 Austin Texas ×
The Claris Museum: The Vault of FileMaker Antiquities at Claris Engage 2025! ×

This topic is 5573 days old. Please don't post here. Open a new topic instead.

Recommended Posts

Posted

I have what I thought was a simple scripted find to implement. But after trying about nine different combinations of Find/Omit/Constrain -- and then reading 100 topics here -- I've come up empty handed. Here's a summary:

I pass the script a parameter with the Test Type request. The script just needs to locate all of those (Table::TestType = $$Type) entries that haven't been marked Result=X.

Table::Result field is a text field that normally holds either a word or a number -- or "X" if the test is invalid.

If I find the Test Type first, I can't constrain for "result not equal to X" because that's not a comparison choice.

If I find Result=X and then show omitted only, I can't constrain for TestType=$$Type, because variables aren't supported.

Am I missing something simple? I hope so.

Thanks for any help.

Posted

It sounds like you might be trying to put your logic into the Perform Find script step, which is not too flexible. It does not take script parameters or variables, only operators and literal text strings. It's generally easier to maintain your scripts if you construct scripted finds like this:

Enter Find  (do not specify)

 Set Field( TestType ; $$Type ) 

 Perform Find (do not specify)


(I'm not sure what the global variable is doing here: are you setting that to the script parameter that you mentioned?) 



You could then do a second Find and constrain it, or you could add a Find request to the original search like so: 




Enter Find (do not specify)

 Set Field( TestType ; $$Type ) 

 New Record/Request

 Set Field( Result ; "X" ) 

 Omit

 Perform Find (do not specify)

Maybe the Omit step was the missing puzzle piece?

Posted

Fitch, many thanks.

Actually, it was not the omit I was missing, it was the New Record/Request. That's a technique I hadn't seen before. Maybe it has a technical name, but I would call it "stacked finds". Using them this way isn't what I would call intuitive, but it has one overriding quality: it works!

For the benefit of others, here's the sequence of steps I've implemented (yes, $$Type contains the script parameter ... the requested test type):


Enter Find Mode[]

Set Field [Table::TestType; $$Type]

New Record/Request

Set Field [Table::Result; "X"]

Omit Record

Perform Find[]

Posted

I'll agree that it's not intuitive, but "multiple find requests" have been around since FMP 2.0 in the early 1990s.

Posted

Thank you for mentioning that. Now that I know what they're called, I'll read up on them. I did finally locate a reference in FMP help to "Finding records except those matching criteria" -- but it had no script examples.

Posted

.. it was the New Record/Request. That's a technique I hadn't seen before. Maybe it has a technical name, but I would call it "stacked finds".

It already has a "technical name", it is called an OR find.

Lee

This topic is 5573 days old. Please don't post here. Open a new topic instead.

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.