{"id":166051,"date":"2013-01-17T00:29:03","date_gmt":"2013-01-16T20:29:03","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=166051"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=166051","title":{"rendered":"<span class=\"post_title\">AnnotatedSQL: schema + content provider<\/span>"},"content":{"rendered":"<div class=\"content html_format\">   \t\u041d\u0430\u043a\u043e\u043d\u0435\u0446 \u0434\u043e\u0448\u043b\u0438 \u0440\u0443\u043a\u0438 \u043e\u043f\u0438\u0441\u0430\u0442\u044c \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u043e\u0438\u0437\u043e\u0448\u043b\u0438 \u0432 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 <a href=\"https:\/\/github.com\/hamsterksu\/Android-AnnotatedSQL\">AnnotatedSQL<\/a><\/p>\n<p>  \u0410\u043d\u043e\u043d\u0441:<br \/>  1. \u0418\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0432 \u043f\u043b\u0430\u0433\u0438\u043d\u0435<br \/>  2. \u0418\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0432 \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u044f\u0445 \u0441\u0445\u0435\u043c\u044b <br \/>  3. \u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 content provider \u0432 \u043c\u043e\u0435\u043c \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u0438<br \/>  4. \u0413\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u043c content provider \u043f\u043e \u0441\u0445\u0435\u043c\u0435 <br \/>  <a name=\"habracut\"><\/a>  <\/p>\n<h4>1. Plugin<\/h4>\n<p>  <\/p>\n<h6>Plugin update site<\/h6>\n<p> \u0422\u0435\u043f\u0435\u0440\u044c \u044d\u0442\u043e \u0438 \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u044b\u0439 \u043f\u043b\u0430\u0433\u0438\u043d \u0434\u043b\u044f Eclipse \u0441\u043e \u0441\u0432\u043e\u0438\u043c <a href=\"http:\/\/dl.dropbox.com\/u\/8604560\/annotatedsql\/update_site\/\">update site<\/a><\/p>\n<h6>Build path-&gt;Libraries-&gt;Add Library<\/h6>\n<p> \u0410\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u0438 \u0442\u0435\u043f\u0435\u0440\u044c \u043d\u0435 \u043d\u0430\u0434\u043e \u043a\u043b\u0430\u0441\u0442\u044c \u0432 \u043f\u0440\u043e\u0435\u043a\u0442, \u043f\u043b\u0430\u0433\u0438\u043d \u043d\u0435\u0441\u0435\u0442 \u0438\u0445 \u0441 \u0441\u043e\u0431\u043e\u0439. \u0412\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c AnnotatedSQL Libaray \u0432 \u043f\u0440\u043e\u0435\u043a\u0442 \u0432 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430\u0445 \u043f\u0440\u043e\u0435\u043a\u0442\u0430. \u0418 \u0443 \u0432\u0430\u0441 \u0432\u0441\u0435\u0433\u0434\u0430 API \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0435 \u043f\u043b\u0430\u0433\u0438\u043d\u0443. <\/p>\n<h6>\u0428\u0430\u0431\u043b\u043e\u043d\u044b \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0441\u0445\u0435\u043c\u044b, \u0442\u0430\u0431\u043b\u0438\u0446\u044b, view<\/h6>\n<p> \u0412 eclipse \u0435\u0441\u0442\u044c \u0442\u0430\u043a\u0430\u044f \u0437\u0430\u043c\u0435\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u0430\u044f \u0448\u0442\u0443\u043a\u0430 \u043a\u0430\u043a \u0448\u0430\u0431\u043b\u043e\u043d\u044b \u043a\u043e\u0434\u0430. \u041f\u043b\u0430\u0433\u0438\u043d \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442 \u0441\u0432\u043e\u0438 \u0448\u0430\u0431\u043b\u043e\u043d\u044b \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0441\u0445\u0435\u043c\u044b, \u0442\u0430\u0431\u043b\u0438\u0446\u044b, view. \u0438 \u044d\u0442\u0438 \u0448\u0430\u0431\u043b\u043e\u043d\u044b \u043f\u043e\u043f\u0430\u0434\u0430\u044e\u0442 code completion, \u0442\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043f\u043e ctrl+space<\/p>\n<p>  \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u043f\u0438\u0448\u0435\u043c <i>Tabl<\/i> \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c \u0437\u0430\u0432\u0435\u0442\u043d\u044b\u0435 \u043a\u043d\u043e\u043f\u043a\u0438 \u0438 \u0432\u0438\u0434\u0438\u043c <i><b>Table \u2014 AnnotatedSQL<\/b><\/i>, \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u0438 \u0443 \u0432\u0430\u0441 \u0448\u0430\u0431\u043b\u043e\u043d \u0434\u043b\u044f \u0442\u0430\u0431\u043b\u0438\u0446\u044b.<br \/>  \u041d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u0435\u043c: \u0447\u0442\u043e \u0431\u044b \u043f\u0435\u0440\u0435\u043f\u0440\u044b\u0433\u043d\u0443\u0442\u044c \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u043f\u043e\u043b\u0435 \u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u0430 \u043d\u0430\u0436\u0438\u043c\u0430\u0435\u043c \u043a\u043b\u0430\u0432\u0438\u0448\u0443 \u00abTab\u00bb, \u0430 \u00abEnter\u00bb \u0437\u0430\u0432\u0435\u0440\u0448\u0438\u0442 \u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u0430. <\/p>\n<h4>2. \u041e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f \u0432 \u0441\u0445\u0435\u043c\u0435<\/h4>\n<p>  <b>\u0418\u0437\u043c\u0435\u043d\u0438\u043b\u0430\u0441\u044c \u043f\u043e\u0436\u0430\u043b\u0443\u0439 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u043d\u0430 \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u044f<\/b>  <\/p>\n<h6>Join<\/h6>\n<p> \u041f\u0435\u0440\u0435\u0438\u043c\u0435\u043d\u043e\u0432\u0430\u043b \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b:<br \/>  <i>srcTable <\/i> -&gt; <b>joinTable<\/b><br \/>  <i>srcColumn<\/i> -&gt; <b>joinColumn <\/b><br \/>  <i>destTable<\/i> -&gt; <b>onTableAlias<\/b><br \/>  <i>destColumn<\/i> -&gt; <b>onColumn<\/b><br \/>  \u043d\u0430\u0434\u0435\u044e\u0441\u044c \u0442\u0430\u043a \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043d\u044f\u0442\u043d\u0435\u0435. \u0410 \u0433\u043b\u0430\u0432\u043d\u043e\u0435 \u043d\u0430\u0434\u043e \u043f\u043e\u043c\u043d\u0438\u0442\u044c, \u0447\u0442\u043e <i>onTableAlias<\/i> \u2014 \u043d\u0435 \u0438\u043c\u044f \u0442\u0430\u0431\u043b\u0438\u0446\u044b, \u0430 \u0430\u043b\u0438\u0430\u0441 \u043d\u0430 \u043d\u0435\u0435. <\/p>\n<p>  <b>\u0410 \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u043e\u0441\u044c \u0441\u0440\u0430\u0437\u0443 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e:<\/b><\/p>\n<h6>RawJoin<\/h6>\n<p> \u0415\u0441\u043b\u0438 ON \u0443\u0441\u043b\u043e\u0432\u0438\u0435 \u043e\u0442\u043b\u0438\u0447\u0430\u0435\u0442\u0441\u044f \u043e\u0442 column1 = column2 \u0442\u043e\u0433\u0434\u0430 \u0432\u0430\u043c \u0441\u044e\u0434\u0430. \u0412\u044b \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0434\u0436\u043e\u0439\u043d\u0438\u0442\u0435 \u0438 \u043f\u0438\u0448\u0438\u0442\u0435 \u0443\u0441\u043b\u043e\u0432\u0438\u0435 \u0440\u0443\u043a\u0430\u043c\u0438.<br \/>  <u>\u0410\u0442\u0440\u0438\u0431\u0443\u0442\u044b:<\/u> <br \/>  <b>joinTable<\/b> \u2014 \u0438\u043c\u044f \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0434\u0436\u043e\u0439\u043d\u0438\u0442\u0435\u0441\u044c <br \/>  <b>onCondition<\/b> \u2014 ON \u0443\u0441\u043b\u043e\u0432\u0438\u0435<\/p>\n<h6>IgnoreColumns<\/h6>\n<p> \u041a\u043e\u0433\u0434\u0430 \u043d\u0430\u043c \u043d\u0435 \u043d\u0430\u0434\u043e \u0432\u044b\u0431\u0438\u0440\u0430\u0442\u044c \u043d\u0438 \u0435\u0434\u0438\u043d\u043e\u0433\u043e \u0441\u0442\u043e\u043b\u0431\u0446\u0430 \u0438\u0437 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u2014 \u043f\u043e\u043c\u0435\u0447\u0430\u0435\u043c \u0435\u0435 \u0442\u0430\u043a\u043e\u0439 \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u0435\u0439. \u041f\u0440\u0438\u043c\u0435\u043d\u0438\u043c\u0430 \u0434\u043b\u044f <i>From<\/i>, <i>Join<\/i>, <i>RawJoin<\/i><\/p>\n<h6>RawQuery<\/h6>\n<p> \u0417\u0430\u043f\u0440\u043e\u0441 \u0441 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438 \u0432 \u043b\u044e\u0431\u043e\u043c \u043c\u0435\u0441\u0442\u0435. \u042d\u0442\u0430 \u0448\u0442\u0443\u043a\u0430 \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u043d\u0430 \u0434\u043b\u044f \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u0430 \u0438 \u043e\u0431\u0443\u0441\u043b\u043e\u0432\u043b\u0435\u043d\u0430 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u043d\u043e\u0441\u0442\u044c\u044e view \u0432 sql. \u0412\u044c\u044e\u0448\u043a\u0430 \u044d\u0442\u043e select + join, \u0430 where \u0443\u0436\u0435 \u043f\u043e\u0442\u043e\u043c \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f.<br \/>  \u041d\u043e \u0447\u0430\u0441\u0442\u043e \u043d\u0430\u0434\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0437\u0430\u043f\u0440\u043e\u0441, \u0433\u0434\u0435 \u0443\u0436\u0435 \u0432 ON \u0443\u0441\u043b\u043e\u0432\u0438\u0438 \u0434\u0436\u043e\u0439\u043d\u0430 \u043d\u0430\u0434\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b. \u0432\u043e\u0442 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043e\u043d\u043e \u0438 \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u043d\u043e, \u0430\u043b\u044f sql function. \u0422\u0430\u043c \u0433\u0434\u0435 \u043d\u0430\u0434\u043e \u044e\u0437\u0430\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0435\u0441\u0442\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0441\u0442\u0430\u0432\u0438\u043c <b>?<\/b><br \/>  \u041f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u044b\u0439 sql \u0437\u0430\u043f\u0440\u043e\u0441 \u043d\u0438\u043a\u0443\u0434\u0430 \u043d\u0435 \u0441\u0442\u043e\u0440\u0438\u0442\u0441\u044f \u043f\u0440\u043e\u0441\u0442\u043e \u043b\u0435\u0436\u0438\u0442 \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u043e\u0439 \u0438 \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u0434\u0435\u0440\u043d\u0443\u0442\u044c \u043f\u043e URI(\u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0443 \u0434\u0430\u043b\u044c\u0448\u0435)<\/p>\n<p>  <b>RawQuery<\/b> \u043c\u043e\u0436\u043d\u043e \u0441\u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043a\u0430\u043a \u0438 SimpleView \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f <i>From<\/i>, <i>Join<\/i> and <i>RawJoin<\/i>,<br \/>  \u0430 \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e \u00ab\u0441\u044b\u0440\u043e\u0439 sql\u00bb \u0447\u0435\u0440\u0435\u0437 \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u044e <i>SqlQuery<\/i><\/p>\n<pre><code class=\"java\">@RawQuery(ChatListQuery.QUERY_NAME) public static interface ChatListQuery{      String QUERY_NAME = &quot;chatListQuery&quot;;      @SqlQuery     String CHAT_LIST_QUERY = &quot; some sql here&quot; } <\/code><\/pre>\n<h4>3. \u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 content provider \u0432 \u043c\u043e\u0435\u043c \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u0438<\/h4>\n<p>  \u0418\u0441\u0445\u043e\u0434\u044f \u0438\u0437 \u043e\u043f\u044b\u0442\u0430 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u043f\u043e\u0434 Android, \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440 \u0434\u043e\u043b\u0436\u0435\u043d \u043e\u0431\u043b\u0430\u0434\u0430\u0442\u044c \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u043c\u0438 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430\u043c\u0438. \u0418 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u043f\u0438\u0445\u043d\u0443\u0442\u044c \u0447\u0435\u0440\u0435\u0437 Uri, \u0442\u0430\u043c \u043f\u043e\u043b\u043d\u043e \u00ab\u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0433\u043e \u043c\u0435\u0441\u0442\u0430\u00bb \u2014 fragment, parametrs \u0432\u0441\u0435 \u043a\u0430\u043a \u0432 url. \u0418\u0442\u0430\u043a, \u0432\u043e\u0442 \u0447\u0442\u043e \u043e\u0431\u044b\u0447\u043d\u043e \u043d\u0430\u0434\u043e:<\/p>\n<p>  <b>no-notify<\/b><br \/>  \u041a\u043e\u0433\u0434\u0430 \u0432\u044b \u0432\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442\u0435 \u043f\u0430\u0447\u043a\u0443 \u0434\u0430\u043d\u043d\u044b\u0445 \u0432 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440 \u043d\u0435\u0442 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u043d\u043e\u0442\u0438\u0444\u0430\u0438\u0442\u044c UI \u043f\u043e\u0441\u043b\u0435 \u0432\u0441\u0442\u0430\u0432\u043a\u0438 \u043a\u0430\u0436\u0434\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438, \u0430 \u043b\u0443\u0447\u0448\u0435 \u0437\u0430\u043d\u043e\u0442\u0438\u0444\u0430\u0438\u0442\u044c \u043f\u043e\u0441\u043b\u0435 \u0432\u0441\u0442\u0430\u0432\u043a\u0438. <\/p>\n<p>  <b>alternative notify uri<\/b><br \/>  \u0427\u0430\u0441\u0442\u043e \u0435\u0441\u0442\u044c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u044c \u043f\u0440\u0438 \u043d\u043e\u0442\u0438\u0444\u0430\u0438 \u043e\u0434\u043d\u043e uri \u0437\u0430\u043d\u043e\u0442\u0438\u0444\u0430\u0438\u0442\u044c \u0437\u0430\u0432\u0438\u0441\u044f\u0449\u0438\u0435 uri. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c UserView \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432\u044b \u044e\u0437\u0430\u0435\u0442\u0435 \u0434\u043b\u044f \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0441\u043f\u0438\u0441\u043a\u0430, \u0430 \u0432\u0441\u0442\u0430\u0432\u043a\u0430 \u0442\u043e \u0438\u0434\u0435\u0442 \u0432 \u0442\u0430\u0431\u043b\u0438\u0446\u0443 User \u0438 \u0432\u0430\u043c \u043d\u0430\u0434\u043e \u043d\u043e\u0442\u0438\u0444\u0430\u0438\u0442\u044c uri \u0438\u0437 view \u0432\u043e\u0442 \u044d\u0442\u043e \u0438 \u0435\u0441\u0442\u044c alternative uri. <\/p>\n<p>  <b>limit<\/b><br \/>  \u0442\u0440\u0438\u0432\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u043b\u0438\u043c\u0438\u0442 \u043f\u0440\u0438 \u0437\u0430\u043f\u0440\u043e\u0441\u0435<\/p>\n<h4>4. \u0413\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u044f Content Provider \u043f\u043e \u0441\u0445\u0435\u043c\u0435<\/h4>\n<p>  \u041f\u043e\u0441\u043b\u0435 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043b \u0430\u0432\u0442\u043e\u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u044e \u0441\u0445\u0435\u043c\u044b \u043f\u043e \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u044f\u043c, \u044f \u0437\u0430\u0434\u0443\u043c\u0430\u043b\u0441\u044f: \u0443 \u043c\u0435\u043d\u044f \u0432\u0435\u0434\u044c \u0435\u0441\u0442\u044c \u0432\u0441\u0435, \u0447\u0442\u043e \u0431\u044b <s>\u0437\u0430\u0445\u0432\u0430\u0442\u0438\u0442\u044c \u043c\u0438\u0440<\/s> \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440 \u0438 \u043e\u0431\u043b\u0435\u0433\u0447\u0438\u0442\u044c \u0441\u0435\u0431\u0435 \u0436\u0438\u0437\u043d\u044c. \u0421\u043a\u0430\u0437\u0430\u043d\u043e \u2014 \u0441\u0434\u0435\u043b\u0430\u043d\u043e. \u041f\u0430\u0440\u0430 \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u0439 \u0438 \u0443 \u0432\u0430\u0441 \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u044b\u0439 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440 + \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u043b\u044e\u0448\u0435\u043a. \u041d\u0443 \u043f\u043e\u043d\u0435\u0441\u043b\u043e\u0441\u044c!<\/p>\n<p>  \u041f\u0435\u0440\u0432\u043e\u0435 \u2014 \u043d\u0430\u0434\u043e \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u0447\u0442\u043e \u043f\u043e \u0441\u0445\u0435\u043c\u0435 \u0433\u0435\u043d\u0435\u0440\u0438\u043c \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440. \u0412 \u044d\u0442\u043e\u043c \u043d\u0430\u043c \u043f\u043e\u043c\u043e\u0436\u0435\u0442 \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u044f <b>Provider<\/b><\/p>\n<h6>Provider<\/h6>\n<p>  <b>name<\/b> \u2014 \u0438\u043c\u044f \u043a\u043b\u0430\u0441\u0441\u0430 \u0434\u043b\u044f \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0440\u0435\u0430<br \/>  <b>authority<\/b> \u2014 \u043d\u0430\u043c \u043d\u0430\u0434\u043e \u0437\u043d\u0430\u0442\u044c \u0430\u0432\u0442\u043e\u0440\u0438\u0442\u0438 \u043a\u043e\u043d\u0442\u0435\u0442 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u0430. <br \/>  <b>schemaClass<\/b> \u2014 \u0438\u043c\u044f \u043a\u043b\u0430\u0441\u0441\u0430 \u0441\u0445\u0435\u043c\u044b. \u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043a\u043e\u0433\u0434\u0430 \u0433\u0435\u043d\u0435\u0440\u0438\u0442\u0441\u044f open helper. <br \/>  <b>openHelperClass<\/b> \u2014 \u043c\u043e\u0436\u0435\u0442\u0435 \u043e\u0442\u043a\u0430\u0437\u0430\u0442\u044c\u0441\u044f \u043e\u0442 \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u0438 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0435\u0433\u043e open helper \u0438 \u0437\u0430\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u044e\u0437\u0430\u0442\u044c \u0432\u0430\u0448.<\/p>\n<pre><code class=\"java\">@Schema(className=&quot;FManagerSchema&quot;, dbName=&quot;fmanager.db&quot;, dbVersion=6) @Provider(authority=&quot;com.gdubina.fmanager.store.FManagerProvider&quot;, schemaClass=&quot;FManagerSchema&quot;, name=&quot;FManagerProvider&quot;, openHelperClass=&quot;CustomOpenHelper&quot;) public interface FManagerStore { <\/code><\/pre>\n<p>  \u0418\u0442\u0430\u043a, \u043c\u044b \u0441\u043a\u0430\u0437\u0430\u043b\u0438 \u0447\u0442\u043e \u0445\u043e\u0442\u0438\u043c \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440. \u0427\u0442\u043e \u0434\u0430\u043b\u044c\u0448\u0435?<br \/>  \u041d\u0430\u0434\u043e \u0441\u043a\u0430\u0437\u0430\u0442\u044c \u043f\u043e \u043a\u0430\u043a\u043e\u043c\u0443 URI \u0431\u0443\u0434\u0443\u0442 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b \u043d\u0430\u0448\u0438 entity \u2014 \u044e\u0437\u0430\u0435\u043c \u043e\u0434\u043d\u043e\u0438\u043c\u0435\u043d\u043d\u0443\u044e \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u044e <b>URI<\/b><\/p>\n<h6>URI<\/h6>\n<p> \u0432\u0435\u0448\u0430\u0435\u043c \u043d\u0430 \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u0443 \u0432 table, view \u0438\u043b\u0438 query. \u041c\u043d\u0435 \u043d\u0440\u0430\u0432\u0438\u0442\u0441\u044f \u043d\u0435\u0447\u0442\u043e \u0442\u0438\u043f\u0430 URI_CONTENT.<br \/>  \u0412\u0441\u0435 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b \u0442\u0443\u0442 \u043e\u043f\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b, \u043d\u043e \u043e\u043d\u0438 \u0435\u0441\u0442\u044c.<br \/>  <b>type<\/b> \u2014 \u0442\u0438\u043f uri. \u041a\u0430\u043a \u043c\u044b \u0437\u043d\u0430\u0435\u043c \u0432 \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u0435 \u043f\u0440\u0438\u043d\u044f\u0442\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0442\u044c, \u0447\u0442\u043e \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442\u0441\u044f \u043f\u043e URI \u043c\u043d\u043e\u0433\u043e \u0437\u0430\u043f\u0438\u0441\u0435\u0439(dir) \u0438\u043b\u0438 \u043e\u0434\u043d\u0430(item). \u041f\u043e\u043c\u043d\u0438\u0442\u0435 \u0442\u0430\u043a\u043e\u0439 \u043c\u0435\u0442\u043e\u0434 <i>getType<\/i>? \u0442\u0443\u0442 \u0442\u043e\u0436\u0435 \u0441\u0430\u043c\u043e\u0435. <br \/>  <b>onlyQuery<\/b> \u2014 \u0434\u043e\u0441\u0442\u0443\u043f \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f query, \u044e\u0437\u0430\u0431\u0435\u043b\u044c\u043d\u043e \u0434\u043b\u044f view and query. \u041f\u0440\u0438 \u043f\u043e\u043f\u044b\u0442\u043a\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c insert\/delete\/update \u2014 \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u0442 \u043a exception<br \/>  <b>column<\/b> \u2014 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e &quot;_id&quot;. \u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043a\u043e\u0433\u0434\u0430 \u0432\u044b \u044e\u0437\u0430\u0435\u0442\u0435 URI \u0442\u0438\u043f\u0430 parh\/# \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440 \u0434\u0435\u043b\u0430\u0435\u0442 \u0432\u044b\u0431\u043e\u0440\u043a\u0443 \u0430\u043b\u044f _id = uri.getLastPathSegment(). \u0442\u0430\u043a \u0432\u043e\u0442 \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043f\u0435\u0440\u0435\u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c \u043f\u043e \u043a\u0430\u043a\u043e\u043c\u0443 \u043f\u043e\u043b\u044e \u0434\u0435\u043b\u0430\u0442\u044c select<br \/>  <b>altNotify<\/b> \u2014 \u0441\u043f\u0438\u0441\u043e\u043a uri \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u0434\u043e \u043f\u0440\u043e\u043d\u0430\u0442\u0438\u0444\u0430\u0438\u0442\u044c \u0435\u0449\u0435 \u043d\u0430\u0434\u043e \u043f\u0440\u043e\u043d\u0430\u0442\u0438\u0444\u0430\u0438\u0442\u044c <\/p>\n<p>  <b>\u041f\u0430\u0440\u0443 \u043f\u0440\u0438\u043c\u0435\u0440\u043e\u0432:<\/b><br \/>  \u0432\u043e\u0442 \u0442\u0430\u043a \u043c\u044b \u0437\u0430\u0441\u0442\u0430\u0432\u0438\u043b\u0438 \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 \u0442\u0430\u0431\u043b\u0438\u0446\u0435\u0439 \u0447\u0435\u043c\u043f\u0438\u043e\u043d\u0430\u0442\u043e\u0432. \u0412\u0441\u0435 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e \u2014 \u0432\u044b\u0431\u043e\u0440\u043a\u0430, \u0432\u0441\u0442\u0430\u0432\u043a\u0430, \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u0435, \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435<\/p>\n<pre><code class=\"java\">@Table(ChempTable.TABLE_NAME) public static interface ChempTable{ \t \t@URI \tString CONTENT_PATH = &quot;chemps&quot;; \t \tString TABLE_NAME = &quot;chemp_table&quot;;  \t@PrimaryKey \t@Column(type = Type.INTEGER) \tString ID = &quot;_id&quot;; \t \t@Column(type = Type.TEXT) \tString TITLE = &quot;title&quot;; \t \t@Column(type = Type.TEXT) \tString CHEMP_KEY = &quot;CHEMP_KEY&quot;; } <\/code><\/pre>\n<p>  \u0410 \u0432\u043e\u0442 \u043a\u0443\u0441\u043e\u043a \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u0439. \u041a\u0430\u043a \u043c\u044b \u0432\u0438\u0434\u0438\u043c, \u0437\u0434\u0435\u0441\u044c \u0443 \u043c\u0435\u043d\u044f \u0434\u0432\u0430 URI<br \/>  1. \u0434\u043b\u044f \u0434\u043e\u0441\u0442\u0443\u043f\u0430 \u043a \u0441\u0430\u043c\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435 URI_CONTENT<br \/>  2. \u0434\u043b\u044f \u0432\u044b\u0431\u043e\u0440\u043a\u0438 \u043c\u0435\u0441\u0441\u0430\u0434\u0436\u0435\u0439 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u0433\u043e \u044e\u0437\u0435\u0440\u0430 URI_MESSAGES_BY_USER, \u043a\u0430\u043a \u0440\u0430\u0437 \u0437\u0434\u0435\u0441\u044c column=Message.FROM_ID<\/p>\n<pre><code class=\"java\">@Table(Message.TABLE_NAME) @PrimaryKey(columns = {Message.USER_ID, Message.ID}) public static interface Message{ \t \t@URI(altNotify={MessageChatView.URI_CONTENT, ChatListQuery.URI_CONTENT, URI_RECALC_MESSAGE_PATH}) \tString URI_CONTENT = &quot;message&quot;; \t \t@URI(type=URI.Type.ITEM, altNotify={Message.URI_CONTENT, MessageChatView.URI_CONTENT, ChatListQuery.URI_CONTENT, URI_RECALC_MESSAGE_PATH}, column=Message.FROM_ID) \tString URI_MESSAGES_BY_USER = &quot;message_by_user&quot;; } <\/code><\/pre>\n<p>  \u0414\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u043f\u0440\u043e\u0441\u0442\u043e\u0433\u043e \u043a\u043e\u043d\u0435\u0442\u043f \u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u0430 \u044d\u0442\u043e\u0433\u043e \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e. \u0412\u0441\u0435\u0433\u043e \u0434\u0432\u0435 \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u0438! <\/p>\n<p>  \u041d\u043e \u044d\u0442\u043e \u0435\u0449\u0435 \u043d\u0435 \u0432\u0441\u0435, \u0447\u0442\u043e \u0434\u0435\u043b\u0430\u0442\u044c \u0435\u0441\u043b\u0438 \u043d\u0430 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0441 \u0442\u0430\u0431\u043b\u0438\u0446\u0435\u0439 \u043d\u0430\u0434\u043e \u0447\u0442\u043e-\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c? \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u0438 \u044e\u0437\u0435\u0440\u0430 \u2014 \u043f\u043e\u0448\u043b\u0438 \u0437\u0430\u043a\u0430\u0447\u0430\u043b\u0438 \u0430\u0432\u0430\u0442\u0430\u0440\u043a\u0443. \u0432 \u0431\u043e\u043b\u044c\u0448\u043e\u043c sql \u0435\u0441\u0442\u044c \u0442\u0430\u043a\u0430\u044f \u0448\u0442\u0443\u043a\u0430 \u043a\u0430\u043a \u0442\u0440\u0438\u0433\u0433\u0435\u0440\u044b \u2014 \u0434\u0435\u043b\u0430\u044e\u0442 \u043d\u0435\u0447\u0442\u043e \u043f\u043e\u0434\u043e\u0431\u043d\u043e\u0435. \u0422\u0430\u043a \u0432\u043e\u0442 \u0438 \u044f \u043e\u0431\u043e\u0437\u0432\u0430\u043b \u0441\u0432\u043e\u044e \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u044e \u0442\u0430\u043a \u0441\u0430\u043c\u043e <b>Trigger<\/b>. \u0412 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u0435 \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u0437\u0434\u0430\u043d protected \u043c\u0435\u0442\u043e\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u043f\u0435\u0440\u0435\u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c \u0432 \u043d\u0430\u0441\u043b\u0435\u0434\u043d\u0438\u043a\u0438 \u0430\u0432\u0442\u043e\u0433\u0435\u043d\u0435\u0440\u0435\u043d\u043d\u043e\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430<\/p>\n<h6>Trigger<\/h6>\n<p> \u0432\u0435\u0448\u0430\u0435\u0442\u0441\u044f \u043d\u0430 uri, \u043d\u043e \u0432\u044b\u0437\u043e\u0432 \u043c\u0435\u0442\u043e\u0434\u0430 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043f\u0440\u0438 \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u0438 \u0438\u043c\u0435\u043d\u0438 \u0442\u0430\u0431\u043b\u0438\u0446\u044b<br \/>  <b>name<\/b> \u2014 \u0438\u043c\u044f \u0442\u0440\u0438\u0433\u0435\u0440\u0430, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0434\u043b\u044f \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u0438 \u0438\u043c\u0435\u043d\u0438 \u043c\u0435\u0442\u043e\u0434\u0430<br \/>  <b>when<\/b> \u2014 \u043a\u043e\u0433\u0434\u0430 \u0432\u044b\u0437\u044b\u0432\u0430\u0442\u044c \u043c\u0435\u0442\u043e\u0434 \u0434\u043e \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0441 \u0442\u0430\u0431\u043b\u0438\u0446\u0435\u0439 \u0438\u043b\u0438 \u043f\u043e\u0441\u043b\u0435.<br \/>  <b>type<\/b> \u2014 \u043d\u0430 \u043a\u0430\u043a\u0438\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0440\u0435\u0430\u0433\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u2014 insert\/delete\/udapte \u0438\u043b\u0438 \u043d\u0430 \u0432\u0441\u0435 \u0441\u0440\u0430\u0437\u0443<\/p>\n<p>  \u0418\u043c\u044f \u043c\u0435\u0442\u043e\u0434\u0430 \u0433\u0435\u043d\u0435\u0440\u0438\u0442\u0441\u044f \u043f\u043e \u0442\u0430\u043a\u043e\u043c\u0443 \u0448\u0430\u0431\u043b\u043e\u043d\u0443   <\/p>\n<pre><code class=\"java\">\ton&lt;Name&gt;&lt;When&gt;Inserted(ContentValues values){}  \ton&lt;Name&gt;&lt;When&gt;Deleted(Uri uri, String selection, String[] selectionArgs){}  \ton&lt;Name&gt;&lt;When&gt;Updated(Uri uri, ContentValues values, String selection, String[] selectionArg){} <\/code><\/pre>\n<p>  \u0415\u0441\u043b\u0438 \u043d\u0430\u0434\u043e \u043f\u043e\u0432\u0435\u0441\u0438\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0442\u0440\u0438\u0433\u0433\u0435\u0440\u043e\u0432 \u2014 \u044e\u0437\u0430\u0435\u043c \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u044e <i>Triggers<\/i> \u0438 \u043d\u0430\u0431\u0438\u0432\u0430\u0435\u043c \u0435\u0435 \u0442\u0440\u0438\u0433\u0433\u0435\u0440\u0430\u043c\u0438.<\/p>\n<p>  \u041f\u0440\u0438\u043c\u0435\u0440:  <\/p>\n<pre><code class=\"java\">@Table(User.TABLE_NAME) public static interface User{  \t@Trigger(type=Trigger.Type.INSERT, name=&quot;user&quot;, when=When.BEFORE) \t@URI(altNotify={SuggestionView.URI_CONTENT, MessageChatView.URI_CONTENT, ChatListQuery.URI_CONTENT}) \tString URI_CONTENT = &quot;user&quot;; <\/code><\/pre>\n<p>  \u0438 \u0432\u043e\u0442 \u0442\u0430\u043a \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440 \u0432 \u044d\u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 <\/p>\n<pre><code class=\"java\">public class AppProvider extends AppAutoProvider { \t@Override \tprotected void onUserBeforeInserted(ContentValues values) { \t\t................. \t} <\/code><\/pre>\n<h6>\u041a\u0430\u043a \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c notify?<\/h6>\n<p>  \u0415\u0441\u043b\u0438 \u0432\u044b \u0445\u043e\u0442\u0438\u0442\u0435 \u043f\u0440\u043e\u043d\u043e\u0442\u0438\u0444\u0430\u0438\u0442\u044c uri \u0438 \u0432\u0441\u0435 \u0430\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0435, \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043c\u0435\u0442\u043e\u0434 <code>notifyUri(ContentResolver cr, Uri uri)<\/code><\/p>\n<h6>\u041f\u0430\u0447\u043a\u0430 \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043c\u0435\u0442\u043e\u0434 \u0438\u0437 \u043f\u0440\u043e\u0432\u0430\u0439\u0434\u0435\u0440\u0430<\/h6>\n<p>  <code>getContentUri(String path)<\/code> \u2014 \u043f\u043e path \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c URI<br \/>  <code>getContentUriGroupBy(String path, String groupBy)<\/code> \u2014 \u043f\u043e path \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c URI \u0441 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u043e\u0439 \u0433\u0440\u0443\u043f\u043f\u0438\u0440\u043e\u0432\u043a\u0438 <br \/>  <code>getContentUri(String path, long id)<\/code> \u2014 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c URI path\/#<br \/>  <code>getContentUri(String path, String id)<\/code> \u2014 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c URI path\/#<\/p>\n<p>  <code>getContentWithLimitUri(String path, int limit)<\/code> \u2014 path + limit<\/p>\n<p>  <code>getNoNotifyContentUri(String path)<\/code> \u2014 \u043f\u043e path \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c URI \u0431\u0435\u0437 \u043d\u043e\u0442\u0438\u0444\u0430\u044f<br \/>  <code>getNoNotifyContentUri(String path, long id)<\/code> \u2014 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c URI path\/# \u0431\u0435\u0437 \u043d\u043e\u0442\u0438\u0444\u0430\u044f<\/p>\n<p>  <b>P.S.<\/b> \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u043f\u0440\u043e\u0448\u043b\u0430 \u00ab\u0431\u043e\u0435\u0432\u044b\u0435\u00bb \u0438\u0441\u043f\u044b\u0442\u0430\u043d\u0438\u044f \u0438 \u0443\u0436\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0430\u0441\u044c \u0432 \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d \u043f\u0440\u043e\u0435\u043a\u0442\u0430\u0445 <br \/>  <b>P.S.S<\/b> \u0437\u0430 \u0433\u0440\u0430\u043c\u043c\u0430\u0442\u0438\u043a\u0443 \u0438 \u043e\u0440\u0444\u043e\u0433\u0440\u0430\u0444\u0438\u044e \u043f\u0440\u043e\u0448\u0443 \u043d\u0435 \u043f\u0438\u043d\u0430\u0442\u044c    \t \t\t   \t<\/p>\n<div class=\"clear\"><\/div>\n<\/p><\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"http:\/\/habrahabr.ru\/post\/166051\/\"> http:\/\/habrahabr.ru\/post\/166051\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div class=\"content html_format\">   \t\u041d\u0430\u043a\u043e\u043d\u0435\u0446 \u0434\u043e\u0448\u043b\u0438 \u0440\u0443\u043a\u0438 \u043e\u043f\u0438\u0441\u0430\u0442\u044c \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u043e\u0438\u0437\u043e\u0448\u043b\u0438 \u0432 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 <a href=\"https:\/\/github.com\/hamsterksu\/Android-AnnotatedSQL\">AnnotatedSQL<\/a><\/p>\n<p>  \u0410\u043d\u043e\u043d\u0441:<br \/>  1. \u0418\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0432 \u043f\u043b\u0430\u0433\u0438\u043d\u0435<br \/>  2. \u0418\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0432 \u0430\u043d\u043d\u043e\u0442\u0430\u0446\u0438\u044f\u0445 \u0441\u0445\u0435\u043c\u044b <br \/>  3. \u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 content provider \u0432 \u043c\u043e\u0435\u043c \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u0438<br \/>  4. \u0413\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u043c content provider \u043f\u043e \u0441\u0445\u0435\u043c\u0435   <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-166051","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/166051","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=166051"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/166051\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=166051"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=166051"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=166051"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}