I have integrated NHibernate.Search into my web app by following tutorials from the following sources:
- NHibernate.Search using Lucene.NET Full Text Index (Part 1)
- Using NHibernate.Search with ActiveRecord
I have also successfully batch-indexed my database, and when testing against Luke, I can search for terms that reside in whatever entities I marked as indexable.
However, when I attempt to update many-to-many entities via my web app, my parent index does not seem to update. For example:
public class Books
{
HasAndBelongsToMany(typeof(Author), Table = "BookAuthor", ColumnKey = "BookId", ColumnRef = "AuthorId")]
[IndexedEmbedded]
public IList<Author> Authors
{
get { return authors; }
set { authors = value; }
}
}
public class Author
{
HasAndBelongsToMany(typeof(Book), Table = "BookAuthor", ColumnKey = "AuthorId", ColumnRef = "BookId"), Inverse=true]
[ContainedIn]
public IList<Author> Authors
{
get { return authors; }
set { authors = value; }
}
}
Now, when I try to do things like myBook.Authors.Add(Author.Create("xxx"))
I can see that my Author index has been updated, however, the Book index (which is the parent index) has not been updated and searching for the newly added author returns an empty result.
Note that this only happens when dealing with many-to-many relationships.
I am not sure why this is so. Has anyone else experienced similar difficulties? I'd appreciate it if I could be pointed in the right direction, cheers.