Contact us

Sign up | United States |

Login

remember me

Go to my home page

Stay on current page

Parsing Text / Compare & Contrast




Visitors to VTC.com will be able to view all introductory videos for each training course.
Free Trial Members will gain access to first three chapters for each training course.
Full Access Members have full access to VTC.com�s entire library of video tutorials.


Learn More

Subtitles of the Movie (FileMaker Pro 11: Advanced / Parsing Text / Compare & Contrast)

Let's take a few minutes to compare and contrast the three methods for preserving Found Sets. Those methods would be Serial Numbers, Find Criteria and the Snapshot Link. There are two other methods that we covered: the New Window method and the Table Occurrence method, but they're not really related. They're more for temporary saving of Found Sets whereas these are more for permanent saving of Found Sets and we want to analyze these so you really know when to use one over the other. It all depends on how they react, what kind of things they add to the whole FileMaker solution, you know, what kind of clutter do they put in there; what do they actually do when they preserve that Found Set. There's all kinds of things you have to consider when you're looking at these and we want to analyze those advantages and disadvantages. So let's start with what records are restored. The Serial number method remembers original set of records. It takes a picture and I'd like to use the word snapshot but I don't want to get you confused with the Snapshot Link method. It just remembers that found set, so if you delete a record that's about the only way to change that found set. If you edit a record so it no longer belongs to the original Find Criteria it will still find it with the Serial number method and maybe that's what you want. On the other hand, the Find Criteria method remembers the actual criteria to locate the records, so if you add a record or edit a record it may be included in that found set. It may evolve over time and, again, you may want that and you may not want that. You may only want to remember the exact found set at that moment in time, or you may want to remember what the Find Criteria is. Now, the Snapshot Link method remembers a lot more and much more easily. It remembers the layout, the mode, the sort order, the found set, and the current record, so it remembers a lot more than these techniques. You can actually modify the Serial number technique to remember the current record by storing two values, the multikey plus the single serial number for the current record and do two Go to Related Records; the first one with that option to restore the found set to find the records and then the second Go to Related Record, on a second relationship without that option, but you know, that's kind of a lot more work to do and you may find out that the Snapshot is much easier and, maybe you want to remember the mode, maybe you want to remember the sort, and you really can't do that with any of these techniques here. Let's talk about the Dynamic nature of all these. The Serial number method can't dynamically restore records across multiple tables. It can, but it's not really dynamic. You're going to require at least one layout per table, possibly two layouts per table and a relationship for each table. So that's a lot of clutter that goes into your database. Plus, your script is going to have to be different, too, for each one. You can try to put it all into one script but there's going to have to be different things, you know, go to this layout, go to that layout. It's all kinds of different things that go into that and so it doesn't really lend itself well to being dynamic which is why we didn't program it for more than one table. We only did it for the INVOICE table. On the other hand, the Find Criteria method works fairly effortlessly across all tables with just the existing relationships and layouts. So that's the nice thing about it. It's very easy to make it work on a whole bunch of tables. Now, the Snapshot Link is dynamic without any programming. That's because it stores all that data in an XML file, that small little XML file that gets made, that keeps all that information, so it knows what table automatically that it goes along with, so it's the most dynamic of any of these. So, it's a pretty good solution, but we'll get into some disadvantages of the Snapshot Link for sure. Let's talk about Speed because speed is a very important factor. The Serial number method can be fairly slow with large found sets compared to, when you use the Find Criteria method, which is lightning fast no matter what the found set because it just remembers what the Find Criteria is. It does get more complex if you're using new requests and omits and things like that, you have to add onto the script because right now what we've done only does one request. But it'll do any field on there and that's no problem. That's most finds in general. The Serial number method remembers that found set so you don't have to worry about what was the Find Criteria and how to store that. Now, the Snapshot Link is also very fast no matter what the found set size, so it's definitely a plus on the Snapshot Link side. Let's talk about Complexity. The Serial number method is fairly easy to implement. If you know how to loop through records you can pretty much do it. You know, you do have to know what a Multikey is in a relationship, but you know, a Multikey is something that everybody should know when they're doing relationships in FileMaker. On the other hand, the Find Criteria method requires a complicated calculation. Sure, once you get it done it's done and you can take it and Copy and Paste it from one solution to another, but it is a little more complicated and if you need to modify it in some way it can be more complicated to do that. The Serial numbers method would be much easier to modify. And the Snapshot Link is also fairly easy to implement. It's really, really to make it just a plain old manual Snapshot Link but to put it onto, into the Documents folder or somewhere else, you have to know a little bit about how Variables work and things like that and it's probably on the same level of complexity as Serial numbers. Let's talk about Table Occurrences and Relationships. We're going to go back to this. The Serial number method requires several table occurrences and several relationships depending on how many tables you implement it across and layouts to go along with all those table occurrences relationships. That's a lot of clutter. The Find Criteria method only needs a script. It is a complicated script but all it needs is a script and it's going to be dynamic across everything, so that's nice. Now the Snapshot only needs a script but it does require FileMaker 11. It also saves those. fpsl files on the hard drive, wherever you decide to put them, I put them in the Documents folder and when they're there they're only accessible to the local user and they could be deleted unwittingly, so they could just delete them not even knowing what they are. So, that's a tough thing to decide on which method, but certainly I think the loser in this one is the Serial number method because of all that extra clutter inside the FileMaker database. So, what's the result? Well, the decision really comes down to whether you want the original set of records, that would be with the Serial number method, or to recreate the Find Criteria. Now the Snapshot Link is more like the Serial number method where it remembers the original set of records not the Find Criteria, so you really have to decide which do I want. That's your major pivot point. If you don't really care there's a possibility that you may be able to go one path or the other, but just remember that that's the main difference. One, the Snapshot Link or the Serial number method just remembers that record, that they're both snapshots, or pictures. But the Find Criteria method actually remembers that Find Criteria so it can evolve as the database gets older. But you always want to remember the other methods. There's the New Window method and the Table Occurrence method. They're more temporary but that may be all you need. Rather than going to one of these more complex methods the New Window method is really easy and very quick for temporary saves. If you just need to preserve that found set because you're going to loop through records or do something to, you know, to change that found set, opening up a New Window and then closing it is so easy to do. And the Table Occurrence method is actually pretty easy to do. It does require layouts and relationships, but it's fairly easy to implement and it saves found set for longer than New Window, although you could keep the New Window open. It will save that found set as long as that file's open, that session is available. So, it'll do it for a longer time typically than the New Window. So, both are temporary. You really have to compare all five of these techniques and decide what you're really going to do. And as you get better at this you'll be able to do it, you know, in a second. You'll, you know, think inside your head, OK, you'll go down this fork in the road, down that fork and you'll have two decisions on two different methods - OK, I want to go that - you'll be able to do it very quickly. Just have to have practice with all these methods in order to make those decisions.

Tutorial Information

Course: FileMaker Pro 11: Advanced
Author: John Mark Osborne
SKU: 34140
ISBN: 1-936334-36-4
Release Date: 2010-07-09
Duration: 14.5 hrs / 159 lessons
Work Files: Yes
Captions: No
Compatibility: Vista/XP/2000, OS X, Linux
QuickTime 7, Flash 8

VTC Sign up & Benefits

  • Unlimited Access
  • 81,350 Video Tutorials (14,200 free)
  • Video Available as Flash or QuickTime
  • Over 715 Courses
  • $30 for One Month Access
  • Multi-User Discounts Available

VTC Terms and Conditions

TERMS & CONDITIONS OF USE

BY SUBSCRIBING TO THIS SERVICE, YOU ARE CONSENTING TO BE BOUND BY AND ARE BECOMING A PARTY TO THIS AGREEMENT, THE TERMS AND CONDITIONS OF WHICH SHALL PREVAIL IN GOVERNING YOUR RIGHTS OF USE. BY CLICKING THE "BECOME A MEMBER" BUTTON, THE INDIVIDUAL OR ENTITY LICENSING THE PRODUCT ("YOU") IS CONSENTING TO BE BOUND BY AND IS BECOMING A PARTY TO THIS AGREEMENT. IF LICENSEE DOES NOT AGREE TO ALL OF THE TERMS OF THIS AGREEMENT, THE BUTTON INDICATING "BECOME A MEMBER" MUST NOT BE SELECTED, AND LICENSEE MUST NOT INSTALL OR USE THE SOFTWARE.

1. DEFINITIONS

"VTC" refers to Virtual Training Company, Inc.
"You" refers to the user or subscriber.
"Software" refers to the VTC training content and software.

2. LICENSE: VTC hereby grants to You a worldwide, non-royalty bearing, non-exclusive license to use the Software according to the provisions contained herein and subject to payment of the applicable subscription fees.

3. RESTRICTIONS: You may not do any of the following:

Save the Software to Your hard disk or other storage medium; permit others to use the Software except as specified by addendum; modify, reverse engineer, decompile, or disassemble the Software; make derivative works based on the Software; publish or otherwise disseminate the Software. VTC, Inc., VTC Online University, and the Virtual Training Company site is owned and operated by VTC, Inc. as a corporation of record.
All materials on this site are the property of VTC unless otherwise specified. No material from these pages may be copied, reproduced, republished, downloaded, uploaded, posted, transmitted, or distributed in any way. Modification of the materials or use of the materials for any other purpose is a violation of U.S. copyright law and other proprietary rights. For purposes of this Agreement, the use of any such material on any other web site or networked computer environment is prohibited.

4. FEES: The rights granted under this Agreement are effective only upon payment of the subscription fees, which are strictly non-refundable other than as expressly provided herein. The term "monthly subscription" is defined as any 30 day period. The term "yearly subscription" is defined as one 365 day period. A yearly subscription ends on the same numerical date as it began (example July 28, 2004 to July 28, 2005).

The VTC Online University is access to every VTC training tutorial in our library. You pay a flat fee for access to these titles. You are billed according to your renewal selection below, and can renew monthly, yearly, or in any other increment offered. If you choose to be billed monthly, you will be billed every 30 days for the subscription until you request the subscription be cancelled. Our terms of service state that you must cancel a monthly subscription at least two business days before your renewal date. These two days give us enough time to ensure that you will not be charged again.

5. LIMITED WARRANTY: VTC warrants that the Software, if operated as directed, will substantially achieve the functionality described. VTC does not warrant, however, that Your use of the Software will be uninterrupted or that the operation of the Software will be error-free or secure. In addition, the security mechanisms implemented by the Software have inherent limitations, and You must determine that the Software sufficiently meets Your requirements. VTC also warrants that the media containing the Software, if provided by VTC, is free from defects in material from the date You acquired the Software. VTC's sole liability for any breach of this warranty shall be, in VTC's sole discretion: (i) to replace Your defective media or Software; or (ii) to advise You how to achieve substantially the same functionality with the Software as described; or (iii) if the above remedies are impracticable, to refund the subscription fee You paid for the Software. Only if You inform VTC of Your problem with the Software during the applicable subscription period will VTC be obligated to honor this warranty. VTC will use reasonable commercial efforts to repair, replace, advise, or refund pursuant to the foregoing warranty within thirty (30) days of being so notified. If any modifications are made to the Software by You during the warranty period; if the medium is subjected to accident, abuse, or improper use; or if You violate the terms of this Agreement, then this warranty shall immediately terminate. This warranty shall not apply if the Software is used on or in conjunction with hardware or software other than the unmodified version of hardware and software with which the Software was designed to be used as described.

THIS IS A LIMITED WARRANTY, AND IT IS THE ONLY WARRANTY MADE BY VTC OR ITS SUPPLIERS. VTC MAKES NO OTHER WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT OF THIRD PARTIES' RIGHTS. YOU MAY HAVE OTHER STATUTORY RIGHTS. HOWEVER, TO THE FULL EXTENT PERMITTED BY LAW, THE DURATION OF STATUTORILY REQUIRED WARRANTIES, IF ANY, SHALL BE LIMITED TO THE ABOVE LIMITED WARRANTY PERIOD. MOREOVER, IN NO EVENT WILL WARRANTIES PROVIDED BY LAW, IF ANY, APPLY UNLESS THEY ARE REQUIRED TO APPLY BY STATUTE NOTWITHSTANDING THEIR EXCLUSION BY CONTRACT. NO DEALER, AGENT, OR EMPLOYEE OF VTC IS AUTHORIZED TO MAKE ANY MODIFICATIONS, EXTENSIONS, OR ADDITIONS TO THIS LIMITED WARRANTY.

6. PROPRIETARY RIGHTS: VTC reserves all proprietary rights in and to the Software, is protected by copyright and other intellectual property laws and by international treaties. VTC, Inc.

Trademark Notice: VTC, Virtual Training Company, Inc., The VTC Logo, and VTC Online University, are trademarks of VTC, Inc. All other company and product names may be trademarks of their respective owners.
The information contained herein is subject to change without notice. Copyright © 1995 - 2005 VTC, Inc. All rights reserved.

7. TERMINATION: This Agreement shall automatically terminate if You fail to comply with the restrictions described herein. Your obligations to pay outstanding subscription fees shall survive any termination of this Agreement.

8. LIMITATION OF LIABILITY: UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, TORT, CONTRACT, OR OTHERWISE, SHALL VTC OR ITS SUPPLIERS OR RESELLERS BE LIABLE TO YOU OR ANY OTHER PERSON FOR ANY INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY CHARACTER, INCLUDING WITHOUT LIMITATION, DAMAGES FOR LOSS OF GOODWILL, WORK STOPPAGE, COMPUTER FAILURE OR MALFUNCTION, OR ANY AND ALL OTHER COMMERCIAL DAMAGES OR LOSSES. IN NO EVENT WILL VTC BE LIABLE FOR ANY DAMAGES IN EXCESS OF THE AMOUNT VTC RECEIVED FROM YOU FOR A LICENSE TO THE SOFTWARE, EVEN IF VTC SHALL HAVE BEEN INFORMED OF THE POSSIBILITY OF SUCH
DAMAGES, OR FOR ANY CLAIM BY ANY OTHER PARTY. THIS LIMITATION OF LIABILITY SHALL NOT APPLY TO LIABILITY FOR DEATH OR PERSONAL INJURY RESULTING FROM VTC'S NEGLIGENCE TO THE EXTENT APPLICABLE LAW PROHIBITS SUCH LIMITATION. SOME JURISDICTIONS DO NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR CONSEQUENTIAL DAMAGES, SO THIS EXCLUSION AND LIMITATION MAY NOT APPLY TO YOU.

9. Links To Other Materials: Linked sites found at the VTC site are not under the control of VTC, and we are not responsible for the content of any linked site or any link contained in a linked site. VTC may change links based solely on our discretion, and we reserve the right to terminate any link or linking program at any time. VTC does not, by linking to sites, endorse companies or products to which it links and reserves the right to note as such on its web pages. If you decide to access any of the third party sites linked to this site, you do this entirely at your own risk.

Forums, and Chat are not always screened by VTC, and we are not responsible for the content of any public or open forum content at the site. VTC may change these public forums based solely on our discretion, and we reserve the right to terminate any forum at any time. VTC does not, by allowing these forums, endorse companies or products which may be mentioned in these forums, and reserves the right to note as such on its web pages. If you decide to access any of the public forums in this site, or linked to this site, you do this entirely at your own risk.

9. GOVERNING LAW & DISPUTE RESOLUTION: This Agreement is governed by Virginia law. All disputes between You and VTC shall be finally resolved through arbitration in Winchester, Virginia. This site is controlled by VTC from its offices within the United States of America. VTC makes no representation that materials in the site are appropriate or available for use in other locations, and access to them from territories where their content is illegal is prohibited. Those who choose to access this site from other locations do so on their own initiative and are responsible for compliance with applicable local laws. You may not use or export the Materials in violation of U.S. export laws and regulations. Any claim relating to the Materials shall be governed by the internal substantive laws of the Commonwealth of Virginia, USA.

VTC may revise these Terms at any time by updating this posting. You should visit this page from time to time to review the then-current Terms because they are binding on you. Certain provisions of these Terms may be superseded by expressly designated legal notices or terms located on particular pages at this Site.

If you have any questions regarding this policy, or your information specifically,
you may email us at:
admin@vtc.com.