Как мне настроить мои POCO с помощью Subsonic 3 и SimpleRepostitory? или где конвенция?
Есть ли где-нибудь подробное описание того, как настроить ваши POCO при использовании SimpleRepository с SubSonic 3? Похоже, это соглашение по конфигурации, но я не могу найти, где это соглашение объясняется.
http://www.subsonicproject.com/docs/Conventions выглядит так, как будто оно предназначено для 2.0, а также помечено как неполное. (Кстати: я хотел бы помочь реорганизовать документы в более 2.0 и 3.0, так как текущие документы немного сбивают с толку, на какую версию они ссылаются.)
Например, я хотел бы знать, как я собираюсь создать
отношения один-к-одному
Профиль пользователя <=>
class User {
Id
ProfileId instead of Profile? or is Profile profile possible?
}
class Profile {
Id
UserId instead of User? or is User user possible?
}
Отношения один ко многим
class User {
Id
IList<Post> Posts (?) or IList<int> PostIds (?) or is this implied somehow? or is this just wrong?
}
class Post {
Id
UserId instead of User? or is User user possible?
}
Многие-ко-многим
Я предполагаю, что мне нужно настроить таблицу "многие ко многим"?
class User {
IList<Blog> Blogs (?) or IList<int> BlogIds (?) or is this implied somehow?
}
class BlogsUsers { // Do I have to create this class?
UserId
BlogId
}
class User {
IList<User> Users (?) or IList<int> UserIds (?) or is this implied somehow?
}
В примере решения не похоже, что они установлены, поэтому мне интересно, как бы вы поступили (пример моего предположения продолжается):
один к одному
User.Profile
r.Single<Profile>(p=>p.User == userId);
родитель на один ко многим
Post.User
id = r.Single<Post>(postId).UserId;
r.Single<User>(id); // which kind of stinks with two queries, JOIN?
дети на одного ко многим
User.Posts
r.Find<Post>(p=>p.UserId == userId)
или многие ко многим
User.Blogs
ids = r.Find<BlogsUsers>(bu=>bu.UserId == userId);
r.Find<Blog>(b=>b.BlogId == ids); // again with the two queries? :)
Blog.Users
ids = r.Find<BlogsUsers>(bu=>bu.BlogId == blogId);
r.Find<User>(u=>u.UserId == ids); // again with the two queries? :)
Я хотел бы предположить, что должен быть способ не иметь два запроса и эти свойства уже каким-то образом генерируются автоматически. По правде говоря, у меня был всего час, чтобы поиграть со всем прошлой ночью, поэтому я немного боюсь, что Роб кричит на меня. Мне жаль!:П
Если это не autogen'd, то где же представления и процедуры хранения для 3.0? Пожалуйста, дайте мне ссылку на них, пока вы в этом, приятель.
1 ответ
Вероятно, это лучшее место для начала: http://subsonicproject.com/docs/Using_SimpleRepository
Отношения устанавливаются в коде вами, и мы не переносим их в БД (пока, надеюсь, скоро). В идеале вы настраиваете свою модель так, как вам нужно, и когда вы готовы, вы идете и вручную "укрепляете" свои отношения в БД. Это должно уменьшить трение во время разработки - целостность данных не стоит беспокоиться при создании сайта.
Тем не менее, я знаю, что люди хотят эту функцию - мне просто нужно ее построить.