получить много-много отношений - PullRequest
0 голосов
/ 07 августа 2011
Tag:
  columns:
    name:              
      type: string(100)

TagNews:
  columns:
    tag_id:  
      type: integer
      primary: true
    news_id:   
      type: integer
      primary: true 
  relations:
    Tag:     { onDelete: CASCADE, local: tag_id, foreign: id }
    News:      { onDelete: CASCADE, local: news_id, foreign: id }

News:
  columns:
    tag_id:        
      type: integer
    name:               
      type: string(100)
  relations:
    Tag:
      class: Tag
      refClass: TagNews
      local: news_id
      foreign: tag_id
      foreignAlias: TagNews


TAG:
| id | name |
| 1  | tag1 |
| 2  | tag2 |
| 3  | tag3 |


TagNews:
| id_tag | tag_news |
| 1      |  1       |
| 2      |  1       |
| 2      |  2       |
| 3      |  2       |
| 3      |  3       |
| 1      |  3       |

News:

| id  | name  |
| 1   | news1 |
| 2   | news2 |
| 3   | news3 |
| 4   | news4 |
| 5   | news5 |

как я могу получить все новости для tag1 и т. Д.?

например site.com / tag / tag1 ? что я должен написать в action.class и шаблон? я использую Symfony 1.4 и Doctrine 1.2

1 Ответ

1 голос
/ 07 августа 2011
$tag = TagTable::getInstance()->find(1);
$news = $tag->getNews();

должно работать .. в противном случае вам придется определить отношение к новостям в теге (так же, как тег в новостях)

...