{"id":339143,"date":"2022-09-30T09:00:47","date_gmt":"2022-09-30T09:00:47","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=339143"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=339143","title":{"rendered":"<span>Tiny-qORM: \u0440\u0430\u0441\u0441\u043a\u0430\u0437 \u0431\u0435\u0437 \u0441\u0447\u0430\u0441\u0442\u043b\u0438\u0432\u043e\u0433\u043e \u043a\u043e\u043d\u0446\u0430<\/span>"},"content":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-1\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\u0427\u0430\u0449\u0435 \u0432\u0441\u0435\u0433\u043e \u043d\u0430 \u0445\u0430\u0431\u0440\u0435 \u043b\u044e\u0434\u0438 \u0434\u0435\u043b\u044f\u0442\u0441\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f\u043c\u0438 \u0441\u0432\u043e\u0435\u0433\u043e \u0443\u0441\u043f\u0435\u0445\u0430. \u0412\u0440\u043e\u0434\u0435, <i>\u00ab\u0420\u0435\u0431\u044f\u0442\u0430, \u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043b \u0441\u0432\u043e\u044e ORM, \u043a\u0430\u0447\u0430\u0439\u0442\u0435, \u0441\u0442\u0430\u0432\u044c\u0442\u0435 \u043b\u043b\u043e\u0439\u0441\u044b!\u00bb<\/i> \u042d\u0442\u0430 \u0438\u0441\u0442\u043e\u0440\u0438\u044f \u0431\u0443\u0434\u0435\u0442 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0434\u0440\u0443\u0433\u0430\u044f. \u0412 \u043d\u0435\u0439 \u044f \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0443 \u043e \u043d\u0435\u0443\u0441\u043f\u0435\u0445\u0435, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u0447\u0438\u0442\u0430\u044e \u0441\u0432\u043e\u0438\u043c \u0441\u0435\u0440\u044c\u0451\u0437\u043d\u044b\u043c \u0434\u043e\u0441\u0442\u0438\u0436\u0435\u043d\u0438\u0435\u043c. <\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w780q1\/webt\/qa\/9u\/ys\/qa9uyserftbj6r5cn-4rvgjcvty.jpeg\" data-src=\"https:\/\/habrastorage.org\/webt\/qa\/9u\/ys\/qa9uyserftbj6r5cn-4rvgjcvty.jpeg\" data-blurred=\"true\"\/><br \/>  <i>\u041e\u0436\u0438\u0434\u0430\u043d\u0438\u0435 \u2014 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c.<\/i><\/p>\n<p>  \u0418\u0441\u0442\u043e\u0440\u0438\u044f \u043e \u043c\u0435\u0442\u0430\u0442\u0438\u043f\u0430\u0445 Qt, \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u0438 \u0432\u0435\u043b\u043e\u0441\u0438\u043f\u0435\u0434\u043e\u0432, \u043f\u0440\u0435\u0432\u044b\u0448\u0435\u043d\u0438\u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0447\u0438\u0441\u043b\u0430 \u0437\u0430\u043f\u0438\u0441\u0435\u0439 \u0432 \u043e\u0431\u044a\u0435\u043a\u0442\u043d\u043e\u043c \u0444\u0430\u0439\u043b\u0435 \u0438, \u043d\u0435\u043e\u0436\u0438\u0434\u0430\u043d\u043d\u043e, <a href=\"https:\/\/github.com\/iiiCpu\/Tiny-qORM\" rel=\"nofollow noopener noreferrer\">\u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0435, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u0430\u043a, \u043a\u0430\u043a \u0438 \u0431\u044b\u043b\u043e \u0437\u0430\u0434\u0443\u043c\u0430\u043d\u043e<\/a>. <br \/>  <a name=\"habracut\"><\/a><br \/>  \u0421 \u0447\u0435\u0433\u043e \u0432\u0441\u0451 \u043d\u0430\u0447\u0430\u043b\u043e\u0441\u044c? \u041f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u043e, \u0441 \u043b\u0435\u043d\u0438. \u041a\u0430\u043a-\u0442\u043e \u0440\u0430\u0437 \u043f\u043e\u044f\u0432\u0438\u043b\u0430\u0441\u044c \u0437\u0430\u0434\u0430\u0447\u0430 (\u0434\u0435-)\u0441\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440 \u0432 SQL. \u0411\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u0447\u0438\u0441\u043b\u0430 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440, \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u043e\u0442\u0435\u043d. \u0415\u0441\u0442\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u0441 \u0440\u0430\u0437\u043d\u044b\u043c\u0438 \u0443\u0440\u043e\u0432\u043d\u044f\u043c\u0438 \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u043e\u0441\u0442\u0438, \u0441 \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u044f\u043c\u0438 \u0438 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430\u043c\u0438. \u041f\u043e\u043c\u0438\u043c\u043e \u043f\u0440\u043e\u0447\u0435\u0433\u043e, \u0438\u043c\u0435\u043b\u0430\u0441\u044c \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u044e\u0449\u0430\u044f \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u044c: \u0432\u0441\u0435 \u043e\u043d\u0438 \u0443\u0436\u0435 \u0438\u043c\u0435\u043b\u0438 \u043f\u0440\u0438\u0432\u044f\u0437\u043a\u0443 \u043a QJSEngine, \u0442\u043e \u0435\u0441\u0442\u044c \u0438\u043c\u0435\u043b\u0438 \u043f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u0443\u044e \u043c\u0435\u0442\u0430\u0441\u0438\u0441\u0442\u0435\u043c\u0443 Qt. <\/p>\n<p>  \u0421 \u0442\u0430\u043a\u0438\u043c\u0438 \u0432\u0432\u043e\u0434\u043d\u044b\u043c\u0438 \u043d\u0435 \u043c\u0443\u0434\u0440\u0435\u043d\u043e \u0431\u044b\u043b\u043e \u043f\u0440\u0438\u0434\u0442\u0438 \u043a \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044e \u0441\u0432\u043e\u0435\u0439 ORM \u0438 \u043f\u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0432\u0435\u0441\u044c\u043c\u0430 \u0430\u043c\u0431\u0438\u0446\u0438\u043e\u0437\u043d\u044b\u0435 \u0446\u0435\u043b\u0438:<br \/>  1) \u041c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u043c\u043e\u0434\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u043c\u044b\u0445 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440. \u0412 \u043b\u0443\u0447\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u0431\u0435\u0437 \u043e\u043d\u043e\u0439 \u0432\u043e\u043e\u0431\u0449\u0435, \u0432 \u0445\u0443\u0434\u0448\u0435\u043c \u2014 Ctrl+Shift+F.<br \/>  2) \u0420\u0430\u0431\u043e\u0442\u0430 \u0441 \u043b\u044e\u0431\u044b\u043c\u0438 \u0442\u0438\u043f\u0430\u043c\u0438, \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430\u043c\u0438 \u0438 \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u044f\u043c\u0438.<br \/>  3) \u041d\u0435 \u0441\u0430\u043c\u044b\u0435 \u0441\u0442\u0440\u0430\u0448\u043d\u044b\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0441 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c\u044e \u0438\u0445 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0432\u043d\u0435 ORM.<\/p>\n<p>  \u0418 \u043e\u0431\u043e\u0437\u043d\u0430\u0447\u0438\u0442\u044c \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u044b\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f:<br \/>  1) \u0422\u0430\u0431\u043b\u0438\u0446\u044b \u0441\u043e\u0437\u0434\u0430\u044e\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u043a\u043b\u0430\u0441\u0441\u043e\u0432 \u0441 \u043c\u0435\u0442\u0430\u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0435\u0439 (<b>Q_OBJECT<\/b>\\<b>Q_GADGET<\/b>) \u0434\u043b\u044f \u0438\u0445 \u0441\u0432\u043e\u0439\u0441\u0442\u0432 (<b>Q_PROPERTY<\/b>). \u0412\u0441\u0435 \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0432 \u043c\u0435\u0442\u0430\u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u0442\u0438\u043f\u044b, \u043d\u0435 \u0438\u043c\u0435\u044e\u0449\u0438\u0435 \u043c\u0435\u0442\u0430\u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438, \u0431\u0443\u0434\u0443\u0442 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0442\u044c\u0441\u044f \u043b\u0438\u0431\u043e \u0432 \u0432\u0438\u0434\u0435 \u0441\u0442\u0440\u043e\u043a, \u043b\u0438\u0431\u043e \u0432 \u0432\u0438\u0434\u0435 \u0441\u044b\u0440\u044b\u0445 \u0434\u0430\u043d\u043d\u044b\u0445. \u0415\u0441\u043b\u0438 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043d\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0438\u043b\u0438 \u0442\u0438\u043f \u043d\u0435\u0438\u0437\u0432\u0435\u0441\u0442\u0435\u043d, \u043e\u043d \u043f\u0440\u043e\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f.<\/p>\n<p>  \u0417\u0430\u0431\u0435\u0433\u0430\u044f \u0432\u043f\u0435\u0440\u0451\u0434, \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">\u0414\u043e ORM<\/b>                         <\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"cpp\">struct Mom {     Q_GADGET     Q_PROPERTY(QString name MEMBER m_name)     Q_PROPERTY(She is MEMBER m_is) public:     enum She {         Nice,         Sweet,         Beautiful,         Pretty,         Cozy,         Fansy,         Bear     }; Q_ENUM(She) public:     QString m_name;     She m_is;     bool operator !=(Mom const&amp; no) { return m_name != no.m_name; } }; Q_DECLARE_METATYPE(Mom)  struct Car {     Q_GADGET     Q_PROPERTY(double gas MEMBER m_gas) public:     double m_gas; }; Q_DECLARE_METATYPE(Car)  struct Dad {     Q_GADGET     Q_PROPERTY(QString name MEMBER m_name)     Q_PROPERTY(Car * car MEMBER m_car) public:     QString m_name;     Car * m_car = nullptr; \/\/ lost somewhere     bool operator !=(Dad const&amp; no) { return m_name != no.m_name; } }; Q_DECLARE_METATYPE(Dad)  struct Brother {     Q_GADGET     Q_PROPERTY(QString name MEMBER m_name)     Q_PROPERTY(int last_combo MEMBER m_lastCombo)     Q_PROPERTY(int total_punches MEMBER m_totalPunches) public:     QString m_name;     int m_lastCombo;     int m_totalPunches;     bool operator !=(Brother const&amp; no) { return m_name != no.m_name; }     bool operator ==(Brother const&amp; no) { return m_name == no.m_name; } }; Q_DECLARE_METATYPE(Brother)  struct Ur {     Q_GADGET     Q_PROPERTY(QString name MEMBER m_name)     Q_PROPERTY(Mom mom MEMBER m_mama)     Q_PROPERTY(Dad dad MEMBER m_papa)     Q_PROPERTY(QList&lt;Brother> bros MEMBER m_bros)     Q_PROPERTY(QList&lt;int> drows MEMBER m_drows) public:     QString m_name;     Mom m_mama;     Dad m_papa;     QList&lt;Brother> m_bros;     QList&lt;int> m_drows; }; Q_DECLARE_METATYPE(Ur) <\/code><\/pre>\n<p>  <\/p>\n<pre><code class=\"cpp\">bool init() {          qRegisterType&lt;Ur>(\"Ur\");         qRegisterType&lt;Dad>(\"Dad\");         qRegisterType&lt;Mom>(\"Mom\");         qRegisterType&lt;Brother>(\"Brother\");         qRegisterType&lt;Car>(\"Car\"); } bool serialize(QList&lt;Ur> const&amp; urs) {      \/* SQL hell *\/  } <\/code><\/pre>\n<p>  <\/div>\n<\/p><\/div>\n<p>  <\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">\u041f\u043e\u0441\u043b\u0435 ORM<\/b>                         <\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"cpp\">struct Mom {     Q_GADGET     Q_PROPERTY(QString name MEMBER m_name)     Q_PROPERTY(She is MEMBER m_is) public:     enum She {         Nice,         Sweet,         Beautiful,         Pretty,         Cozy,         Fansy,         Bear     }; Q_ENUM(She) public:     QString m_name;     She m_is;     bool operator !=(Mom const&amp; no) { return m_name != no.m_name; } }; ORM_DECLARE_METATYPE(Mom)  struct Car {     Q_GADGET     Q_PROPERTY(double gas MEMBER m_gas) public:     double m_gas; }; ORM_DECLARE_METATYPE(Car)  struct Dad {     Q_GADGET     Q_PROPERTY(QString name MEMBER m_name)     Q_PROPERTY(Car * car MEMBER m_car) public:     QString m_name;     Car * m_car = nullptr; \/\/ lost somewhere     bool operator !=(Dad const&amp; no) { return m_name != no.m_name; } }; ORM_DECLARE_METATYPE(Dad)  struct Brother {     Q_GADGET     Q_PROPERTY(QString name MEMBER m_name)     Q_PROPERTY(int last_combo MEMBER m_lastCombo)     Q_PROPERTY(int total_punches MEMBER m_totalPunches) public:     QString m_name;     int m_lastCombo;     int m_totalPunches;     bool operator !=(Brother const&amp; no) { return m_name != no.m_name; }     bool operator ==(Brother const&amp; no) { return m_name == no.m_name; } }; ORM_DECLARE_METATYPE(Brother)  struct Ur {     Q_GADGET     Q_PROPERTY(QString name MEMBER m_name)     Q_PROPERTY(Mom mom MEMBER m_mama)     Q_PROPERTY(Dad dad MEMBER m_papa)     Q_PROPERTY(QList&lt;Brother> bros MEMBER m_bros)     Q_PROPERTY(QList&lt;int> drows MEMBER m_drows) public:     QString m_name;     Mom m_mama;     Dad m_papa;     QList&lt;Brother> m_bros;     QList&lt;int> m_drows; }; ORM_DECLARE_METATYPE(Ur) <\/code><\/pre>\n<p>  <\/p>\n<pre><code class=\"cpp\">bool init() {          ormRegisterType&lt;Ur>(\"Ur\");         ormRegisterType&lt;Dad>(\"Dad\");         ormRegisterType&lt;Mom>(\"Mom\");         ormRegisterType&lt;Brother>(\"Brother\");         ormRegisterType&lt;Car>(\"Car\"); } bool serialize(QList&lt;Ur> const&amp; urs) {           ORM orm;          orm.create&lt;Ur>(); \/\/ if not exists          orm.insert(urs); } <\/code><\/pre>\n<p>  <\/div>\n<\/p><\/div>\n<p>  <\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">Diff<\/b>                         <\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"plaintext\">        Q_DECLARE_METATYPE(Mom)     -> ORM_DECLARE_METATYPE(Mom)         Q_DECLARE_METATYPE(Car)     -> ORM_DECLARE_METATYPE(Car)         Q_DECLARE_METATYPE(Dad)     -> ORM_DECLARE_METATYPE(Dad)         Q_DECLARE_METATYPE(Brother) -> ORM_DECLARE_METATYPE(Brother)         Q_DECLARE_METATYPE(Ur)      -> ORM_DECLARE_METATYPE(Ur)          qRegisterType&lt;Ur>(\"Ur\");         -> ormRegisterType&lt;Ur>(\"Ur\");         qRegisterType&lt;Dad>(\"Dad\");        -> ormRegisterType&lt;Dad>(\"Ur\");         qRegisterType&lt;Mom>(\"Mom\");        -> ormRegisterType&lt;Mom>(\"Ur\");         qRegisterType&lt;Brother>(\"Brother\");-> ormRegisterType&lt;Brother>(\"Ur\");         qRegisterType&lt;Car>(\"Car\");        -> ormRegisterType&lt;Car>(\"Ur\");           \/* sql hell *\/ -> ORM orm;                            orm.create&lt;Ur>(); \/\/ if not exists                            orm.insert(urs); <\/code><\/pre>\n<p>  <\/div>\n<\/p><\/div>\n<h2>Making of&#8230;<\/h2>\n<p>  <\/p>\n<h3>\u0428\u0430\u0433 1. \u041f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u043c\u0435\u0442\u0430\u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e, \u0441\u043f\u0438\u0441\u043e\u043a \u043f\u043e\u043b\u0435\u0439 \u043a\u043b\u0430\u0441\u0441\u0430 \u0438 \u0438\u0445 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f.<\/h3>\n<p>  \u0421\u043f\u0430\u0441\u0438\u0431\u043e \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430\u043c Qt, \u043c\u044b \u044d\u0442\u043e \u043c\u043e\u0436\u0435\u043c \u0434\u0435\u043b\u0430\u0442\u044c \u043f\u043e \u0449\u0435\u043b\u0447\u043a\u0443 \u043f\u0430\u043b\u044c\u0446\u0435\u0432 \u0438 id \u043c\u0435\u0442\u0430\u043a\u043b\u0430\u0441\u0441\u0430. \u0412\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u044d\u0442\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a:<\/p>\n<pre><code class=\"cpp\">const QMetaObject * object = QMetaType::metaObjectForType(id); if (object) {     for (int i = 0; i &lt; object->propertyCount(); ++i) {         QMetaProperty property = object->property(i);         columns &lt;&lt; property.name();         types &lt;&lt; property.userType();     } }<\/code><\/pre>\n<p>  \u0427\u0442\u0435\u043d\u0438\u0435 \u0438 \u0437\u0430\u043f\u0438\u0441\u044c \u0442\u0430\u043a \u0436\u0435 \u043d\u0435 \u0432\u044b\u0437\u044b\u0432\u0430\u044e\u0442 \u043f\u0440\u043e\u0431\u043b\u0435\u043c. \u041f\u043e\u0447\u0442\u0438. <b>QMetaProperty<\/b> \u0438\u043c\u0435\u0435\u0442 \u043f\u0430\u0440\u0443 \u043c\u0435\u0442\u043e\u0434\u043e\u0432 \u0447\u0442\u0435\u043d\u0438\u044f-\u0437\u0430\u043f\u0438\u0441\u0438 \u0434\u043b\u044f \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432. \u0418 \u0435\u0449\u0451 \u043e\u0434\u043d\u0443 \u043f\u0430\u0440\u0443 \u0434\u043b\u044f \u0433\u0430\u0434\u0436\u0435\u0442\u043e\u0432. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0430 \u044d\u0442\u0430\u043f\u0435 \u0447\u0442\u0435\u043d\u0438\u044f-\u0437\u0430\u043f\u0438\u0441\u0438 \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c\u0441\u044f, \u0432 \u043a\u043e\u0433\u043e \u043c\u044b \u043f\u0438\u0448\u0435\u043c. \u0414\u0435\u043b\u0430\u0435\u0442\u0441\u044f \u044d\u0442\u043e \u0442\u0430\u043a:<\/p>\n<pre><code class=\"cpp\">bool isQObject(QMetaObject const&amp; meta) {     return meta.inherits(QMetaType::metaObjectForType(QMetaType::QObjectStar)); }<\/code><\/pre>\n<p>  \u0422\u043e\u0433\u0434\u0430 \u0447\u0442\u0435\u043d\u0438\u0435 \u0438 \u0437\u0430\u043f\u0438\u0441\u044c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u044f\u0442\u0441\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<\/p>\n<pre><code class=\"cpp\">inline bool write(bool isQObject, QVariant &amp; writeInto,                    QMetaProperty property, QVariant const&amp; value) {     if (isQObject) return property.write(writeInto.value&lt;QObject*>(), value);     else return property.writeOnGadget(writeInto.data(), value); }  inline QVariant read(bool isQObject, QVariant const&amp; readFrom,                       QMetaProperty property) {     if (isQObject) {         QObject * object = readFrom.value&lt;QObject*>();         return property.read(object);     }     else {         return property.readOnGadget(readFrom.value&lt;void*>());     } }<\/code><\/pre>\n<p>  \u041a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u0431\u044b, readOnGadget, \u0432 \u043a\u043e\u043d\u0446\u0435 \u043a\u043e\u043d\u0446\u043e\u0432, \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 \u0442\u043e\u0442 \u0436\u0435 read, \u0442\u0430\u043a \u0447\u0442\u043e \u0437\u0430\u0447\u0435\u043c \u0433\u043e\u0440\u043e\u0434\u0438\u0442\u044c \u0432\u0435\u0441\u044c \u044d\u0442\u043e\u0442 \u043a\u043e\u0434? \u0421\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u044c \u0438 \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0438\u0435 \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0439, \u0447\u0442\u043e \u0442\u0430\u043a\u043e\u0435 \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u0441\u044f.<\/p>\n<p>  \u0418 \u0435\u0449\u0451 \u043e\u0434\u0438\u043d \u043d\u044e\u0430\u043d\u0441. \u041f\u0440\u0438 \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0438 <b>Q_ENUM<\/b> \u0432 <b>QVariant<\/b> \u0435\u0433\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043a\u0430\u0441\u0442\u0443\u0435\u0442\u0441\u044f \u0432 <b>int<\/b>. \u0412 \u0431\u0430\u0437\u0443 \u0434\u0430\u043d\u043d\u044b\u0445 \u0442\u043e\u0436\u0435 \u043f\u043e\u0441\u0442\u0443\u043f\u0430\u0435\u0442 <b>int<\/b>. \u041d\u043e \u0437\u0430\u043f\u0438\u0441\u0430\u0442\u044c <b>int<\/b> \u0432 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e \u0442\u0438\u043f\u0430 <b>Q_ENUM<\/b> \u043c\u044b \u043d\u0435 \u043c\u043e\u0436\u0435\u043c. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043f\u0435\u0440\u0435\u0434 \u0437\u0430\u043f\u0438\u0441\u044c\u044e \u043c\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c, \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043b\u0438 \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u0435 \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e \u043f\u0435\u0440\u0435\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0435\u043c \u2014 \u0438 \u0432\u044b\u0437\u0432\u0430\u0442\u044c \u044f\u0432\u043d\u043e\u0435 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0432 \u0442\u0430\u043a\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435. \u0417\u0432\u0443\u0447\u0438\u0442 \u0441\u0442\u0440\u0430\u0448\u043d\u0435\u0435, \u0447\u0435\u043c \u0435\u0441\u0442\u044c \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435.<\/p>\n<pre><code class=\"cpp\">if (property.isEnumType()) {    variant.convert(property.userType()); }<\/code><\/pre>\n<h3>\u0428\u0430\u0433 2. \u0421\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u044b\u0435 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u043f\u043e \u043c\u0435\u0442\u0430\u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438.<\/h3>\n<p>  \u0421\u043d\u043e\u0432\u0430 \u0431\u044c\u0451\u043c \u0447\u0435\u043b\u043e\u043c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430\u043c \u0437\u0430 \u043a\u043b\u0430\u0441\u0441 <b>QVariant<\/b> \u0438 \u0435\u0433\u043e \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440 <b>QVariant(int id, void* copy)<\/b>. \u0421 \u0435\u0433\u043e \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043c\u043e\u0436\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043b\u044e\u0431\u0443\u044e \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 \u0441 \u043f\u0443\u0441\u0442\u044b\u043c \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440\u043e\u043c \u2014 \u0438 \u044d\u0442\u043e \u0445\u043e\u0440\u043e\u0448\u0430\u044f \u043d\u043e\u0432\u043e\u0441\u0442\u044c. \u041f\u043b\u043e\u0445\u0430\u044f \u043d\u043e\u0432\u043e\u0441\u0442\u044c: \u043d\u0430\u0441\u043b\u0435\u0434\u043d\u0438\u043a\u0438 <b>QObject<\/b> \u0432 \u0441\u043f\u0438\u0441\u043e\u043a \u043d\u0435 \u0432\u0445\u043e\u0434\u044f\u0442. \u0425\u043e\u0440\u043e\u0448\u0430\u044f \u043d\u043e\u0432\u043e\u0441\u0442\u044c: \u0438\u0445 \u043c\u043e\u0436\u043d\u043e \u0434\u0435\u043b\u0430\u0442\u044c \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e <b>QMetaObject::newInstance()<\/b>. <\/p>\n<p>  \u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0430 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u043e\u0433\u043e \u0442\u0438\u043f\u0430 \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a:<\/p>\n<pre><code class=\"cpp\">QVariant make_variant(QMetaObject const&amp; meta) {     QVariant variant;     if (isQObject(meta)) {         QObject * obj = meta.newInstance();         if (obj) {             obj->setObjectName(\"orm_made\");             obj->setParent(QCoreApplication::instance());             variant = QVariant::fromValue(obj);         }     }     else {         variant = QVariant((classtype), nullptr);     }     if (!variant.isValid()){         qWarning() &lt;&lt; \"Unable to create instance of type \" &lt;&lt; meta.className();     }     if (isQObject(meta) &amp;&amp; variant.value&lt;QObject*>() == nullptr) {         qWarning() &lt;&lt; \"Unable to create instance of QObject \" &lt;&lt; meta.className();     }     return variant; }<\/code><\/pre>\n<h3>\u0428\u0430\u0433 3. \u0420\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044e \u0442\u0440\u0438\u0432\u0438\u0430\u043b\u044c\u043d\u044b\u0445 \u0442\u0438\u043f\u043e\u0432.<\/h3>\n<p>  \u041f\u043e\u0434 \u0442\u0440\u0438\u0432\u0438\u0430\u043b\u044c\u043d\u044b\u043c\u0438 \u0442\u0438\u043f\u0430\u043c\u0438 \u0431\u0443\u0434\u0435\u043c \u043f\u043e\u043d\u0438\u043c\u0430\u0442\u044c \u0447\u0438\u0441\u043b\u0430, \u0441\u0442\u0440\u043e\u043a\u0438 \u0438 \u0431\u0438\u043d\u0430\u0440\u043d\u044b\u0435 \u043f\u043e\u043b\u044f. \u0412\u0440\u043e\u0434\u0435 \u0431\u044b \u0437\u0430\u0434\u0430\u0447\u0430 \u043f\u0440\u043e\u0441\u0442\u0430\u044f, \u0441\u043d\u043e\u0432\u0430 \u0431\u0435\u0440\u0451\u043c <b>QVariant<\/b> \u0438 \u0432 \u0431\u043e\u0439. \u041d\u043e \u0435\u0441\u0442\u044c \u043d\u044e\u0430\u043d\u0441. \u0412 \u0440\u044f\u0434\u0435 \u0441\u043b\u0443\u0447\u0430\u0435\u0432 \u043d\u0430\u043c \u043c\u043e\u0436\u0435\u0442 \u0437\u0430\u0445\u043e\u0442\u0435\u0442\u044c\u0441\u044f \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u00ab\u0442\u0440\u0438\u0432\u0438\u0430\u043b\u044c\u043d\u044b\u043c\u0438\u00bb \u0438\u043d\u044b\u0435 \u0442\u0438\u043f\u044b, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435. \u0421 \u043e\u0434\u043d\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0431\u044b \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0442\u044c, \u0435\u0441\u0442\u044c \u043b\u0438 \u0443 \u043c\u0435\u0442\u0430\u0442\u0438\u043f\u0430 \u043d\u0443\u0436\u043d\u044b\u0435 \u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0435\u0440\u044b \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0438\u0445. \u041d\u043e \u044d\u0442\u043e \u043d\u0435 \u0441\u0430\u043c\u044b\u0439 \u0443\u0434\u0430\u0447\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431, \u0442\u0435\u043c \u0431\u043e\u043b\u0435\u0435, \u0447\u0442\u043e \u043e\u043d \u0447\u0440\u0435\u0432\u0430\u0442 \u0432\u043e\u0437\u043d\u0438\u043a\u043d\u043e\u0432\u0435\u043d\u0438\u0435\u043c \u043a\u043e\u043d\u0444\u043b\u0438\u043a\u0442\u043e\u0432, \u0442\u0430\u043a \u0447\u0442\u043e \u043b\u0443\u0447\u0448\u0435 \u0438\u043c\u0435\u0442\u044c \u0441\u043f\u0438\u0441\u043a\u0438 \u0442\u0438\u043f\u043e\u0432 \u0438 \u0441\u043f\u043e\u0441\u043e\u0431\u044b \u0438\u0445 \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f: \u0432 \u0441\u0442\u0440\u043e\u043a\u0443, \u0432 BLOB \u0438\u043b\u0438 \u043e\u0442\u0434\u0430\u0442\u044c \u043d\u0430 \u043e\u0442\u043a\u0443\u043f Qt. \u041d\u0430 \u044d\u0442\u043e\u043c \u0436\u0435 \u0448\u0430\u0433\u0435 \u043b\u0443\u0447\u0448\u0435 \u0437\u0430\u0438\u043c\u0435\u0442\u044c \u0441\u043f\u0438\u0441\u043e\u043a \u0442\u0435\u0445 \u0442\u0438\u043f\u043e\u0432, \u0441 \u043a\u043e\u0442\u043e\u0440\u044b\u043c\u0438 \u0432\u044b \u043f\u0440\u0435\u0434\u043f\u043e\u0447\u0442\u0451\u0442\u0435 \u043d\u0435 \u0441\u0432\u044f\u0437\u044b\u0432\u0430\u0442\u044c\u0441\u044f. \u0418\u0437 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0445 \u044d\u0442\u043e \u043c\u043e\u0433\u0443\u0442 \u0431\u044b\u0442\u044c JSON-\u043e\u0431\u044a\u0435\u043a\u0442\u044b \u0438\u043b\u0438 <b>QModelIndex<\/b>. \u041e\u043f\u044f\u0442\u044c \u0436\u0435, \u043d\u0438\u043a\u0430\u043a\u043e\u0439 \u043c\u0430\u0433\u0438\u0438, \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0441\u043f\u0438\u0441\u043a\u0438.<\/p>\n<h3>\u0428\u0430\u0433 4. \u0420\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044e \u043d\u0435\u0442\u0440\u0438\u0432\u0438\u0430\u043b\u044c\u043d\u044b\u0445 \u0442\u0438\u043f\u043e\u0432: \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440, \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u0435\u0439, \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u043e\u0432.<\/h3>\n<p>  \u0418 \u043e\u043f\u044f\u0442\u044c, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u043f\u043e\u0441\u0442\u0430\u0440\u0430\u043b\u0438\u0441\u044c: \u0438\u0445 QVariant \u0440\u0435\u0448\u0430\u0435\u0442 \u044d\u0442\u0443 \u0437\u0430\u0434\u0430\u0447\u0443. \u0418\u043b\u0438 \u043d\u0435\u0442?<\/p>\n<p>  <b>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 1: \u0441\u0432\u044f\u0437\u043d\u043e\u0441\u0442\u044c \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u044f \u0438 \u0442\u0438\u043f\u0430, \u0448\u0430\u0431\u043b\u043e\u043d\u0430 \u0438 \u0442\u0438\u043f\u043e\u0432-\u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432.<\/b><\/p>\n<p>  \u0414\u043b\u044f \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u043e\u0433\u043e \u043c\u0435\u0442\u0430\u043a\u043b\u0430\u0441\u0441\u0430 \u043d\u0435\u043b\u044c\u0437\u044f \u043d\u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0441\u0432\u044f\u0437\u043d\u044b\u0435 \u0441 \u043d\u0438\u043c \u043c\u0435\u0442\u0430\u043a\u043b\u0430\u0441\u0441\u044b \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u0435\u0439 (\u0438\u043b\u0438 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b), \u043d\u0438 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0442\u0438\u043f, \u0445\u0440\u0430\u043d\u0438\u043c\u044b\u0439 \u0432 \u0448\u0430\u0431\u043b\u043e\u043d\u0435. \u042d\u0442\u043e \u043e\u0447\u0435\u043d\u044c \u043f\u0435\u0447\u0430\u043b\u044c\u043d\u043e, \u0445\u043e\u0442\u044f \u0438 \u0432\u043f\u043e\u043b\u043d\u0435 \u043f\u0440\u0435\u0434\u0441\u043a\u0430\u0437\u0443\u0435\u043c\u043e. \u041e\u0442\u043a\u0443\u0434\u0430 \u0435\u0439 \u0432\u0437\u044f\u0442\u044c\u0441\u044f? <\/p>\n<p>  \u041d\u0435\u043e\u0442\u043a\u0443\u0434\u0430.<\/p>\n<p>  \u041c\u043e\u0436\u043d\u043e, \u043a\u043e\u043d\u0435\u0447\u043d\u043e, \u043f\u043e\u0438\u0433\u0440\u0430\u0442\u044c\u0441\u044f \u0441 \u0438\u043c\u0435\u043d\u0435\u043c \u043a\u043b\u0430\u0441\u0441\u0430, \u043f\u043e\u0449\u0435\u043a\u043e\u0442\u0430\u0432 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0448\u0430\u0431\u043b\u043e\u043d\u043e\u0432, \u043d\u043e \u044d\u0442\u043e \u043e\u0447\u0435\u043d\u044c \u043d\u0435\u0436\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043b\u043e\u043c\u0430\u0435\u0442\u0441\u044f \u043e \u0433\u0440\u0443\u0431\u0443\u044e \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c <b>typedef<\/b>. \u0427\u0442\u043e \u0436\u0435, \u0438\u043d\u043e\u0433\u043e \u043d\u0435 \u043e\u0441\u0442\u0430\u0451\u0442\u0441\u044f, \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u0437\u0430\u0432\u0435\u0441\u0442\u0438 \u0441\u0432\u043e\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0434\u043b\u044f \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438 \u0442\u0438\u043f\u043e\u0432.<\/p>\n<pre><code class=\"cpp\">template &lt;typename T> int orm::Register(const char * c) {             int type = qMetaTypeId&lt;T>();             if (!type) {                 if (c) {                     type = qRegisterMetaType&lt;T>(c);                 }                 else {                     type = qRegisterMetaType&lt;T>();                 }             }             Config::addPointerStub(orm::Pointers::registerTypePointers&lt;T>());             orm::Containers::registerSequentialContainers&lt;T>();             return type; }<\/code><\/pre>\n<p>  \u0410 \u0432\u043c\u0435\u0441\u0442\u0435 \u0441 \u043d\u0435\u0439 \u0438 \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043c\u0430\u0441\u0441\u0438\u0432\u0447\u0438\u043a \u043f\u043e\u0434 \u044d\u0442\u043e \u0434\u0435\u043b\u043e. \u0422\u043e\u0447\u043d\u0435\u0435, <b>QMap<\/b>, \u0433\u0434\u0435 \u043a\u043b\u044e\u0447\u043e\u043c \u0431\u0443\u0434\u0435\u0442 <b>id<\/b> \u043c\u0435\u0442\u0430\u043a\u043b\u0430\u0441\u0441\u0430, \u0430 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c \u2014 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430, \u0445\u0440\u0430\u043d\u044f\u0449\u0430\u044f \u0432\u0441\u0435 \u0441\u0432\u044f\u0437\u043d\u044b\u0435 \u0442\u0438\u043f\u044b. <\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">\u0412\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u044d\u0442\u043e, \u043a\u043e\u043d\u0435\u0447\u043d\u043e, \u043f\u043e\u0448\u043b\u043e\u0432\u0430\u0442\u043e, \u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442.<\/b>                         <\/p>\n<div class=\"spoiler_text\">\u0421\u0435\u0440\u044c\u0451\u0437\u043d\u043e, \u0432\u044b \u0432\u0440\u044f\u0434 \u043b\u0438 \u0442\u0443\u0442 \u043d\u0430\u0439\u0434\u0451\u0442\u0435 \u0447\u0442\u043e-\u043d\u0438\u0431\u0443\u0434\u044c \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0438\u0430\u043b\u044c\u043d\u043e \u043d\u043e\u0432\u043e\u0435.<\/p>\n<pre><code class=\"cpp\">\/\/ &lt;h> struct ORMPointerStub {     int T =0;  \/\/ T     int pT=0; \/\/ T*     int ST=0; \/\/ QSharedPointer&lt;T>     int WT=0; \/\/ QWeakPointer&lt;T>     int sT=0; \/\/ std::shared_ptr&lt;T>     int wT=0; \/\/ std::weak_ptr&lt;T> }; \/\/ &lt;cpp> static QMap&lt;int, orm_pointers::ORMPointerStub> pointerMap; void ORM_Config::addPointerStub(const orm_pointers::ORMPointerStub &amp; stub) {     if (stub. T) pointerMap[stub. T] = stub;     if (stub.pT) pointerMap[stub.pT] = stub;     if (stub.ST) pointerMap[stub.ST] = stub;     if (stub.WT) pointerMap[stub.WT] = stub;     if (stub.sT) pointerMap[stub.sT] = stub;     if (stub.wT) pointerMap[stub.wT] = stub; } \/\/ &lt;h> template &lt;typename T> void* toVPointer (                T  const&amp; t)     { return reinterpret_cast&lt;void*>(const_cast&lt;T*>(&amp;t       )); } template &lt;typename T> void* toVPointerP(                T *       t)     { return reinterpret_cast&lt;void*>(                t        ); } template &lt;typename T> void* toVPointerS(QSharedPointer &lt;T> const&amp; t)     { return reinterpret_cast&lt;void*>(const_cast&lt;T*>( t.data())); } template &lt;typename T> void* toVPointers(std::shared_ptr&lt;T> const&amp; t)     { return reinterpret_cast&lt;void*>(const_cast&lt;T*>( t.get ())); }  template &lt;typename T> T* fromVoidP(void* t)     { return                    reinterpret_cast&lt;T*>(t) ; } template &lt;typename T> QSharedPointer &lt;T> fromVoidS(void* t)     { return QSharedPointer &lt;T>(reinterpret_cast&lt;T*>(t)); } template &lt;typename T> std::shared_ptr&lt;T> fromVoids(void* t)     { return std::shared_ptr&lt;T>(reinterpret_cast&lt;T*>(t)); }  template &lt;typename T> ORMPointerStub registerTypePointersEx() {     ORMPointerStub stub;     stub.T = qMetaTypeId&lt;T>();     stub.pT = qRegisterMetaType&lt;T*>();     stub.ST = qRegisterMetaType&lt;QSharedPointer &lt;T>>();     stub.WT = qRegisterMetaType&lt;QWeakPointer   &lt;T>>();     stub.sT = qRegisterMetaType&lt;std::shared_ptr&lt;T>>();     stub.wT = qRegisterMetaType&lt;std::weak_ptr  &lt;T>>();      QMetaType::registerConverter&lt;                T , void*>(&amp;toVPointer &lt;T>);     QMetaType::registerConverter&lt;                T*, void*>(&amp;toVPointerP&lt;T>);     QMetaType::registerConverter&lt;QSharedPointer &lt;T>, void*>(&amp;toVPointerS&lt;T>);     QMetaType::registerConverter&lt;std::shared_ptr&lt;T>, void*>(&amp;toVPointers&lt;T>);      QMetaType::registerConverter&lt;void*,                 T*>(&amp;fromVoidP&lt;T>);     QMetaType::registerConverter&lt;void*, QSharedPointer &lt;T>>(&amp;fromVoidS&lt;T>);     QMetaType::registerConverter&lt;void*, std::shared_ptr&lt;T>>(&amp;fromVoids&lt;T>);     return stub; }<\/code><\/pre>\n<p>  \u041a\u0430\u043a \u0432\u044b \u043c\u043e\u0433\u043b\u0438 \u0437\u0430\u043c\u0435\u0442\u0438\u0442\u044c, \u0442\u0443\u0442 \u0443\u0436\u0435 \u0431\u044b\u043b\u0438 \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u044b \u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0435\u0440\u044b <b>T<\/b>><b>void*<\/b>, <b>T*<\/b>><b>void*<\/b> \u0438 <b>void*<\/b>><b>T*<\/b>. \u041d\u0438\u0447\u0435\u0433\u043e \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0433\u043e, \u043e\u043d\u0438 \u043d\u0430\u043c \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u044e\u0442\u0441\u044f \u0434\u043b\u044f \u0441\u043f\u043e\u043a\u043e\u0439\u043d\u043e\u0439 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 <b>QMetaProperty<\/b>, \u0442\u0430\u043a \u043a\u0430\u043a \u0432 <i>select<\/i>, \u0433\u0434\u0435 \u0431\u0443\u0434\u0443\u0442 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c\u0441\u044f \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b, \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0434\u0435\u043b\u0430\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u044b\u0435 \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u0438, \u0430 \u043f\u0435\u0440\u0435\u0434\u0430\u0432\u0430\u0442\u044c \u0432\u043e\u043e\u0431\u0449\u0435 \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u044b\u0439 <b>void*<\/b>. \u041d\u0443\u0436\u043d\u044b\u0439 \u0442\u0438\u043f \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u044f \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u0437\u0434\u0430\u043d \u0441\u0430\u043c\u0438\u043c <b>QVariant<\/b> \u0432 \u043c\u043e\u043c\u0435\u043d\u0442 \u0437\u0430\u043f\u0438\u0441\u0438.  <\/div>\n<\/p><\/div>\n<p>  <b>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 2: \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u043e\u0432.<\/b><\/p>\n<p>  \u0421 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430\u043c\u0438 \u043d\u0435 \u0432\u0441\u0451 \u0442\u0430\u043a \u043f\u043b\u043e\u0445\u043e. \u0414\u043b\u044f \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u0435\u0441\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u043f\u043e\u0441\u043e\u0431 \u0443\u0437\u043d\u0430\u0442\u044c, \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043b\u0438 \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u043d\u044b\u0439 \u043d\u0430\u043c \u0442\u0438\u043f \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u043c:<\/p>\n<pre><code class=\"cpp\">bool isSequentialContainer(int metaTypeID){     return QMetaType::hasRegisteredConverterFunction(metaTypeID,                  qMetaTypeId&lt;QtMetaTypePrivate::QSequentialIterableImpl>()); }<\/code><\/pre>\n<p>\u041f\u0440\u043e\u0431\u0435\u0436\u0430\u0442\u044c\u0441\u044f \u043f\u043e \u043d\u0435\u043c\u0443:<\/p>\n<pre><code class=\"cpp\">QSequentialIterable sequentialIterable = myList.value&lt;QSequentialIterable>(); for (QVariant variant : sequentialIterable) {     \/\/ do stuff }<\/code><\/pre>\n<p>  \u0418 \u0434\u0430\u0436\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c ID \u0445\u0440\u0430\u043d\u0438\u043c\u043e\u0433\u043e \u043c\u0435\u0442\u0430\u0442\u0438\u043f\u0430 (\u043e\u0441\u0442\u043e\u0440\u043e\u0436\u043d\u043e \u2014 \u0433\u043b\u0430\u0437\u0430!)<\/p>\n<pre><code class=\"cpp\">inline int getSequentialContainerStoredType(int metaTypeID) {     return (*(QVariant(static_cast&lt;QVariant::Type>(metaTypeID))                 .value&lt;QSequentialIterable>()).end()).userType(); \/\/ \u0434\u0430, .end()).userType(); \/\/ \u043c\u043d\u0435 \u0441\u0442\u044b\u0434\u043d\u043e, \u0445\u043e\u0440\u043e\u0448\u043e? }<\/code><\/pre>\n<p>  \u0422\u0430\u043a \u0447\u0442\u043e \u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0445 \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0434\u0435\u043b\u043e\u043c \u0447\u0438\u0441\u0442\u043e \u0442\u0435\u0445\u043d\u0438\u0447\u0435\u0441\u043a\u0438\u043c. \u041e\u0441\u0442\u0430\u0451\u0442\u0441\u044f \u043b\u0438\u0448\u044c \u0441\u043f\u0440\u0430\u0432\u0438\u0442\u044c\u0441\u044f \u0441\u043e \u0432\u0441\u0435\u043c \u043c\u043d\u043e\u0433\u043e\u043e\u0431\u0440\u0430\u0437\u0438\u0435\u043c \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u043e\u0432. \u041c\u043e\u044f \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u0442\u0440\u0430\u0433\u0438\u0432\u0430\u0435\u0442 \u043b\u0438\u0448\u044c \u0442\u0435, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u043a\u0430\u0441\u0442\u0430\u043c\u0438 \u0438\u0437 <b>QList<\/b>. \u0412\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, \u043f\u043e\u0442\u043e\u043c\u0443, \u0447\u0442\u043e \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u043c <b>QSqlQuery<\/b> \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f <b>QVariantList<\/b>, \u0430, \u0432\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, \u043f\u043e\u0442\u043e\u043c\u0443, \u0447\u0442\u043e \u043e\u043d \u043c\u043e\u0436\u0435\u0442 \u043a\u0430\u0441\u0442\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0432\u043e \u0432\u0441\u0435 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 Qt \u0438 std \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u044b. (\u0415\u0441\u0442\u044c \u0438 \u0442\u0440\u0435\u0442\u044c\u044f \u043f\u0440\u0438\u0447\u0438\u043d\u0430, \u0448\u0430\u0431\u043b\u043e\u043d\u043d\u0430\u044f \u043c\u0430\u0433\u0438\u044f std \u043f\u043b\u043e\u0445\u043e \u0432\u043f\u0438\u0445\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0432 \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u044b\u0435 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u044f.)<\/p>\n<pre><code class=\"cpp\">template &lt;typename T> QList&lt;T> qListFromQVariantList(QVariant const&amp; variantList) {     QList&lt;T> list;     QSequentialIterable sequentialIterable = variantList.value&lt;QSequentialIterable>();     for (QVariant const&amp; variant : sequentialIterable) {         if(v.canConvert&lt;T>()) {             list &lt;&lt; variant.value&lt;T>();         }     }     return list; } template &lt;typename T> QVector    &lt;T>   qVectorFromQVariantList(QVariant const&amp; v)      { return qListFromQVariantList&lt;T>(v).toVector              (); } template &lt;typename T> std::list  &lt;T>   stdListFromQVariantList(QVariant const&amp; v)      { return qListFromQVariantList&lt;T>(v).toStdList             (); } template &lt;typename T> std::vector&lt;T> stdVectorFromQVariantList(QVariant const&amp; v)      { return qListFromQVariantList&lt;T>(v).toVector().toStdVector(); }  template &lt;typename T> void registerTypeSequentialContainers() {     qMetaTypeId&lt;QList      &lt;T>>() ? qMetaTypeId&lt;QList      &lt;T>>()                                    : qRegisterMetaType&lt;QList      &lt;T>>();     qMetaTypeId&lt;QVector    &lt;T>>() ? qMetaTypeId&lt;QVector    &lt;T>>()                                    : qRegisterMetaType&lt;QVector    &lt;T>>();     qMetaTypeId&lt;std::list  &lt;T>>() ? qMetaTypeId&lt;std::list  &lt;T>>()                                    : qRegisterMetaType&lt;std::list  &lt;T>>();     qMetaTypeId&lt;std::vector&lt;T>>() ? qMetaTypeId&lt;std::vector&lt;T>>()                                    : qRegisterMetaType&lt;std::vector&lt;T>>();     QMetaType::registerConverter&lt;QVariantList, QList      &lt;T>>(&amp;(    qListFromQVariantList&lt;T>));     QMetaType::registerConverter&lt;QVariantList, QVector    &lt;T>>(&amp;(  qVectorFromQVariantList&lt;T>));     QMetaType::registerConverter&lt;QVariantList, std::list  &lt;T>>(&amp;(  stdListFromQVariantList&lt;T>));     QMetaType::registerConverter&lt;QVariantList, std::vector&lt;T>>(&amp;(stdVectorFromQVariantList&lt;T>)); }<\/code><\/pre>\n<p>  \u0421 \u0430\u0441\u0441\u043e\u0446\u0438\u0430\u0442\u0438\u0432\u043d\u044b\u043c\u0438 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430\u043c\u0438 \u0438 \u043f\u0430\u0440\u0430\u043c\u0438 \u0434\u0435\u043b\u0430 \u043e\u0431\u0441\u0442\u043e\u044f\u0442 \u0445\u0443\u0436\u0435. \u041d\u0435\u0441\u043c\u043e\u0442\u0440\u044f \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u0434\u043b\u044f \u043d\u0438\u0445 \u0435\u0441\u0442\u044c \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u044b\u0439 \u043f\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0441 <b>QSequentialIterable<\/b> \u043a\u043b\u0430\u0441\u0441 <b>QAssociativeIterable<\/b>, \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u0438 \u0435\u0433\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u0440\u0438\u0432\u043e\u0434\u044f\u0442 \u043a \u0432\u044b\u043b\u0435\u0442\u0430\u043c \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u044b. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0430\u0441 \u0441\u043d\u043e\u0432\u0430 \u043e\u0436\u0438\u0434\u0430\u044e\u0442 \u0441\u0442\u0430\u0440\u044b\u0435 \u0434\u0440\u0443\u0437\u044c\u044f: \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0438 \u0441\u0442\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043c\u0430\u0441\u0441\u0438\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0443\u0436\u043d\u044b \u0434\u043b\u044f \u0432\u044b\u044f\u0441\u043d\u0435\u043d\u0438\u044f \u0445\u0440\u0430\u043d\u0438\u0432\u0448\u0435\u0433\u043e\u0441\u044f \u0432 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0435 \u0442\u0438\u043f\u0430. \u041a\u0440\u043e\u043c\u0435 \u0442\u043e\u0433\u043e, \u043d\u0430\u043c \u043f\u043e\u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0442\u0438\u043f-\u043f\u0440\u043e\u043a\u043b\u0430\u0434\u043a\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0431\u044b \u0441\u043c\u043e\u0433 \u0441\u043e\u0445\u0440\u0430\u043d\u0438\u0442\u044c \u043f\u0440\u043e\u043c\u0435\u0436\u0443\u0442\u043e\u0447\u043d\u044b\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b <i>select<\/i> \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438. \u041c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0431\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <b>QPair&lt;QVariant,QVariant><\/b>, \u043d\u043e \u044f \u0440\u0435\u0448\u0438\u043b \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u0442\u0438\u043f, \u0447\u0442\u043e\u0431\u044b \u0438\u0437\u0431\u0435\u0436\u0430\u0442\u044c \u043a\u043e\u043d\u0444\u043b\u0438\u043a\u0442\u043e\u0432 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u044f.<\/p>\n<pre><code class=\"cpp\">\/\/ \u041a\u043e\u0434 \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0432\u0441\u0451 \u0431\u043e\u043b\u044c\u0448\u0435 \u0438 \u0432\u0441\u0451 \u0441\u043a\u0443\u0447\u043d\u0435\u0435. \u0415\u0441\u043b\u0438 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e, https:\/\/github.com\/iiiCpu\/Tiny-qORM\/blob\/master\/ORM\/orm.h<\/code><\/pre>\n<p>  <\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">\u0421\u043a\u0440\u044b\u0442\u044b\u0439 \u0442\u0435\u043a\u0441\u0442<\/b>                         <\/p>\n<div class=\"spoiler_text\">\u042f \u0441\u043c\u043e\u0442\u0440\u044e, \u0442\u044b \u0443\u043f\u043e\u0440\u043d\u044b\u0439. \u041d\u0430.  <\/p>\n<pre><code class=\"cpp\">     struct ORM_QVariantPair \/\/: public ORMValue     {         Q_GADGET         Q_PROPERTY(QVariant key MEMBER key)         Q_PROPERTY(QVariant value MEMBER value)     public:         QVariant key, value;         QVariant&amp; operator[](int index){ return index == 0 ? key : value; }     };      template &lt;typename K, typename T> QMap&lt;K,T> qMapFromQVariantMap(QVariant const&amp; v)     {         QMap&lt;K,T> list;         QAssociativeIterable ai = v.value&lt;QAssociativeIterable>();         QAssociativeIterable::const_iterator it = ai.begin();         const QAssociativeIterable::const_iterator end = ai.end();         for ( ; it != end; ++it) {             if(it.key().canConvert&lt;K>() &amp;&amp; it.value().canConvert&lt;T>()) {                 list.insert(it.key().value&lt;K>(), it.value().value&lt;T>());             }         }         return list;     }      template &lt;typename K, typename T> QList&lt;ORM_QVariantPair> qMapToPairListStub(QMap&lt;K,T> const&amp; v)     {         QList&lt;ORM_QVariantPair> psl;         for (auto i = v.begin(); i != v.end(); ++i) {             ORM_QVariantPair ps;             ps.key = QVariant::fromValue(i.key());             ps.value = QVariant::fromValue(i.value());             psl &lt;&lt; ps;         }         return psl;     }      template &lt;typename K, typename T> void registerQPair()     {         ORM_Config::addPairType(qMetaTypeId&lt;K>(), qMetaTypeId&lt;T>(),                                 qMetaTypeId&lt;QPair &lt;K,T>>() ? qMetaTypeId&lt;QPair &lt;K,T>>() : qRegisterMetaType&lt;QPair &lt;K,T>>());         QMetaType::registerConverter&lt;QVariant, QPair&lt;K,T>>(&amp;(qPairFromQVariant&lt;K,T>));         QMetaType::registerConverter&lt;QVariantList, QPair&lt;K,T>>(&amp;(qPairFromQVariantList&lt;K,T>));         QMetaType::registerConverter&lt;ORM_QVariantPair, QPair&lt;K,T>>(&amp;(qPairFromPairStub&lt;K,T>));         QMetaType::registerConverter&lt;QPair&lt;K,T>, ORM_QVariantPair>(&amp;(toQPairStub&lt;K,T>));     }     template &lt;typename K, typename T> void registerQMap()     {         registerQPair&lt;K,T>();          ORM_Config::addContainerPairType(qMetaTypeId&lt;K>(), qMetaTypeId&lt;T>(),                                          qMetaTypeId&lt;QMap &lt;K,T>>() ? qMetaTypeId&lt;QMap &lt;K,T>>() : qRegisterMetaType&lt;QMap &lt;K,T>>());         QMetaType::registerConverter&lt;QMap&lt;K,T>, QList&lt;ORM_QVariantPair>>(&amp;(qMapToPairListStub&lt;K,T>));         QMetaType::registerConverter&lt;QVariantMap            , QMap&lt;K,T>>(&amp;(qMapFromQVariantMap&lt;K,T>));         QMetaType::registerConverter&lt;QVariantList           , QMap&lt;K,T>>(&amp;(qMapFromQVariantList&lt;K,T>));         QMetaType::registerConverter&lt;QList &lt;ORM_QVariantPair>, QMap&lt;K,T>>(&amp;(qMapFromPairListStub&lt;K,T>));     }  uint qHash(ORM_QVariantPair const&amp; variantPair) noexcept; Q_DECLARE_METATYPE(ORM_QVariantPair) <\/code><\/pre>\n<p>  <\/div>\n<\/p><\/div>\n<p>  <b>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 3: \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u043e\u0432.<\/b><\/p>\n<p>  \u0423 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u043e\u0432 \u0435\u0441\u0442\u044c \u0435\u0449\u0451 \u043e\u0434\u043d\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430: \u043e\u043d\u0438 \u043d\u0435 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043e\u0439. \u0412\u043e\u0442 \u0442\u0430\u043a\u043e\u0439 \u0432\u043e\u0442 \u0432\u043d\u0435\u0437\u0430\u043f\u043d\u044b\u0439 \u0443\u0434\u0430\u0440 \u043f\u043e\u0434\u0434\u044b\u0445 \u043e\u0442 \u041a\u0430\u043f\u0438\u0442\u0430\u043d\u0430 \u041e\u0447\u0435\u0432\u0438\u0434\u043d\u043e\u0441\u0442\u0438! \u041d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435, \u0432\u0441\u0451 \u043f\u0440\u043e\u0441\u0442\u043e: \u0443 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u043e\u0432 \u043d\u0435\u0442 \u043f\u043e\u043b\u0435\u0439 \u0438 \u043c\u0435\u0442\u0430\u043e\u0431\u044a\u0435\u043a\u0442\u0430, \u0430, \u0437\u043d\u0430\u0447\u0438\u0442, \u043c\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0438\u0445 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e, \u043f\u0440\u043e\u043f\u0438\u0445\u0438\u0432\u0430\u044f \u0437\u0430\u0433\u043b\u0443\u0448\u043a\u0438. \u0422\u043e\u0447\u043d\u0435\u0435, \u043d\u0435 \u0442\u0430\u043a. \u041d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u044b \u0441 \u0442\u0440\u0438\u0432\u0438\u0430\u043b\u044c\u043d\u044b\u043c\u0438 \u0442\u0438\u043f\u0430\u043c\u0438 \u0438 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u2014 \u0430\u0441\u0441\u043e\u0446\u0438\u0430\u0442\u0438\u0432\u043d\u044b\u0435 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u044b, \u0442\u0430\u043a \u043a\u0430\u043a \u043f\u043e\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u044b \u0438\u0437 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440 \u0437\u0430\u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u044e\u0442\u0441\u044f, \u043a\u0430\u043a \u043f\u0440\u043e\u0441\u0442\u044b\u0435 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b. \u0421 \u043f\u0435\u0440\u0432\u044b\u043c\u0438 \u043c\u043e\u0436\u043d\u043e \u0441\u0445\u0438\u0442\u0440\u0438\u0442\u044c, \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u0432 \u0438\u0445 \u0432 \u0441\u0442\u0440\u043e\u043a\u0443 \u0438\u043b\u0438 BLOB (\u043d\u0443\u0436\u043d\u044b\u0435 \u043c\u0435\u0442\u043e\u0434\u044b \u0432 <b>QList<\/b> \u0435\u0441\u0442\u044c \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438). \u0421\u043e \u0432\u0442\u043e\u0440\u044b\u043c\u0438 \u0436\u0435 \u043d\u0438\u0447\u0435\u0433\u043e \u043d\u0435 \u043f\u043e\u0434\u0435\u043b\u0430\u0442\u044c: \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u0434\u0443\u0431\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432\u0441\u0435 \u043c\u0435\u0442\u043e\u0434\u044b, \u043f\u0440\u043e\u043f\u0438\u0445\u0438\u0432\u0430\u044f \u0432\u043c\u0435\u0441\u0442\u043e \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u0445 <b>Q_PROPERTY<\/b> \u0437\u0430\u0433\u043b\u0443\u0448\u043a\u0438 <i>key<\/i> \u0438 <i>value<\/i>.<\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">\u0414\u043e<\/b>                         <\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"cpp\">QVariant ORM::meta_select(const QMetaObject &amp;meta, QString const&amp; parent_name,                            QString const&amp; property_name, long long parent_orm_rowid) {     QString table_name = generate_table_name(parent_name, property_name,                                               QString(meta.className()),QueryType::Select);     int classtype = QMetaType::type(meta.className());     bool isQObject = ORM_Impl::isQObject(meta);     bool with_orm_rowid = ORM_Impl::withRowid(meta);     if (!selectQueries.contains(table_name)) {         QStringList query_columns;         QList&lt;int> query_types;         for (int i = 0; i &lt; meta.propertyCount(); ++i) {             QMetaProperty property = meta.property(i);             if (ORM_Impl::isIgnored(property.userType())) {                 continue;             }<\/code><\/pre>\n<p>  <\/div>\n<\/p><\/div>\n<p>  <\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">\u041f\u043e\u0441\u043b\u0435<\/b>                         <\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"cpp\">QVariant ORM::meta_select_pair  (int metaTypeID, QString const&amp; parent_name,                                 QString const&amp; property_name, long long parent_orm_rowid) {     QString className = QMetaType::typeName(metaTypeID);     QString table_name = generate_table_name(parent_name, property_name, className, QueryType::Select);     int keyType = ORM_Impl::getAssociativeContainerStoredKeyType(metaTypeID);     int valueType = ORM_Impl::getAssociativeContainerStoredValueType(metaTypeID);     if (!selectQueries.contains(table_name)) {         QStringList query_columns;         QList&lt;int> query_types;         query_columns &lt;&lt; ORM_Impl::orm_rowidName;         query_types &lt;&lt; qMetaTypeId&lt;long long>();         for (int column = 0; column &lt; 2; ++column) {             int userType = column == 0 ? keyType : valueType;             QString name = column == 0 ? \"key\" : \"value\";             if (ORM_Impl::isIgnored(userType)) {                 continue;             }<\/code><\/pre>\n<p>  <\/div>\n<\/p><\/div>\n<p>  \u0412 \u0438\u0442\u043e\u0433\u0435 \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u043e\u0434\u043d\u043e\u0440\u043e\u0434\u043d\u044b\u0439 \u0434\u043e\u0441\u0442\u0443\u043f \u043d\u0430 \u0447\u0442\u0435\u043d\u0438\u0435 \u0438 \u0437\u0430\u043f\u0438\u0441\u044c \u043a\u043e \u0432\u0441\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u043c \u0442\u0438\u043f\u0430\u043c \u0438 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430\u043c \u0441 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c\u044e \u0438\u0445 \u0440\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u043e\u0433\u043e \u043e\u0431\u0445\u043e\u0434\u0430.<\/p>\n<h3>\u0428\u0430\u0433 5. \u041d\u0430\u043f\u0438\u0441\u0430\u0442\u044c SQL \u0437\u0430\u043f\u0440\u043e\u0441\u044b.<\/h3>\n<p>  \u0414\u043b\u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f SQL \u0437\u0430\u043f\u0440\u043e\u0441\u0430 \u043d\u0430\u043c \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0438\u043c\u0435\u0442\u044c \u043c\u0435\u0442\u0430\u0442\u0438\u043f \u043a\u043b\u0430\u0441\u0441\u0430, \u0438\u043c\u044f \u043f\u043e\u043b\u044f \u0432 \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u0441\u043a\u043e\u0439 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0435, \u0438\u043c\u044f \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u0441\u043a\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u044b, \u0441\u043f\u0438\u0441\u043e\u043a \u0438\u043c\u0451\u043d \u0438 \u043c\u0435\u0442\u0430\u0442\u0438\u043f\u043e\u0432 \u043f\u043e\u043b\u0435\u0439. \u0418\u0437 \u043f\u0435\u0440\u0432\u044b\u0445 \u0442\u0440\u0451\u0445 \u0441\u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u0443\u0435\u043c \u0438\u043c\u044f \u0442\u0430\u0431\u043b\u0438\u0446\u044b, \u0438\u0437 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0441\u0442\u043e\u043b\u0431\u0446\u044b.<\/p>\n<pre><code class=\"cpp\"> QString ORM::generate_update_query(QString const&amp; parent_name,                  QString const&amp; property_name, const QString &amp;class_name,                  const QStringList &amp;names, const QList&lt;int> &amp;types,                  bool parent_orm_rowid) const {     Q_UNUSED(types)     QString table_name = generate_table_name(parent_name,                         property_name, class_name, QueryType::Update);     QString query_text = QString(\"UPDATE OR IGNORE %1 SET \").arg(table_name);     QStringList t_set;     for (int i = 0; i &lt; names.size(); ++i) {         t_set &lt;&lt; normalize(names[i], QueryType::Update) + \" = \" +                  normalizeVar(\":\" + names[i], types[i], QueryType::Update);     }     query_text += t_set.join(',') + \" WHERE \" +                    normalize(ORM_Impl::orm_rowidName, QueryType::Update) + \" = :\" +                    ORM_Impl::orm_rowidName + \" \";     if (parent_orm_rowid) {         query_text += \" AND \" + ORM_Impl::orm_parentRowidName + \" = :\" +                        ORM_Impl::orm_parentRowidName + \" \";     }     query_text += \";\";     return query_text; }<\/code><\/pre>\n<p>  \u041e \u0447\u0451\u043c \u043d\u0435 \u0441\u0442\u043e\u0438\u0442 \u0437\u0430\u0431\u044b\u0432\u0430\u0442\u044c:<br \/>  1) \u041d\u043e\u0440\u043c\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0438\u043c\u0451\u043d. \u0414\u0435\u043b\u043e \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0435, \u0442\u0438\u043f\u044b \u043c\u043e\u0433\u0443\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u0432 \u0441\u0435\u0431\u0435 \u0441\u043a\u043e\u0431\u043a\u0438 \u0438 \u0437\u0430\u043f\u044f\u0442\u044b\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u043e\u0432, \u0434\u0432\u043e\u0435\u0442\u043e\u0447\u0438\u044f \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432 \u0438\u043c\u0451\u043d. \u041e\u0442 \u0432\u0441\u0435\u0433\u043e \u044d\u0442\u043e\u0433\u043e \u043c\u043d\u043e\u0433\u043e\u043e\u0431\u0440\u0430\u0437\u0438\u044f \u0441\u043b\u0435\u0434\u0443\u0435\u0442 \u0438\u0437\u0431\u0430\u0432\u043b\u044f\u0442\u044c\u0441\u044f.<\/p>\n<pre><code class=\"cpp\">QString ORM::normalize(const QString &amp; str, QueryType queryType) const {     Q_UNUSED(queryType)     QString s = str;     static QRegularExpression regExp1 {\"(.)([A-Z]+)\"};     static QRegularExpression regExp2 {\"([a-z0-9])([A-Z])\"};     static QRegularExpression regExp3 {\"[:;,.&lt;>]+\"};     return \"_\" + s.replace(regExp1, \"\\\\1_\\\\2\")                  .replace(regExp2, \"\\\\1_\\\\2\").toLower()                  .replace(regExp3, \"_\"); }<\/code><\/pre>\n<p>  2) \u041f\u0440\u0438\u0432\u0435\u0434\u0435\u043d\u0438\u044f \u0442\u0438\u043f\u043e\u0432. \u0415\u0441\u043b\u0438 \u0440\u0430\u0431\u043e\u0442\u0430 \u0432\u0435\u0434\u0451\u0442\u0441\u044f \u0441 SQLite, \u0442\u043e \u0432\u0441\u0451 \u043f\u0440\u043e\u0441\u0442\u043e: \u043a\u0442\u043e \u0431\u044b \u0442\u044b \u043d\u0438 \u0431\u044b\u043b, \u0442\u044b \u2014 \u0441\u0442\u0440\u043e\u043a\u0430. \u041d\u043e \u0435\u0441\u043b\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u0434\u0440\u0443\u0433\u0438\u0435 \u0411\u0414, \u043f\u043e\u0440\u043e\u0439, \u0431\u0435\u0437 \u043a\u0430\u0441\u0442\u0430 \u043d\u0435 \u043e\u0431\u043e\u0439\u0442\u0438\u0441\u044c. \u0417\u043d\u0430\u0447\u0438\u0442, \u043f\u0440\u0438 \u0432\u0441\u0442\u0430\u0432\u043a\u0435 \u0438\u043b\u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0438 \u043d\u043e\u0440\u043c\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 (\u043f\u043b\u0435\u0439\u0441\u0445\u043e\u043b\u0434\u0435\u0440) \u043d\u0443\u0436\u043d\u043e \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u0442\u044c, \u0434\u0430 \u0438 \u043f\u0440\u0438 \u0432\u044b\u0431\u043e\u0440\u0435 \u0442\u043e\u0436\u0435.<\/p>\n<h2>\u0418 \u0432 \u0447\u0451\u043c \u0436\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430? \u041f\u043e\u0447\u0435\u043c\u0443 \u00ab\u043d\u0435\u0443\u0441\u043f\u0435\u0445\u00bb?<\/h2>\n<p>  \u0414\u0443\u043c\u0430\u044e, \u043c\u043d\u043e\u0433\u0438\u043c \u043e\u0442\u0432\u0435\u0442 \u0443\u0436\u0435 \u043e\u0447\u0435\u0432\u0438\u0434\u0435\u043d. \u0421\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u044b. \u041d\u0430 \u043f\u0440\u043e\u0441\u0442\u044b\u0445 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430\u0445 \u043f\u0430\u0434\u0435\u043d\u0438\u0435 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 10% \u043d\u0430 \u0437\u0430\u043f\u0438\u0441\u044c \u0438 100% \u043d\u0430 \u0447\u0442\u0435\u043d\u0438\u0435. \u041d\u0430 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0435 \u0441 \u0433\u043b\u0443\u0431\u0438\u043d\u043e\u0439 \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u043e\u0441\u0442\u0438 1 \u2014 \u0443\u0436\u0435 30% \u0438 700%. \u041d\u0430 \u0433\u043b\u0443\u0431\u0438\u043d\u0435 2 \u2014 50% \u0438 2000%. \u0421 \u043f\u043e\u0432\u044b\u0448\u0435\u043d\u0438\u0435\u043c \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u044b \u043f\u0430\u0434\u0430\u0435\u0442 \u044d\u043a\u0441\u043f\u043e\u043d\u0435\u043d\u0446\u0438\u0430\u043b\u044c\u043d\u043e.<\/p>\n<p>  <code>Simple sqlite[10000]:<br \/>  ORM: insert= 2160 select= 56<br \/>  QSqlQuery: insert= 1352 select= 53<br \/>  RAW: insert= 1271 select= 3<\/p>\n<p>  Complex sqlite[10000]:<br \/>  ORM: insert= 7231 select= 24095<br \/>  QSqlQuery: insert= 4594 select= 127<br \/>  RAW: insert= 1117 select= 7<br \/>  <\/code>  <\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">Simple<\/b>                         <\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"cpp\">    struct U1 : public ORMValue     {         Q_GADGET         Q_PROPERTY(int index MEMBER m_i)     public:         int m_i = 0;         U1():m_i(0){}         U1&amp; operator=(U1 const&amp; o) { m_orm_rowid = o.m_orm_rowid; m_i = o.m_i; return *this; }     };<\/code><\/pre>\n<p>  <\/div>\n<\/p><\/div>\n<p>  <\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">Complex<\/b>                         <\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"cpp\">        struct U3 : public ORMValue     {         Q_GADGET         Q_PROPERTY(int index MEMBER m_i)     public:         int m_i;         U3(int i = rand()):m_i(i){}         bool operator !=(U3 const&amp; o) const { return m_i != o.m_i; }         U3&amp; operator=(U3 const&amp; o) { m_orm_rowid = o.m_orm_rowid; m_i = o.m_i; return *this; }     };     struct U2 : public ORMValue     {         Q_GADGET         Q_PROPERTY(Test3::U3 u3    MEMBER m_u3)         Q_PROPERTY(int       index MEMBER m_i )     public:         U3 m_u3;         int m_i;         U2(int i = rand()):m_i(i){}         bool operator !=(U2 const&amp; o) const { return m_i != o.m_i || m_u3 != o.m_u3; }         U2&amp; operator=(U2 const&amp; o) { m_orm_rowid = o.m_orm_rowid; m_u3 = o.m_u3; m_i = o.m_i; return *this; }     };     struct U1 : public ORMValue     {         Q_GADGET         Q_PROPERTY(Test3::U3* u3 MEMBER m_u3)         Q_PROPERTY(Test3::U2 u2 MEMBER m_u2)         Q_PROPERTY(int index MEMBER m_i)     public:         U3* m_u3 = nullptr;         U2 m_u2;         int m_i = 0;         U1():m_i(0){}         U1(U1 const&amp; o):m_i(0){ m_orm_rowid = o.m_orm_rowid; m_u2 = o.m_u2; m_i = o.m_i; if (!o.m_u3) { delete m_u3; m_u3 = nullptr; } else { if (!m_u3) { m_u3 = new U3();} *m_u3 = *o.m_u3; } }         U1(U1 &amp;&amp; o):m_i(0){ m_orm_rowid = o.m_orm_rowid; m_u2 = o.m_u2; m_i = o.m_i; delete m_u3; m_u3 = o.m_u3; o.m_u3 = nullptr; }          ~U1(){ delete m_u3; }         U1&amp; operator=(U1 const&amp; o) { m_orm_rowid = o.m_orm_rowid; m_u2 = o.m_u2; m_i = o.m_i; if (!o.m_u3) { delete m_u3; m_u3 = nullptr; } else { if (!m_u3) { m_u3 = new U3();} *m_u3 = *o.m_u3; } return *this; }     };<\/code><\/pre>\n<p>  <\/div>\n<\/p><\/div>\n<p>  \u041f\u0440\u0438\u0447\u0438\u043d\u0430 \u0442\u043e\u043c\u0443 \u0440\u043e\u0432\u043d\u043e \u043e\u0434\u043d\u0430. \u041c\u0435\u0442\u0430\u0441\u0438\u0441\u0442\u0435\u043c\u0430 Qt. \u041e\u043d\u0430 \u0443\u0441\u0442\u0440\u043e\u0435\u043d\u0430 \u0442\u0430\u043a, \u0447\u0442\u043e \u0432 \u043d\u0435\u0439 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043e\u0447\u0435\u043d\u044c \u043c\u043d\u043e\u0433\u043e \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0439. \u0412\u0435\u0440\u043d\u0435\u0435, \u0432 \u043d\u0435\u0439 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0441\u044f \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0435 \u0447\u0438\u0441\u043b\u043e \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0439 \u0434\u043b\u044f \u0440\u0435\u0430\u043b\u0442\u0430\u0439\u043c\u0430, \u043d\u043e, \u0442\u0435\u043c \u043d\u0435 \u043c\u0435\u043d\u0435\u0435, \u0432\u0435\u0441\u044c\u043c\u0430 \u0431\u043e\u043b\u044c\u0448\u043e\u0435. \u041a\u043e\u0433\u0434\u0430 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0441\u044f \u0441\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0434\u0430\u043d\u043d\u044b\u0445, \u043d\u0443\u0436\u043d\u043e \u043e\u0434\u0438\u043d \u0440\u0430\u0437 \u0441\u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0432 QVariant, \u0438 \u0431\u043e\u043b\u044c\u0448\u0435 \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0439 \u043d\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0441\u044f. \u041a\u043e\u0433\u0434\u0430 \u0436\u0435 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0434\u0435\u0441\u0435\u0440\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u2014 \u044d\u0442\u043e \u043f\u0435\u0441\u043d\u044f! \u041a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043d\u0430 \u043a\u0430\u0436\u0434\u043e\u043c \u0432\u044b\u0437\u043e\u0432\u0435 write\\writeOnGadget \u2014 \u0438 \u043e\u0442 \u043d\u0438\u0445 \u0441\u043e\u0432\u0435\u0440\u0448\u0435\u043d\u043d\u043e \u043d\u0435\u043b\u044c\u0437\u044f \u0438\u0437\u0431\u0430\u0432\u0438\u0442\u044c\u0441\u044f. <\/p>\n<p>  \u0415\u0441\u0442\u044c \u043b\u0438 \u0434\u0440\u0443\u0433\u043e\u0439 \u043f\u043e\u0434\u0445\u043e\u0434, \u043f\u0440\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u043d\u0430\u043c \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0434\u0435\u043b\u0430\u0442\u044c \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f? \u0415\u0441\u0442\u044c. \u041e\u0431\u044a\u044f\u0432\u043b\u044f\u0442\u044c \u0432\u0441\u0435 \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0435 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b \u0443\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u044f\u043c\u0438.<\/p>\n<pre><code class=\"cpp\">struct Car {     Q_GADGET     Q_PROPERTY(double gas MEMBER m_gas) public:     double m_gas; };  struct Dad {     Q_GADGET     Q_PROPERTY(Car car MEMBER m_car STORED false)     Q_PROPERTY(ormReferen\u0441e&lt;Car> car READ getCar WRITE setCar SCRIPTABLE false) public:     Car m_car;     ormReferen\u0441e&lt;Car> getCar() const { return ormReferen\u0441e&lt;Car>(&amp;m_car); }     void setCar(ormReferen\u0441e&lt;Car> car) { if (car) m_car = *car; } }; <\/code><\/pre>\n<p>  \u0422\u0430\u043a\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0443\u0441\u043a\u043e\u0440\u0438\u0442\u044c ORM. \u041f\u0430\u0434\u0435\u043d\u0438\u0435 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438 \u0440\u0430\u0431\u043e\u0442\u044b \u0432\u0441\u0451 \u0435\u0449\u0451 \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0435, \u0432 \u0440\u0430\u0437\u044b, \u043d\u043e \u0443\u0436\u0435 \u043d\u0435 \u043d\u0430 \u043f\u043e\u0440\u044f\u0434\u043a\u0438. \u0422\u0435\u043c \u043d\u0435 \u043c\u0435\u043d\u0435\u0435, \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u044d\u0442\u043e flawed by design, \u0442\u0440\u0435\u0431\u0443\u044e\u0449\u0435\u0435 \u0438\u0437\u043c\u0435\u043d\u044f\u0442\u044c \u043a\u0443\u0447\u0443 \u043a\u043e\u0434\u0430. \u0410 \u0435\u0441\u043b\u0438 \u044d\u0442\u043e \u0432 \u043b\u044e\u0431\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043d\u0443\u0436\u043d\u043e \u0434\u0435\u043b\u0430\u0442\u044c, \u043d\u0435 \u043f\u0440\u043e\u0449\u0435 \u043b\u0438 \u0441\u0440\u0430\u0437\u0443 \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0433\u0435\u043d\u0435\u0440\u0430\u0442\u043e\u0440 SQL \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432? \u0423\u0432\u044b, \u043f\u0440\u043e\u0449\u0435, \u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u0430\u043a\u043e\u0439 \u043a\u043e\u0434 \u0440\u0430\u0437\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0431\u044b\u0441\u0442\u0440\u0435\u0435. \u041f\u043e\u0442\u043e\u043c\u0443 \u043c\u043e\u044f \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u0438 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u0430\u044f \u0440\u0430\u0431\u043e\u0442\u0430 \u043e\u0441\u0442\u0430\u043b\u0430\u0441\u044c \u043f\u044b\u043b\u0438\u0442\u044c\u0441\u044f \u0432 \u0443\u0433\u043b\u0443.<\/p>\n<h2>\u0412\u043c\u0435\u0441\u0442\u043e \u0432\u044b\u0432\u043e\u0434\u0430<\/h2>\n<p>  \u0416\u0430\u043b\u0435\u044e \u043b\u0438 \u044f, \u0447\u0442\u043e \u043f\u043e\u0442\u0440\u0430\u0442\u0438\u043b \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u0435\u0441\u044f\u0446\u0435\u0432 \u043d\u0430 \u0435\u0451 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u0435? \u0427\u0451\u0440\u0442 \u043f\u043e\u0434\u0435\u0440\u0438, \u043d\u0435\u0442! \u042d\u0442\u043e \u0431\u044b\u043b\u043e \u043e\u0447\u0435\u043d\u044c \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e\u0435 \u043f\u043e\u0433\u0440\u0443\u0436\u0435\u043d\u0438\u0435 \u0432\u043d\u0443\u0442\u0440\u044c \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0439 \u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0449\u0435\u0439 \u043c\u0435\u0442\u0430\u0441\u0438\u0441\u0442\u0435\u043c\u044b, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u043e \u043c\u043e\u0439 \u0432\u0437\u0433\u043b\u044f\u0434 \u043d\u0430 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435. \u042f \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u0430\u0433\u0430\u043b \u0442\u0430\u043a\u043e\u0439 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442, \u043a\u043e\u0433\u0434\u0430 \u043f\u0440\u0438\u0441\u0442\u0443\u043f\u0430\u043b \u043a \u0440\u0430\u0431\u043e\u0442\u0435. \u041d\u0430\u0434\u0435\u044f\u043b\u0441\u044f \u043d\u0430 \u043b\u0443\u0447\u0448\u0435\u0435, \u043d\u043e \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u0430\u0433\u0430\u043b \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a\u043e\u0439. \u042f \u043f\u043e\u043b\u0443\u0447\u0438\u043b \u0435\u0433\u043e \u043d\u0430 \u0432\u044b\u0445\u043e\u0434\u0435. \u0418 \u043e\u043d \u043c\u0435\u043d\u044f \u0443\u0441\u0442\u0440\u043e\u0438\u043b! <\/p>\n<h2>\u041f\u043e\u0441\u043b\u0435\u0441\u043b\u043e\u0432\u0438\u0435<\/h2>\n<p>  \u0421\u0442\u0430\u0442\u044c\u044f, \u043a\u0430\u043a \u0438 \u0441\u0430\u043c \u043a\u043e\u0434, \u0431\u044b\u043b\u0438 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u044b 4 \u0433\u043e\u0434\u0430 \u043d\u0430\u0437\u0430\u0434 \u0438 \u043e\u0442\u043b\u043e\u0436\u0435\u043d\u044b \u0434\u043b\u044f \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 \u0438 \u043f\u0440\u0430\u0432\u043a\u0438. \u0417\u0430 \u044d\u0442\u0438 4 \u0433\u043e\u0434\u0430 \u0432\u044b\u0448\u043b\u043e 2 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u0430 C++ \u0438 \u043e\u0434\u043d\u0430 \u043c\u0430\u0436\u043e\u0440\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0438\u044f Qt, \u043d\u043e \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0445 \u043f\u0440\u0430\u0432\u043e\u043a \u0432\u043d\u0435\u0441\u0435\u043d\u043e \u043d\u0435 \u0431\u044b\u043b\u043e. \u042f \u0434\u0430\u0436\u0435 \u043d\u0435 \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u043b, \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043b\u0438 ORM \u0432 6-\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438. (UPD: \u0420\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043f\u043e\u0441\u043b\u0435 \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u0438\u0445 \u043f\u0440\u0430\u0432\u043e\u043a deprecated \u043c\u0435\u0442\u043e\u0434\u043e\u0432 \u0438 \u0442\u0438\u043f\u043e\u0432) \u0422\u0435\u043c \u043d\u0435 \u043c\u0435\u043d\u0435\u0435, \u0432\u0435\u0440\u043d\u0443\u0432\u0448\u0438\u0441\u044c \u043d\u0430\u0437\u0430\u0434, \u044f \u043f\u043e\u0441\u0447\u0438\u0442\u0430\u043b, \u0447\u0442\u043e \u0435\u0451 \u0441\u0442\u043e\u0438\u0442 \u043e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u0442\u044c. \u0425\u043e\u0442\u044f \u0431\u044b \u0434\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0432\u043e\u043e\u0434\u0443\u0448\u0435\u0432\u0438\u0442\u044c \u0434\u0440\u0443\u0433\u0438\u0445 \u043d\u0430 \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u0435. \u0412\u0435\u0434\u044c \u0435\u0441\u043b\u0438 \u043e\u043d\u0438 \u0434\u043e\u0441\u0442\u0438\u0433\u043d\u0443\u0442 \u0431\u043e\u043b\u044c\u0448\u0435\u0433\u043e \u0443\u0441\u043f\u0435\u0445\u0430, \u0447\u0435\u043c \u044f, \u2014 \u044f \u0442\u043e\u0436\u0435 \u043e\u0441\u0442\u0430\u043d\u0443\u0441\u044c \u0432 \u0432\u044b\u0438\u0433\u0440\u044b\u0448\u0435. \u0411\u0443\u0434\u0435\u0442 \u043d\u0430 \u043e\u0434\u043d\u0443 \u043f\u043e\u043b\u0435\u0437\u043d\u0443\u044e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u0431\u043e\u043b\u044c\u0448\u0435! \u0410 \u0435\u0441\u043b\u0438 \u043d\u0435 \u0434\u043e\u0441\u0442\u0438\u0433\u043d\u0443\u0442 \u2014 \u0442\u043e, \u043a\u0430\u043a \u043c\u0438\u043d\u0438\u043c\u0443\u043c, \u043e\u043d\u0438 \u0431\u0443\u0434\u0443\u0442 \u0437\u043d\u0430\u0442\u044c, \u0447\u0442\u043e \u043e\u043d\u0438 \u043d\u0435 \u043e\u0434\u043d\u0438 \u0442\u0430\u043a\u0438\u0435, \u0438 \u0447\u0442\u043e \u0438\u0445 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442, \u043a\u0430\u043a\u0438\u043c \u0431\u044b \u0440\u0430\u0437\u043e\u0447\u0430\u0440\u043e\u0432\u044b\u0432\u0430\u044e\u0449\u0438\u043c \u043e\u043d \u043d\u0435 \u0431\u044b\u043b, \u2014 \u044d\u0442\u043e \u0432\u0441\u0451 \u0440\u0430\u0432\u043d\u043e \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442.<\/div>\n<\/div>\n<\/div>\n<div class=\"v-portal\" style=\"display:none;\"><\/div>\n<\/div>\n<p> <!----> <!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/post\/452588\/\"> https:\/\/habr.com\/ru\/post\/452588\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-1\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\u0427\u0430\u0449\u0435 \u0432\u0441\u0435\u0433\u043e \u043d\u0430 \u0445\u0430\u0431\u0440\u0435 \u043b\u044e\u0434\u0438 \u0434\u0435\u043b\u044f\u0442\u0441\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f\u043c\u0438 \u0441\u0432\u043e\u0435\u0433\u043e \u0443\u0441\u043f\u0435\u0445\u0430. \u0412\u0440\u043e\u0434\u0435, <i>\u00ab\u0420\u0435\u0431\u044f\u0442\u0430, \u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043b \u0441\u0432\u043e\u044e ORM, \u043a\u0430\u0447\u0430\u0439\u0442\u0435, \u0441\u0442\u0430\u0432\u044c\u0442\u0435 \u043b\u043b\u043e\u0439\u0441\u044b!\u00bb<\/i> \u042d\u0442\u0430 \u0438\u0441\u0442\u043e\u0440\u0438\u044f \u0431\u0443\u0434\u0435\u0442 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0434\u0440\u0443\u0433\u0430\u044f. \u0412 \u043d\u0435\u0439 \u044f \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0443 \u043e \u043d\u0435\u0443\u0441\u043f\u0435\u0445\u0435, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u0447\u0438\u0442\u0430\u044e \u0441\u0432\u043e\u0438\u043c \u0441\u0435\u0440\u044c\u0451\u0437\u043d\u044b\u043c \u0434\u043e\u0441\u0442\u0438\u0436\u0435\u043d\u0438\u0435\u043c. <\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w780q1\/webt\/qa\/9u\/ys\/qa9uyserftbj6r5cn-4rvgjcvty.jpeg\" data-src=\"https:\/\/habrastorage.org\/webt\/qa\/9u\/ys\/qa9uyserftbj6r5cn-4rvgjcvty.jpeg\" data-blurred=\"true\"\/><br \/>  <i>\u041e\u0436\u0438\u0434\u0430\u043d\u0438\u0435 \u2014 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c.<\/i><\/p>\n<p>  \u0418\u0441\u0442\u043e\u0440\u0438\u044f \u043e \u043c\u0435\u0442\u0430\u0442\u0438\u043f\u0430\u0445 Qt, \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u0438 \u0432\u0435\u043b\u043e\u0441\u0438\u043f\u0435\u0434\u043e\u0432, \u043f\u0440\u0435\u0432\u044b\u0448\u0435\u043d\u0438\u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0447\u0438\u0441\u043b\u0430 \u0437\u0430\u043f\u0438\u0441\u0435\u0439 \u0432 \u043e\u0431\u044a\u0435\u043a\u0442\u043d\u043e\u043c \u0444\u0430\u0439\u043b\u0435 \u0438, \u043d\u0435\u043e\u0436\u0438\u0434\u0430\u043d\u043d\u043e, <a href=\"https:\/\/github.com\/iiiCpu\/Tiny-qORM\" rel=\"nofollow noopener noreferrer\">\u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0435, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u0430\u043a, \u043a\u0430\u043a \u0438 \u0431\u044b\u043b\u043e \u0437\u0430\u0434\u0443\u043c\u0430\u043d\u043e<\/a>.   <\/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-339143","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/339143","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=339143"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/339143\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=339143"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=339143"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=339143"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}