{"id":80,"date":"2016-04-17T23:04:54","date_gmt":"2016-04-17T21:04:54","guid":{"rendered":"http:\/\/antek.atthost24.pl\/?p=80"},"modified":"2016-04-20T00:17:53","modified_gmt":"2016-04-19T22:17:53","slug":"ormlite-realizacja-relacji-wiele-do-wielu","status":"publish","type":"post","link":"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/","title":{"rendered":"OrmLite &#8211; realizacja relacji wiele-do-wielu"},"content":{"rendered":"<p>W <a href=\"http:\/\/antek.atthost24.pl\/index.php\/2016\/03\/08\/przechowywanie-danych-w-aplikacji\/\">tym wpisie<\/a> przedstawi\u0142em orientacyjny schemat bazy danych, kt\u00f3ry b\u0119dzie zastosowany w mojej aplikacji. Mo\u017cna tam zauwa\u017cy\u0107 relacje wiele-do-wielu pomi\u0119dzy tabelami tags i documents oraz tabele documents_tags, kt\u00f3ra jest tak zwan\u0105 tabel\u0105 skrzy\u017cowa\u0144.<\/p>\n<p><a href=\"http:\/\/ormlite.com\/\">OrmLite<\/a> niestety nie wspiera relacji wiele-do-wielu, ale sama realizacja tego na szcz\u0119\u015bcie nie jest trudna.<\/p>\n<p>Zaczn\u0119 od pokazania encji dla tabeli documents_tags.<\/p>\n<pre>@DatabaseTable(tableName = \"documents_tags\")\r\nclass DocumentTag {\r\n  @DatabaseField(generatedId = true)\r\n  var id: Int = _\r\n  @DatabaseField(foreign = true, canBeNull = false)\r\n  var document: Document = _\r\n  @DatabaseField(foreign = true, canBeNull = false)\r\n  var tag: Tag = _\r\n}<\/pre>\n<p>Jak wida\u0107 encja zawiera tylko 3 pola:<\/p>\n<ul>\n<li>id &#8211; id encji, kt\u00f3re jest wymagane<\/li>\n<li>document &#8211; klucz obcy odnosz\u0105cy si\u0119 do dokumentu<\/li>\n<li>tag &#8211; klucz obcy odnosz\u0105cy si\u0119 do tagu<\/li>\n<\/ul>\n<p>Encja tag wygl\u0105da nast\u0119puj\u0105co:<\/p>\n<pre>@DatabaseTable(tableName = \"tags\")\r\nclass Tag {\r\n  @DatabaseField(generatedId = true)\r\n  var id: Int = _\r\n  @DatabaseField(canBeNull = false, unique = true)\r\n  var name: String = _\r\n}<\/pre>\n<p>Wydaj\u0119 mi si\u0119, \u017ce tutaj nie ma nic do t\u0142umaczenia \ud83d\ude42<\/p>\n<p>Encja dla dokumentu wygl\u0105da natomiast tak:<\/p>\n<pre>@DatabaseTable(tableName = \"documents\")\r\nclass Document {\r\n  @DatabaseField(generatedId = true)\r\n  var id: Int = _\r\n  @DatabaseField(canBeNull = false)\r\n  var title: String = _\r\n  @DatabaseField(canBeNull = false)\r\n  var createDate: Date = _\r\n  @ForeignCollectionField(eager = false)\r\n  var documentTags: ForeignCollection[DocumentTag] = _\r\n  @ForeignCollectionField(eager = false)\r\n  var documentFiles: ForeignCollection[DocumentFile] = _\r\n}<\/pre>\n<p>Tutaj istotne jest nast\u0119puj\u0105ce pole:<\/p>\n<pre>  @ForeignCollectionField(eager = false)\r\n  var documentTags: ForeignCollection[DocumentTag] = _<\/pre>\n<p>Jak wida\u0107 jest to 'obca&#8217; kolekcja. Co b\u0119dzie zawiera\u0142a kolekcja po pobraniu dokumentu przy pomocy metody\u00a0queryForId?<\/p>\n<pre>class DocumentDao(val dao: Dao[Document, Int]) extends RuntimeExceptionDao[Document, Int](dao) {\r\n  def getDocumentById(documentId: Int): Document = {\r\n    dao.queryForId(documentId)\r\n  }\r\n}<\/pre>\n<p>Ot\u00f3\u017c, jak mo\u017cna si\u0119 domy\u015bli\u0107, kolekcja ta b\u0119dzie zawieraja liste encji DocumentTag powi\u0105zanych z dokumentem. Jest tylko jeden haczyk &#8211; pobrane encje\u00a0DocumentTag nie zawieraj\u0105 'ca\u0142ych&#8217; obiekt\u00f3w, a jedynie ich id. Czyli np. instancja klasy Tag w pobranej kolekcji bedzie zawiera\u0142a uzupe\u0142nione id, lecz pole name zawsze b\u0119dzie puste.<\/p>\n<p>Maj\u0105c t\u0105 wiedze wystarcz\u0105 dwa kroki do pobrania naszych tag\u00f3w.<\/p>\n<p>Po pierwsze musimy stworzy\u0107 metod\u0119, kt\u00f3ra na podstawie listy id tag\u00f3w, zwr\u00f3ci nam tagi.<\/p>\n<pre>def getTagsByIds(tagIds: List[Int]): List[Tag] = {\r\n  dao.queryBuilder.where().in(\"id\", tagIds.asJava).query().toList\r\n}<\/pre>\n<p>A maj\u0105c pobran\u0105 nasz\u0105 encje mo\u017cemy pobra\u0107 jej taki wywo\u0142uj\u0105c powy\u017csz\u0105 metod\u0119 w nast\u0119puj\u0105cy spos\u00f3b:<\/p>\n<pre>val tags: List[Tag] = tagDao.getTagsByIds(document.documentTags.map(t =&gt; t.tag.id).toList)<\/pre>\n<p>&nbsp;<\/p>\n<p>Jak wida\u0107 pomimo braku jawnego wsparcia dla relacji wiele-do-wielu mo\u017cemy sobie z tym w miar\u0119 \u0142adny spos\u00f3b poradzi\u0107 \ud83d\ude42<\/p>\n","protected":false},"excerpt":{"rendered":"<p>W tym wpisie przedstawi\u0142em orientacyjny schemat bazy danych, kt\u00f3ry b\u0119dzie zastosowany w mojej aplikacji. Mo\u017cna tam zauwa\u017cy\u0107 relacje wiele-do-wielu pomi\u0119dzy tabelami tags i documents oraz tabele documents_tags, kt\u00f3ra&#8230;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[2,6],"tags":[5,3,4],"class_list":["post-80","post","type-post","status-publish","format-standard","hentry","category-daj-sie-poznac","category-simple-document-manager","tag-android","tag-dajsiepoznac","tag-sdm"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v21.4 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>OrmLite - realizacja relacji wiele-do-wielu - Lukasz Antkowiak&#039;s blog<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/\" \/>\n<meta property=\"og:locale\" content=\"pl_PL\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"OrmLite - realizacja relacji wiele-do-wielu - Lukasz Antkowiak&#039;s blog\" \/>\n<meta property=\"og:description\" content=\"W tym wpisie przedstawi\u0142em orientacyjny schemat bazy danych, kt\u00f3ry b\u0119dzie zastosowany w mojej aplikacji. Mo\u017cna tam zauwa\u017cy\u0107 relacje wiele-do-wielu pomi\u0119dzy tabelami tags i documents oraz tabele documents_tags, kt\u00f3ra...\" \/>\n<meta property=\"og:url\" content=\"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/\" \/>\n<meta property=\"og:site_name\" content=\"Lukasz Antkowiak&#039;s blog\" \/>\n<meta property=\"article:published_time\" content=\"2016-04-17T21:04:54+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2016-04-19T22:17:53+00:00\" \/>\n<meta name=\"author\" content=\"\u0141ukasz Antkowiak\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Napisane przez\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u0141ukasz Antkowiak\" \/>\n\t<meta name=\"twitter:label2\" content=\"Szacowany czas czytania\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 minuty\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/\",\"url\":\"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/\",\"name\":\"OrmLite - realizacja relacji wiele-do-wielu - Lukasz Antkowiak&#039;s blog\",\"isPartOf\":{\"@id\":\"https:\/\/blog.lantkowiak.pl\/#website\"},\"datePublished\":\"2016-04-17T21:04:54+00:00\",\"dateModified\":\"2016-04-19T22:17:53+00:00\",\"author\":{\"@id\":\"https:\/\/blog.lantkowiak.pl\/#\/schema\/person\/009bfc4db220c225786c59b1748ba1e6\"},\"breadcrumb\":{\"@id\":\"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/#breadcrumb\"},\"inLanguage\":\"pl-PL\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Strona g\u0142\u00f3wna\",\"item\":\"https:\/\/blog.lantkowiak.pl\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"OrmLite &#8211; realizacja relacji wiele-do-wielu\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/blog.lantkowiak.pl\/#website\",\"url\":\"https:\/\/blog.lantkowiak.pl\/\",\"name\":\"Lukasz Antkowiak&#039;s blog\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/blog.lantkowiak.pl\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"pl-PL\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/blog.lantkowiak.pl\/#\/schema\/person\/009bfc4db220c225786c59b1748ba1e6\",\"name\":\"\u0141ukasz Antkowiak\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pl-PL\",\"@id\":\"https:\/\/blog.lantkowiak.pl\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/e18e2bfe319da9b5757cf7f7ae1bfecf?s=96&d=monsterid&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/e18e2bfe319da9b5757cf7f7ae1bfecf?s=96&d=monsterid&r=g\",\"caption\":\"\u0141ukasz Antkowiak\"},\"description\":\"dd\",\"url\":\"https:\/\/blog.lantkowiak.pl\/index.php\/author\/antek\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"OrmLite - realizacja relacji wiele-do-wielu - Lukasz Antkowiak&#039;s blog","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/","og_locale":"pl_PL","og_type":"article","og_title":"OrmLite - realizacja relacji wiele-do-wielu - Lukasz Antkowiak&#039;s blog","og_description":"W tym wpisie przedstawi\u0142em orientacyjny schemat bazy danych, kt\u00f3ry b\u0119dzie zastosowany w mojej aplikacji. Mo\u017cna tam zauwa\u017cy\u0107 relacje wiele-do-wielu pomi\u0119dzy tabelami tags i documents oraz tabele documents_tags, kt\u00f3ra...","og_url":"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/","og_site_name":"Lukasz Antkowiak&#039;s blog","article_published_time":"2016-04-17T21:04:54+00:00","article_modified_time":"2016-04-19T22:17:53+00:00","author":"\u0141ukasz Antkowiak","twitter_card":"summary_large_image","twitter_misc":{"Napisane przez":"\u0141ukasz Antkowiak","Szacowany czas czytania":"2 minuty"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/","url":"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/","name":"OrmLite - realizacja relacji wiele-do-wielu - Lukasz Antkowiak&#039;s blog","isPartOf":{"@id":"https:\/\/blog.lantkowiak.pl\/#website"},"datePublished":"2016-04-17T21:04:54+00:00","dateModified":"2016-04-19T22:17:53+00:00","author":{"@id":"https:\/\/blog.lantkowiak.pl\/#\/schema\/person\/009bfc4db220c225786c59b1748ba1e6"},"breadcrumb":{"@id":"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/#breadcrumb"},"inLanguage":"pl-PL","potentialAction":[{"@type":"ReadAction","target":["https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/blog.lantkowiak.pl\/index.php\/2016\/04\/17\/ormlite-realizacja-relacji-wiele-do-wielu\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Strona g\u0142\u00f3wna","item":"https:\/\/blog.lantkowiak.pl\/"},{"@type":"ListItem","position":2,"name":"OrmLite &#8211; realizacja relacji wiele-do-wielu"}]},{"@type":"WebSite","@id":"https:\/\/blog.lantkowiak.pl\/#website","url":"https:\/\/blog.lantkowiak.pl\/","name":"Lukasz Antkowiak&#039;s blog","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/blog.lantkowiak.pl\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"pl-PL"},{"@type":"Person","@id":"https:\/\/blog.lantkowiak.pl\/#\/schema\/person\/009bfc4db220c225786c59b1748ba1e6","name":"\u0141ukasz Antkowiak","image":{"@type":"ImageObject","inLanguage":"pl-PL","@id":"https:\/\/blog.lantkowiak.pl\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/e18e2bfe319da9b5757cf7f7ae1bfecf?s=96&d=monsterid&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/e18e2bfe319da9b5757cf7f7ae1bfecf?s=96&d=monsterid&r=g","caption":"\u0141ukasz Antkowiak"},"description":"dd","url":"https:\/\/blog.lantkowiak.pl\/index.php\/author\/antek\/"}]}},"_links":{"self":[{"href":"https:\/\/blog.lantkowiak.pl\/index.php\/wp-json\/wp\/v2\/posts\/80","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.lantkowiak.pl\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.lantkowiak.pl\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.lantkowiak.pl\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.lantkowiak.pl\/index.php\/wp-json\/wp\/v2\/comments?post=80"}],"version-history":[{"count":8,"href":"https:\/\/blog.lantkowiak.pl\/index.php\/wp-json\/wp\/v2\/posts\/80\/revisions"}],"predecessor-version":[{"id":88,"href":"https:\/\/blog.lantkowiak.pl\/index.php\/wp-json\/wp\/v2\/posts\/80\/revisions\/88"}],"wp:attachment":[{"href":"https:\/\/blog.lantkowiak.pl\/index.php\/wp-json\/wp\/v2\/media?parent=80"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.lantkowiak.pl\/index.php\/wp-json\/wp\/v2\/categories?post=80"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.lantkowiak.pl\/index.php\/wp-json\/wp\/v2\/tags?post=80"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}