=head1 NAME KinoSearch::Docs::Tutorial::FieldType - Specify per-field properties and behaviors. =head1 DESCRIPTION The Schema we used in the last chapter specifies three fields: my $type = KinoSearch::FieldType::FullTextType->new( analyzer => $polyanalyzer, ); $schema->spec_field( name => 'title', type => $type ); $schema->spec_field( name => 'content', type => $type ); $schema->spec_field( name => 'url', type => $type ); Since they are all defined as "full text" fields, they are all searchable -- including the C field, a dubious choice. Some URLs contain meaningful information, but these don't, really: http://example.com/us_constitution/amend1.html We may as well not bother indexing the URL content. To achieve that we need to assign the C field to a different FieldType. =head2 StringType Instead of FullTextType, we'll use a L, which doesn't use an Analyzer to break up text into individual fields. Furthermore, we'll mark this StringType as unindexed, so that its content won't be searchable at all. my $url_type = KinoSearch::FieldType::StringType( indexed => 0 ); $schema->spec_field( name => 'url', type => $url_type ); To observe the change in behavior, try searching for C both before and after changing the Schema and re-indexing. =head2 Toggling 'stored' For a taste of other FieldType possibilities, try turning off C for one or more fields. my $content_type = KinoSearch::FieldType::FullTextType->new( analyzer => $polyanalyzer, stored => 0, ); Turning off C for either C or C<url> mangles our results page, but since we're not displaying C<content>, turning it off for C<content> has no effect -- except on index size. =head2 Analyzers up next Analyzers play a crucial role in the behavior of FullTextType fields. In our next tutorial chapter, L<KinoSearch::Docs::Tutorial::Analysis>, we'll see how changing up the Analyzer changes search results. =head1 COPYRIGHT Copyright 2008-2009 Marvin Humphrey =head1 LICENSE, DISCLAIMER, BUGS, etc. See L<KinoSearch> version 0.30.