{"id":283900,"date":"2017-03-25T16:50:02","date_gmt":"2017-03-25T13:50:02","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=283900"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=283900","title":{"rendered":"\u0414\u0435\u043b\u0430\u0435\u043c \u0431\u044b\u0441\u0442\u0440\u044b\u0439 \u043f\u043e\u0438\u0441\u043a \u043f\u043e \u0442\u0443\u0440\u0430\u043c \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 ClickHouse"},"content":{"rendered":"<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/626\/562\/a17\/626562a17c194dcb84e075c423ef1003.png\" align=\"right\" width=\"320\"\/> \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u043c\u044b \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u044b \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e \u0431\u0430\u0437\u0435 \u0442\u0443\u0440\u043e\u0432 (\u0442\u0443\u0440 \u0438\u0437 \u0441\u0435\u0431\u044f \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u043d\u0430\u0431\u043e\u0440 \u0438\u0437 \u043e\u0442\u0435\u043b\u044f \u0438 \u043f\u0435\u0440\u0435\u043b\u0435\u0442\u0430) \u0438 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0434\u0432\u0435 \u043e\u043f\u0446\u0438\u0438 \u2014 <a href=\"https:\/\/clickhouse.yandex\">ClickHouse<\/a> \u0438 MySQL (\u0434\u0432\u0430 \u0434\u0432\u0438\u0436\u043a\u0430 \u2014 InnoDB \u0438 MyISAM).<\/p>\n<h3>\u0412 \u0447\u0435\u043c \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e \u0442\u0443\u0440\u0430\u043c<\/h3>\n<p>  \u0422\u0443\u0440\u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u044b (TezTour, TUI, Natalie Tours, etc) \u043f\u0440\u043e\u0434\u0430\u044e\u0442 \u0441\u0432\u043e\u0438 \u043f\u0443\u0442\u0435\u0432\u043a\u0438 \u043d\u0435\u043e\u0447\u0435\u0432\u0438\u0434\u043d\u044b\u043c, \u043d\u0430 \u043f\u0435\u0440\u0432\u044b\u0439 \u0432\u0437\u0433\u043b\u044f\u0434, \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c:<\/p>\n<ul>\n<li>\u0440\u0435\u0437\u0435\u0440\u0432\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043d\u043e\u043c\u0435\u0440\u043e\u0432 \u0432 \u043e\u0442\u0435\u043b\u044f\u0445 \u043d\u0430 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0434\u0430\u0442<\/li>\n<li>\u0432\u044b\u043a\u0443\u043f\u0430\u0435\u0442\u0441\u044f \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u0430\u043c\u043e\u043b\u0435\u0442\u043e\u0432<\/li>\n<li>\u0432\u044b\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f \u043d\u043e\u0432\u044b\u0439 \u043f\u0430\u043a\u0435\u0442 \u0442\u0443\u0440\u043e\u0432, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u0441\u044f \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0438 \u0432\u0441\u0435\u0445 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0445 \u0442\u0438\u043f\u043e\u0432 \u043d\u043e\u043c\u0435\u0440\u043e\u0432, \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0435\u0439 \u043f\u0440\u0435\u0431\u044b\u0432\u0430\u043d\u0438\u044f, \u0433\u043e\u0440\u043e\u0434\u043e\u0432 \u0438 \u0434\u0430\u0442 \u0432\u044b\u043b\u0435\u0442\u0430<\/li>\n<\/ul>\n<p>  \u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0433\u043e \u043f\u043e \u0442\u0430\u043a\u0438\u043c \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u044f\u043c (\u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043c\u043e\u0436\u0435\u0442 \u0438\u0441\u0447\u0438\u0441\u043b\u044f\u0442\u044c\u0441\u044f \u0441\u043e\u0442\u043d\u044f\u043c\u0438 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0438 \u0434\u0430\u0436\u0435 \u043c\u0438\u043b\u043b\u0438\u0430\u0440\u0434\u0430\u043c\u0438) \u043e\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u043e\u0438\u0441\u043a. \u041f\u0440\u0438\u043c\u0435\u0440 \u0444\u043e\u0440\u043c\u044b \u043f\u043e\u0438\u0441\u043a\u0430 \u043c\u043e\u0436\u043d\u043e \u0443\u0432\u0438\u0434\u0435\u0442\u044c \u0443 <a href=\"http:\/\/www.tez-tour.com\/search.html\">TezTour<\/a> \u2014 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0431\u0440\u0430\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u0438\u043d \u0433\u043e\u0440\u043e\u0434 \u0432\u044b\u043b\u0435\u0442\u0430, \u0442\u0438\u043f \u0440\u0430\u0437\u043c\u0435\u0449\u0435\u043d\u0438\u044f \u0438 \u0441\u0442\u0440\u0430\u043d\u0443, \u0430 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0431\u0438\u0440\u0430\u0442\u044c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u044b\u0435.<\/p>\n<p>  \u041d\u0435\u0441\u043c\u043e\u0442\u0440\u044f \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u043e\u0431\u0449\u0435\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0442\u0443\u0440\u043e\u0432 (\u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0439) \u0438\u0441\u0447\u0438\u0441\u043b\u044f\u0435\u0442\u0441\u044f \u0441\u043e\u0442\u043d\u044f\u043c\u0438 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432, \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 (\u0433\u043e\u0440\u043e\u0434 \u0432\u044b\u043b\u0435\u0442\u0430, \u0442\u0438\u043f \u0440\u0430\u0437\u043c\u0435\u0449\u0435\u043d\u0438\u044f, \u0441\u0442\u0440\u0430\u043d\u0430) \u043f\u0440\u0438\u0445\u043e\u0434\u044f\u0442\u0441\u044f, \u0432 \u0445\u0443\u0434\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432. \u041d\u043e \u0434\u0430\u0436\u0435 \u043f\u043e \u0442\u0430\u043a\u043e\u043c\u0443 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0443 \u0442\u0443\u0440\u043e\u0432 \u043d\u0435 \u0442\u0430\u043a \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043b\u044f\u0442\u044c \u043f\u043e\u0438\u0441\u043a, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438 \u0437\u0430\u043f\u0438\u0441\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0443\u0434\u043e\u0432\u043b\u0435\u0442\u0432\u043e\u0440\u044f\u044e\u0442 \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u044b\u043c \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u044f\u043c, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0437\u0430\u0434\u0430\u044e\u0442 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438, \u0438 \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0431\u043e\u043b\u0435\u0435-\u043c\u0435\u043d\u0435\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u043e\u0439 (\u043a\u0430\u043a \u043f\u0440\u0430\u0432\u0438\u043b\u043e, \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430 \u0434\u0435\u043b\u0430\u0435\u0442\u0441\u044f \u043f\u043e \u0446\u0435\u043d\u0435, \u043d\u043e \u044d\u0442\u043e \u043d\u0435 \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0439 \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u0439). \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u043c\u044b \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0443\u043f\u0440\u043e\u0449\u0435\u043d\u043d\u0443\u044e \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0443 \u0440\u0435\u0430\u043b\u0442\u0430\u0439\u043c-\u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e \u0442\u0443\u0440\u0430\u043c \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 MySQL \u0438 ClickHouse, \u0431\u0435\u0437 \u0443\u0447\u0435\u0442\u0430 \u0441\u0442\u043e\u043f\u043e\u0432 (\u0441\u043b\u0435\u043d\u0433\u043e\u0432\u044b\u0439 \u0442\u0435\u0440\u043c\u0438\u043d, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442, \u0447\u0442\u043e \u043f\u043e \u043a\u0430\u043a\u0438\u043c-\u0442\u043e \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430\u043c \u0437\u0430\u043a\u043e\u043d\u0447\u0438\u043b\u0438\u0441\u044c \u043d\u043e\u043c\u0435\u0440\u0430 \u0438\u043b\u0438 \u043c\u0435\u0441\u0442\u0430 \u0432 \u0441\u0430\u043c\u043e\u043b\u0435\u0442\u0435, \u0438 \u0442\u0430\u043a\u0438\u0435 \u0442\u0443\u0440\u044b \u043d\u0443\u0436\u043d\u043e \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0438\u0437 \u0432\u044b\u0434\u0430\u0447\u0438). \u041c\u044b \u043d\u0430\u0443\u0447\u0438\u043c\u0441\u044f \u0434\u0435\u043b\u0430\u0442\u044c \u043f\u043e\u0438\u0441\u043a \u0431\u044b\u0441\u0442\u0440\u044b\u043c \u0438 \u0443\u043c\u0435\u0442\u044c \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b \u0441 \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u043e\u0439 \u043f\u043e \u043b\u044e\u0431\u044b\u043c \u043f\u043e\u043b\u044f\u043c.<\/p>\n<p>  <a name=\"habracut\"><\/a><\/p>\n<h3>\u041e\u0442\u043a\u0443\u0434\u0430 \u0431\u0440\u0430\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0435<\/h3>\n<p>  \u0418\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u044f \u0445\u043e\u0442\u0435\u043b \u0432\u0437\u044f\u0442\u044c \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0443\u044e \u0431\u0430\u0437\u0443 \u043a\u0430\u043a\u043e\u0433\u043e-\u043d\u0438\u0431\u0443\u0434\u044c \u0442\u0443\u0440\u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u0430 \u0438 \u0437\u0430\u0433\u0440\u0443\u0436\u0430\u0442\u044c \u0435\u0451 \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0445 \u0434\u0430\u043d\u043d\u044b\u0445 \u0434\u043b\u044f \u043d\u0430\u0448\u0435\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b \u2014 \u0442\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0431\u044b \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0442\u044c \u0430\u0434\u0435\u043a\u0432\u0430\u0442\u043d\u043e\u0441\u0442\u044c \u043d\u0430\u0448\u0435\u0433\u043e \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u0443\u0442\u0435\u043c \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f \u043d\u0430\u0448\u0435\u0439 \u0432\u044b\u0434\u0430\u0447\u0438 \u0438 \u0432\u044b\u0434\u0430\u0447\u0438 \u043f\u043e\u0438\u0441\u043a\u0430 \u043d\u0430 \u0441\u0430\u0439\u0442\u0435 \u0442\u0443\u0440\u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u0430. \u041d\u043e, \u043a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e, \u043b\u0435\u0433\u043a\u043e \u043d\u0430\u0439\u0442\u0438 \u0431\u0430\u0437\u0443 \u0442\u0443\u0440\u043e\u0432 \u0432 \u043e\u0442\u043a\u0440\u044b\u0442\u043e\u043c \u0434\u043e\u0441\u0442\u0443\u043f\u0435 \u043c\u043d\u0435 \u043d\u0435 \u0443\u0434\u0430\u043b\u043e\u0441\u044c, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432\u043c\u0435\u0441\u0442\u043e \u044d\u0442\u043e\u0433\u043e \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0442\u044c\u0441\u044f \u043d\u0430\u0431\u043e\u0440\u043e\u043c \u043f\u0441\u0435\u0432\u0434\u043e\u0441\u043b\u0443\u0447\u0430\u0439\u043d\u044b\u0445 \u0434\u0430\u043d\u043d\u044b\u0445, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0431\u0443\u0434\u0443\u0442 \u0438\u043c\u0438\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0435 \u0442\u0443\u0440\u044b.<\/p>\n<h3>\u041d\u0430\u0431\u043e\u0440 \u043f\u043e\u043b\u0435\u0439<\/h3>\n<p>  \u0422\u0430\u043a \u043a\u0430\u043a \u043f\u0440\u0438 \u043f\u043e\u0438\u0441\u043a\u0435 \u0433\u043e\u0440\u043e\u0434, \u0441\u0442\u0440\u0430\u043d\u0430 \u0438 \u0442\u0438\u043f \u0440\u0430\u0437\u043c\u0435\u0449\u0435\u043d\u0438\u044f \u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u044b, \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0442\u0430\u0431\u043b\u0438\u0446\u044b, \u0432 \u0438\u043c\u0435\u043d\u0430\u0445 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c\u0441\u044f ID \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 tours_12_55_1001, \u0433\u0434\u0435 12, 55 \u0438 1001 \u2014 \u044d\u0442\u043e ID \u0433\u043e\u0440\u043e\u0434\u0430, \u0441\u0442\u0440\u0430\u043d\u044b \u0438 \u0442\u0438\u043f\u0430 \u0440\u0430\u0437\u043c\u0435\u0449\u0435\u043d\u0438\u044f \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e. \u042d\u0442\u043e \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043d\u0430\u043c \u0440\u0435\u0437\u043a\u043e \u0441\u043e\u043a\u0440\u0430\u0442\u0438\u0442\u044c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0437\u0430\u043f\u0438\u0441\u0435\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u043f\u0440\u043e\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c \u0438 \u0437\u0430\u043e\u0434\u043d\u043e \u0441\u044d\u043a\u043e\u043d\u043e\u043c\u0438\u0442\u044c \u043c\u0435\u0441\u0442\u043e \u0437\u0430 \u0441\u0447\u0451\u0442 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u043c\u044b \u043d\u0435 \u0431\u0443\u0434\u0435\u043c \u0445\u0440\u0430\u043d\u0438\u0442\u044c \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u044e\u0449\u0438\u0435\u0441\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0432 \u0442\u0430\u0431\u043b\u0438\u0446\u0430\u0445.<\/p>\n<p>  \u0422\u0435\u043c \u043d\u0435 \u043c\u0435\u043d\u0435\u0435, \u0434\u0430\u0436\u0435 \u0434\u043b\u044f \u043e\u0434\u043d\u043e\u0439 \u0442\u0430\u043a\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u043c\u043e\u0433\u0443\u0442 \u0431\u044b\u0442\u044c \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432, \u0438 \u0434\u043b\u044f \u0442\u0435\u0441\u0442\u043e\u0432\u043e\u0439 \u0432\u044b\u0431\u043e\u0440\u043a\u0438 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0440\u043e\u0432\u043d\u043e 10 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0437\u0430\u043f\u0438\u0441\u0435\u0439 \u0441\u043e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043e\u0439:<\/p>\n<ul>\n<li>tour_id \u2014 uint64 \u2014 \u0443\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u044b\u0439 ID \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u0438\u044f<\/li>\n<li>package_id \u2014 uint64 \u2014 ID \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0433\u043e \u043f\u0430\u043a\u0435\u0442\u0430 \u0442\u0443\u0440\u043e\u0432 (\u043f\u0430\u043a\u0435\u0442\u044b \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0438 \u043e\u0442\u0437\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0446\u0435\u043b\u0438\u043a\u043e\u043c)<\/li>\n<li>date_start \u2014 uint8 \u2014 \u0434\u0430\u0442\u0430 \u043f\u0440\u0438\u043b\u0435\u0442\u0430 \u2014 \u0447\u0438\u0441\u043b\u043e \u0434\u043d\u0435\u0439 \u0441 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u0433\u043e \u043c\u043e\u043c\u0435\u043d\u0442\u0430<\/li>\n<li>stars \u2014 uint8 \u2014 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0437\u0432\u0435\u0437\u0434 \u0443 \u043e\u0442\u0435\u043b\u044f + \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u044b\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0434\u043b\u044f \u0430\u043f\u0430\u0440\u0442\u0430\u043c\u0435\u043d\u0442\u043e\u0432<\/li>\n<li>pansion \u2014 uint8 \u2014 \u0442\u0438\u043f \u043f\u0438\u0442\u0430\u043d\u0438\u044f (Bed &#038; Breakfast, All Inclusive, etc)<\/li>\n<li>nights \u2014 uint8 \u2014 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u043f\u0440\u0435\u0431\u044b\u0432\u0430\u043d\u0438\u044f (\u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043d\u043e\u0447\u0435\u0439)<\/li>\n<li>region_id \u2014 uint16 \u2014 ID \u0440\u0435\u0433\u0438\u043e\u043d\u0430 \u043e\u0442\u0435\u043b\u044f<\/li>\n<li>hotel_id \u2014 uint32 \u2014 ID \u043e\u0442\u0435\u043b\u044f<\/li>\n<li>airport_id \u2014 uint8 \u2014 ID \u0430\u044d\u0440\u043e\u043f\u043e\u0440\u0442\u0430 \u043f\u0440\u0438\u043b\u0435\u0442\u0430<\/li>\n<li>price \u2014 uint16 \u2014 \u0446\u0435\u043d\u0430 \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u0432 \u0434\u043e\u043b\u043b\u0430\u0440\u0430\u0445<\/li>\n<\/ul>\n<p>  \u0414\u043b\u044f \u0440\u0430\u0437\u043d\u044b\u0445 \u0441\u0442\u0440\u0430\u043d \u0438 \u0440\u0430\u0437\u043d\u044b\u0445 \u0442\u0443\u0440\u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u043e\u0432 \u0441\u043f\u0438\u0441\u043e\u043a \u043c\u043e\u0436\u0435\u0442 \u043e\u0442\u043b\u0438\u0447\u0430\u0442\u044c\u0441\u044f (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043c\u043e\u0436\u0435\u0442 \u0442\u0430\u043a\u0436\u0435 \u043f\u0440\u0438\u0441\u0443\u0442\u0441\u0442\u0432\u043e\u0432\u0430\u0442\u044c \u0430\u044d\u0440\u043e\u043f\u043e\u0440\u0442 \u0432\u044b\u043b\u0435\u0442\u0430, \u0438\u043b\u0438 \u0446\u0435\u043d\u0430 \u0443\u043a\u0430\u0437\u0430\u043d\u0430 \u0432 \u0434\u0440\u0443\u0433\u043e\u0439 \u0432\u0430\u043b\u044e\u0442\u0435, \u0438 \u0442\u043e\u0433\u0434\u0430 \u043e\u043d\u0430 \u043d\u0435 \u043f\u043e\u043c\u0435\u0441\u0442\u0438\u0442\u0441\u044f \u0432 uint16, \u0438 \u0442.\u0434.), \u043d\u043e \u043c\u044b \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043c\u0441\u044f \u043d\u0430 \u044d\u0442\u043e\u043c \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0435, \u043a\u0430\u043a \u0441\u0430\u043c\u043e\u043c \u0431\u0430\u0437\u043e\u0432\u043e\u043c.<\/p>\n<p>  \u041a\u043e\u0434 \u0434\u043b\u044f \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u0438 \u043f\u0438\u0448\u0435\u0442\u0441\u044f \u0437\u0430 10 \u043c\u0438\u043d\u0443\u0442 \u043b\u044e\u0431\u044b\u043c \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0441\u0442\u043e\u043c, \u044f \u043f\u0440\u0438\u0432\u0435\u0434\u0443 \u043f\u0440\u0438\u043c\u0435\u0440 \u043d\u0430 go:<\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0421\u043a\u0440\u044b\u0442\u044b\u0439 \u0442\u0435\u043a\u0441\u0442<\/b><\/p>\n<div class=\"spoiler_text\">\n<pre><code class=\"go\">package main  import ( \t&quot;encoding\/csv&quot; \t&quot;flag&quot; \t&quot;math\/rand&quot; \t&quot;os&quot; \t&quot;strconv&quot; )  var n = flag.Int(&quot;n&quot;, 10000000, &quot;How many entries to generate&quot;)  func main() { \twr := csv.NewWriter(os.Stdout) \tdefer wr.Flush()  \twr.Write([]string{ \t\t&quot;tour_id&quot;, \t\t&quot;package_id&quot;, \t\t&quot;date_start&quot;, \t\t&quot;stars&quot;, \t\t&quot;pansion&quot;, \t\t&quot;nights&quot;, \t\t&quot;region_id&quot;, \t\t&quot;hotel_id&quot;, \t\t&quot;airport_id&quot;, \t\t&quot;price&quot;, \t})  \tfor i := 0; i &lt; *n; i++ { \t\twr.Write([]string{ \t\t\tstrconv.FormatInt(int64(i), 10), \t\t\tstrconv.FormatInt(rand.Int63(), 10), \t\t\tstrconv.FormatInt(rand.Int63n(90), 10), \t\t\tstrconv.FormatInt(rand.Int63n(10), 10), \t\t\tstrconv.FormatInt(rand.Int63n(10), 10), \t\t\tstrconv.FormatInt(rand.Int63n(30), 10), \t\t\tstrconv.FormatInt(rand.Int63n(1000), 10), \t\t\tstrconv.FormatInt(rand.Int63n(1000000), 10), \t\t\tstrconv.FormatInt(rand.Int63n(10), 10), \t\t\tstrconv.FormatInt(rand.Int63n(10000), 10), \t\t}) \t} } <\/code><\/pre>\n<p>  <\/div>\n<\/div>\n<p>  \u041f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u044b\u0439 csv-\u0444\u0430\u0439\u043b \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u043f\u043e\u0440\u044f\u0434\u043a\u0430 500 \u041c\u0431 \u0438 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 10 \u043c\u043b\u043d \u0437\u0430\u043f\u0438\u0441\u0435\u0439, \u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 tour_id \u043c\u043e\u043d\u043e\u0442\u043e\u043d\u043d\u043e \u0432\u043e\u0437\u0440\u0430\u0441\u0442\u0430\u0435\u0442, \u0430 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u043e\u043b\u044f \u0438\u043c\u0435\u044e\u0442 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u044b\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0432 \u0431\u043e\u043b\u0435\u0435-\u043c\u0435\u043d\u0435\u0435 \u043f\u0440\u0438\u0431\u043b\u0438\u0436\u0435\u043d\u043d\u044b\u0445 \u043a \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u0430\u0445.<\/p>\n<h3>\u041a\u0440\u0438\u0442\u0435\u0440\u0438\u0438 \u043f\u043e\u0438\u0441\u043a\u0430<\/h3>\n<p>  \u041d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0443\u043c\u0435\u0442\u044c \u0438\u0441\u043a\u0430\u0442\u044c \u043f\u043e \u043b\u044e\u0431\u044b\u043c \u043d\u0430\u0431\u043e\u0440\u0430\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0438\u0437 \u043f\u043e\u043b\u0435\u0439 \u0438 \u0441 \u043b\u044e\u0431\u043e\u0439 \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u043e\u0439, \u043d\u043e, \u043a\u0430\u043a \u043f\u0440\u0430\u0432\u0438\u043b\u043e, \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u044b \u0434\u0430\u0442 \u0432\u044b\u043b\u0435\u0442\u0430 \u0438 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0438\u043c\u0435\u044e\u0442 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0440\u0430\u0437\u0431\u0440\u043e\u0441 \u2014 \u043b\u044e\u0434\u0438 \u0440\u0435\u0434\u043a\u043e \u0438\u0449\u0443\u0442 \u0442\u0443\u0440\u044b \u0441 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u043e\u043c \u0434\u0430\u0442 \u0432\u044b\u043b\u0435\u0442\u0430, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0441 1 \u043c\u0430\u0440\u0442\u0430 \u043f\u043e 1 \u043c\u0430\u044f. \u041c\u044b \u043c\u043e\u0436\u0435\u043c \u0441\u0447\u0438\u0442\u0430\u0442\u044c, \u0447\u0442\u043e \u043f\u043e\u0438\u0441\u043a \u0441 \u0448\u0438\u0440\u043e\u043a\u0438\u043c \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u043e\u043c \u0434\u0430\u0442 \u0432\u044b\u043b\u0435\u0442\u0430 \u0442\u043e\u0436\u0435 \u0434\u043e\u043b\u0436\u0435\u043d \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c, \u043d\u043e \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432\u0440\u0435\u043c\u044f \u043e\u0442\u0432\u0435\u0442\u0430 \u0438 \u043f\u043e\u0442\u0440\u0435\u0431\u043b\u0435\u043d\u0438\u0435 \u0440\u0435\u0441\u0443\u0440\u0441\u043e\u0432 \u043d\u0443\u0436\u043d\u043e \u0434\u043b\u044f \u0441\u043b\u0443\u0447\u0430\u044f, \u043a\u043e\u0433\u0434\u0430 \u044d\u0442\u043e\u0442 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0432 \u0441\u0440\u0435\u0434\u043d\u0435\u043c \u043d\u0435 \u0431\u043e\u043b\u0435\u0435 10 \u0434\u043d\u0435\u0439. \u042d\u0442\u043e \u0437\u043d\u0430\u043d\u0438\u0435 \u043d\u0430\u043c \u043f\u0440\u0438\u0433\u043e\u0434\u0438\u0442\u0441\u044f \u043f\u0440\u0438 \u0432\u044b\u0431\u043e\u0440\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432.<\/p>\n<h3>\u0420\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u043d\u0430 MySQL<\/h3>\n<p>  \u042f \u0432\u044b\u0431\u0440\u0430\u043b MySQL \u043f\u043e\u0442\u043e\u043c\u0443, \u0447\u0442\u043e \u0445\u043e\u0440\u043e\u0448\u043e \u0437\u043d\u0430\u043a\u043e\u043c \u0441 \u044d\u0442\u043e\u0439 \u0431\u0430\u0437\u043e\u0439 \u0434\u0430\u043d\u043d\u044b\u0445, \u0430 \u0442\u0430\u043a\u0436\u0435 \u043f\u043e\u0442\u043e\u043c\u0443, \u0447\u0442\u043e \u043e\u043d\u0430 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0435\u043f\u043b\u043e\u0445\u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u0442 \u0434\u043b\u044f \u044d\u0442\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0438.<\/p>\n<p>  \u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c 3 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0440\u0430\u0437\u043d\u044b\u0445 \u043f\u043e\u0434\u0445\u043e\u0434\u0430: \u043f\u0440\u043e\u0441\u0442\u043e\u0439 InnoDB, InnoDB + primary key(date_start, id) \u0438 MyISAM. \u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0431\u0443\u0434\u0435\u0442 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e\u0439 \u0434\u043b\u044f \u0432\u0441\u0435\u0445 3 \u043f\u043e\u0434\u0445\u043e\u0434\u043e\u0432 \u0438 \u043e\u0442\u043b\u0438\u0447\u0438\u044f \u0431\u0443\u0434\u0443\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u0434\u0432\u0438\u0436\u043a\u0435 \u0438 \u0432 \u0442\u043e\u043c, \u043a\u0430\u043a\u0438\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u044b \u043c\u044b \u043d\u0430\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u043c:<\/p>\n<pre><code class=\"sql\">CREATE TABLE `tours` (   `tour_id` bigint(20) NOT NULL,   `package_id` bigint(20) NOT NULL,   `date_start` tinyint(4) NOT NULL,   `stars` tinyint(4) NOT NULL,   `pansion` tinyint(4) NOT NULL,   `nights` tinyint(4) NOT NULL,   `region_id` smallint(6) NOT NULL,   `hotel_id` int(11) NOT NULL,   `airport_id` tinyint(4) NOT NULL,   `price` smallint(6) NOT NULL ) <\/code><\/pre>\n<h3>InnoDB<\/h3>\n<p>  \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0439 \u0434\u0432\u0438\u0436\u043e\u043a InnoDB \u0441\u043e \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u043c\u0438 \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u043c\u0438 \u2014 <code>PRIMARY KEY (`tour_id`), KEY `date_start` (`date_start`)<\/code>. \u041a\u043b\u044e\u0447 \u043d\u0430 date_start \u043d\u0430\u043c \u0434\u043e\u043b\u0436\u0435\u043d \u0443\u0441\u043a\u043e\u0440\u0438\u0442\u044c \u0432\u044b\u0431\u043e\u0440\u043a\u0438 \u043f\u043e \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u0443 \u0434\u0430\u0442 \u0432\u044b\u043b\u0435\u0442\u0430, \u0430 PRIMARY KEY tour_id \u0441\u0434\u0435\u043b\u0430\u043d \u0441 \u0440\u0430\u0441\u0447\u0435\u0442\u043e\u043c \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e tour_id \u043c\u043e\u043d\u043e\u0442\u043e\u043d\u043d\u043e \u0432\u043e\u0437\u0440\u0430\u0441\u0442\u0430\u0435\u0442, \u0447\u0442\u043e \u043d\u0430\u043c \u0434\u043e\u043b\u0436\u043d\u043e \u0434\u0430\u0442\u044c \u043e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u0443\u044e \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c \u0432\u0441\u0442\u0430\u0432\u043a\u0438.<\/p>\n<p>  \u0412\u0441\u0442\u0430\u0432\u0438\u043c \u043d\u0430\u0448\u0438 \u0434\u0430\u043d\u043d\u044b\u0435 \u0432 \u0434\u0435\u0444\u043e\u043b\u0442\u043d\u0443\u044e \u0438\u043d\u0441\u0442\u0430\u043b\u043b\u044f\u0446\u0438\u044e MySQL 5.7.17 (innodb_buffer_pool_size=128 \u041c\u0431, \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u0441\u043c. \u043f\u043e\u0434 \u0441\u043f\u043e\u0439\u043b\u0435\u0440\u043e\u043c):  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0434\u0435\u0444\u043e\u043b\u0442\u043d\u044b\u0435 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 innodb<\/b><\/p>\n<div class=\"spoiler_text\">innodb_adaptive_flushing ON<br \/>  innodb_adaptive_flushing_lwm 10<br \/>  innodb_adaptive_hash_index ON<br \/>  innodb_adaptive_hash_index_parts 8<br \/>  innodb_adaptive_max_sleep_delay 150000<br \/>  innodb_api_bk_commit_interval 5<br \/>  innodb_api_disable_rowlock OFF<br \/>  innodb_api_enable_binlog OFF<br \/>  innodb_api_enable_mdl OFF<br \/>  innodb_api_trx_level 0<br \/>  innodb_autoextend_increment 64<br \/>  innodb_autoinc_lock_mode 1<br \/>  innodb_buffer_pool_chunk_size 134217728<br \/>  innodb_buffer_pool_dump_at_shutdown ON<br \/>  innodb_buffer_pool_dump_now OFF<br \/>  innodb_buffer_pool_dump_pct 25<br \/>  innodb_buffer_pool_filename ib_buffer_pool<br \/>  innodb_buffer_pool_instances 1<br \/>  innodb_buffer_pool_load_abort OFF<br \/>  innodb_buffer_pool_load_at_startup ON<br \/>  innodb_buffer_pool_load_now OFF<br \/>  innodb_buffer_pool_size 134217728<br \/>  innodb_change_buffer_max_size 25<br \/>  innodb_change_buffering all<br \/>  innodb_checksum_algorithm crc32<br \/>  innodb_checksums ON<br \/>  innodb_cmp_per_index_enabled OFF<br \/>  innodb_commit_concurrency 0<br \/>  innodb_compression_failure_threshold_pct 5<br \/>  innodb_compression_level 6<br \/>  innodb_compression_pad_pct_max 50<br \/>  innodb_concurrency_tickets 5000<br \/>  innodb_data_file_path ibdata1:12M:autoextend<br \/>  innodb_data_home_dir <br \/>  innodb_deadlock_detect ON<br \/>  innodb_default_row_format dynamic<br \/>  innodb_disable_sort_file_cache OFF<br \/>  innodb_doublewrite ON<br \/>  innodb_fast_shutdown 1<br \/>  innodb_file_format Barracuda<br \/>  innodb_file_format_check ON<br \/>  innodb_file_format_max Barracuda<br \/>  innodb_file_per_table ON<br \/>  innodb_fill_factor 100<br \/>  innodb_flush_log_at_timeout 1<br \/>  innodb_flush_log_at_trx_commit 1<br \/>  innodb_flush_method <br \/>  innodb_flush_neighbors 1<br \/>  innodb_flush_sync ON<br \/>  innodb_flushing_avg_loops 30<br \/>  innodb_force_load_corrupted OFF<br \/>  innodb_force_recovery 0<br \/>  innodb_ft_aux_table <br \/>  innodb_ft_cache_size 8000000<br \/>  innodb_ft_enable_diag_print OFF<br \/>  innodb_ft_enable_stopword ON<br \/>  innodb_ft_max_token_size 84<br \/>  innodb_ft_min_token_size 3<br \/>  innodb_ft_num_word_optimize 2000<br \/>  innodb_ft_result_cache_limit 2000000000<br \/>  innodb_ft_server_stopword_table <br \/>  innodb_ft_sort_pll_degree 2<br \/>  innodb_ft_total_cache_size 640000000<br \/>  innodb_ft_user_stopword_table <br \/>  innodb_io_capacity 200<br \/>  innodb_io_capacity_max 2000<br \/>  innodb_large_prefix ON<br \/>  innodb_lock_wait_timeout 50<br \/>  innodb_locks_unsafe_for_binlog OFF<br \/>  innodb_log_buffer_size 16777216<br \/>  innodb_log_checksums ON<br \/>  innodb_log_compressed_pages ON<br \/>  innodb_log_file_size 50331648<br \/>  innodb_log_files_in_group 2<br \/>  innodb_log_group_home_dir .\/<br \/>  innodb_log_write_ahead_size 8192<br \/>  innodb_lru_scan_depth 1024<br \/>  innodb_max_dirty_pages_pct 75.000000<br \/>  innodb_max_dirty_pages_pct_lwm 0.000000<br \/>  innodb_max_purge_lag 0<br \/>  innodb_max_purge_lag_delay 0<br \/>  innodb_max_undo_log_size 1073741824<br \/>  innodb_monitor_disable <br \/>  innodb_monitor_enable <br \/>  innodb_monitor_reset <br \/>  innodb_monitor_reset_all <br \/>  innodb_old_blocks_pct 37<br \/>  innodb_old_blocks_time 1000<br \/>  innodb_online_alter_log_max_size 134217728<br \/>  innodb_open_files 2000<br \/>  innodb_optimize_fulltext_only OFF<br \/>  innodb_page_cleaners 1<br \/>  innodb_page_size 16384<br \/>  innodb_print_all_deadlocks OFF<br \/>  innodb_purge_batch_size 300<br \/>  innodb_purge_rseg_truncate_frequency 128<br \/>  innodb_purge_threads 4<br \/>  innodb_random_read_ahead OFF<br \/>  innodb_read_ahead_threshold 56<br \/>  innodb_read_io_threads 4<br \/>  innodb_read_only OFF<br \/>  innodb_replication_delay 0<br \/>  innodb_rollback_on_timeout OFF<br \/>  innodb_rollback_segments 128<br \/>  innodb_sort_buffer_size 1048576<br \/>  innodb_spin_wait_delay 6<br \/>  innodb_stats_auto_recalc ON<br \/>  innodb_stats_include_delete_marked OFF<br \/>  innodb_stats_method nulls_equal<br \/>  innodb_stats_on_metadata OFF<br \/>  innodb_stats_persistent ON<br \/>  innodb_stats_persistent_sample_pages 20<br \/>  innodb_stats_sample_pages 8<br \/>  innodb_stats_transient_sample_pages 8<br \/>  innodb_status_output OFF<br \/>  innodb_status_output_locks OFF<br \/>  innodb_strict_mode ON<br \/>  innodb_support_xa ON<br \/>  innodb_sync_array_size 1<br \/>  innodb_sync_spin_loops 30<br \/>  innodb_table_locks ON<br \/>  innodb_temp_data_file_path ibtmp1:12M:autoextend<br \/>  innodb_thread_concurrency 0<br \/>  innodb_thread_sleep_delay 10000<br \/>  innodb_tmpdir <br \/>  innodb_undo_directory .\/<br \/>  innodb_undo_log_truncate OFF<br \/>  innodb_undo_logs 128<br \/>  innodb_undo_tablespaces 0<br \/>  innodb_use_native_aio OFF<br \/>  innodb_version 5.7.17<br \/>  innodb_write_io_threads 4  <\/div>\n<\/div>\n<pre><code class=\"sql\">LOAD DATA LOCAL INFILE 'tours.csv' INTO TABLE tours FIELDS TERMINATED BY ','<\/code><\/pre>\n<p>  \u0412\u043e \u0432\u0440\u0435\u043c\u044f \u0437\u0430\u043b\u0438\u0432\u043a\u0438 \u0443\u0431\u0435\u0434\u0438\u043c\u0441\u044f, \u0447\u0442\u043e \u0443\u0437\u043a\u0438\u043c \u043c\u0435\u0441\u0442\u043e\u043c \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0438\u043c\u0435\u043d\u043d\u043e MySQL-\u0441\u0435\u0440\u0432\u0435\u0440, \u0430 \u043d\u0435 \u043a\u043b\u0438\u0435\u043d\u0442 (CPU usage \u043a\u043b\u0438\u0435\u043d\u0442\u0430 \u043d\u0435 \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u0442\u044c 100%) \u0438 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043d\u0430 \u0432\u0440\u0435\u043c\u044f \u0438\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u0430:<\/p>\n<pre><code>Query OK, 10000000 rows affected, 11 warnings (1 min 35.09 sec) Records: 10000001  Deleted: 0  Skipped: 1  Warnings: 11 <\/code><\/pre>\n<p>  \u041a\u0430\u0436\u0435\u0442\u0441\u044f, \u0447\u0442\u043e 1,5 \u043c\u0438\u043d\u0443\u0442\u044b \u0434\u043b\u044f \u0432\u0441\u0442\u0430\u0432\u043a\u0438 10 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0437\u0430\u043f\u0438\u0441\u0435\u0439 \u2014 \u044d\u0442\u043e \u043e\u043a \u0434\u043b\u044f InnoDB. \u0412\u043e\u0440\u043d\u0438\u043d\u0433\u0438 \u043e\u0442\u043d\u043e\u0441\u044f\u0442\u0441\u044f \u043a \u043f\u0435\u0440\u0432\u043e\u0439 \u0441\u0442\u0440\u043e\u0447\u043a\u0435 \u0432 CSV-\u0444\u0430\u0439\u043b\u0435, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u0442\u0430\u043c \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u044b \u0438\u043c\u0435\u043d\u0430 \u0441\u0442\u043e\u043b\u0431\u0446\u043e\u0432.<\/p>\n<p>  \u041f\u043e\u043b\u0443\u0447\u0438\u0432\u0448\u0438\u0439\u0441\u044f \u0440\u0430\u0437\u043c\u0435\u0440 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u2014 490 \u041c\u0431 \u0434\u0430\u043d\u043d\u044b\u0445 \u0438 162 \u041c\u0431 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432. \u0412 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u0430 MySQL \u0437\u0430\u043f\u0438\u0441\u0430\u043b \u043d\u0430 \u0434\u0438\u0441\u043a 3,5 \u0413\u0431 \u0438 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0430 CPU \u0431\u044b\u043b\u0430 \u0432 \u0440\u0430\u0439\u043e\u043d\u0435 100% (\u0443\u0442\u0438\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043e 1 \u044f\u0434\u0440\u043e \u0438\u0437 4 \u043d\u0430 \u0442\u0435\u0441\u0442\u043e\u0432\u043e\u043c \u043d\u043e\u0443\u0442\u0431\u0443\u043a\u0435).<\/p>\n<p>  \u041f\u0435\u0440\u0435\u0434 \u0442\u0435\u043c, \u043a\u0430\u043a \u0434\u0435\u043b\u0430\u0442\u044c \u043f\u043e\u0438\u0441\u043a\u043e\u0432\u044b\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b, \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043d\u0430 \u0434\u0440\u0443\u0433\u0438\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0435 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u0432\u0441\u0442\u0430\u0432\u043a\u0438 \u0434\u0430\u043d\u043d\u044b\u0445.<\/p>\n<h3>InnoDB + PRIMARY KEY(date_start, tour_id)<\/h3>\n<p>  \u041f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043c\u044b \u0437\u0430\u0440\u0430\u043d\u0435\u0435 \u0437\u043d\u0430\u0435\u043c, \u0447\u0442\u043e \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0431\u0443\u0434\u0443\u0442 \u0437\u0430\u0442\u0440\u0430\u0433\u0438\u0432\u0430\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d \u0434\u0430\u0442 \u0432\u044b\u043b\u0435\u0442\u0430, \u043c\u043e\u0436\u043d\u043e \u043a\u043b\u0430\u0441\u0442\u0435\u0440\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0435 \u043f\u043e \u0434\u0430\u0442\u0435 \u0432\u044b\u043b\u0435\u0442\u0430 \u0432\u043c\u0435\u0441\u0442\u043e tour_id \u2014 \u0432 \u044d\u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0447\u0442\u0435\u043d\u0438\u0435 \u043f\u043e \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u0443 date_start \u0431\u0443\u0434\u0435\u0442 \u0434\u0430\u0432\u0430\u0442\u044c \u043c\u0435\u043d\u044c\u0448\u0435 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u043e\u0433\u043e \u0447\u0442\u0435\u043d\u0438\u044f \u0441 \u0434\u0438\u0441\u043a\u0430 (\u0438\u043b\u0438 \u0438\u0437 buffer_pool), \u0430 \u0437\u043d\u0430\u0447\u0438\u0442 \u043f\u043e\u0438\u0441\u043a \u043f\u043e \u0442\u0430\u043a\u043e\u0439 \u0442\u0430\u0431\u043b\u0438\u0446\u0435 \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u0442\u044c \u0431\u044b\u0441\u0442\u0440\u0435\u0435.<\/p>\n<p>  \u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c, \u043a\u0430\u043a \u043e\u0431\u0441\u0442\u043e\u044f\u0442 \u0434\u0435\u043b\u0430 \u0441\u043e \u0432\u0441\u0442\u0430\u0432\u043a\u043e\u0439:<\/p>\n<pre><code>Query OK, 10000001 rows affected, 10 warnings (1 min 13.34 sec) Records: 10000001  Deleted: 0  Skipped: 0  Warnings: 10 <\/code><\/pre>\n<p>  \u0412\u043e\u043f\u0440\u0435\u043a\u0438 \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f\u043c, \u0432\u0441\u0442\u0430\u0432\u043a\u0430 \u0432 \u0442\u0430\u043a\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u043f\u0440\u043e\u0448\u043b\u0430 \u0434\u0430\u0436\u0435 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0431\u044b\u0441\u0442\u0440\u0435\u0435, \u0447\u0435\u043c \u0432 \u00ab\u043e\u0431\u044b\u0447\u043d\u0443\u044e\u00bb \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443. \u0412\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u044d\u0442\u043e \u0441\u0432\u044f\u0437\u0430\u043d\u043e \u0441 \u0442\u0435\u043c, \u0447\u0442\u043e \u0443 \u043d\u0430\u0441 \u043d\u0435\u0442 \u00ab\u043b\u0438\u0448\u043d\u0435\u0433\u043e\u00bb \u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u043f\u043e date_start, \u0438 \u043e\u043d \u0432\u043a\u043b\u044e\u0447\u0435\u043d \u0432 PRIMARY KEY. \u041d\u0430 \u0434\u0438\u0441\u043a \u0431\u044b\u043b\u043e \u0437\u0430\u043f\u0438\u0441\u0430\u043d\u043e \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043c\u0435\u043d\u044c\u0448\u0435, \u0447\u0435\u043c \u0432 \u043f\u0440\u043e\u0448\u043b\u044b\u0439 \u0440\u0430\u0437 \u2014 \u0432\u0441\u0435\u0433\u043e 3 \u0413\u0431.<\/p>\n<p>  \u0420\u0430\u0437\u043c\u0435\u0440 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u2014 538 \u041c\u0431 \u0434\u0430\u043d\u043d\u044b\u0445 \u0438 0 \u041c\u0431 \u0438\u043d\u0434\u0435\u043a\u0441\u0430 (\u0432\u0442\u043e\u0440\u0438\u0447\u043d\u044b\u0445 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043d\u0435\u0442, \u0430 PRIMARY KEY \u0437\u0430\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0447\u0430\u0441\u0442\u044c\u044e \u0434\u0430\u043d\u043d\u044b\u0445 \u0432 InnoDB)<\/p>\n<h3>MyISAM<\/h3>\n<p>  \u0412 \u0431\u044b\u043b\u044b\u0435 \u0433\u043e\u0434\u044b MyISAM \u0431\u044b\u043b \u0434\u0432\u0438\u0436\u043a\u043e\u043c \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u0432 MySQL \u0438 \u0441\u043b\u0430\u0432\u0438\u043b\u0441\u044f \u0441\u0432\u043e\u0435\u0439 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c\u044e \u0432\u0441\u0442\u0430\u0432\u043a\u0438 \u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f FULL SCAN. \u0427\u0435\u043c \u043d\u0435 \u0438\u0434\u0435\u0430\u043b\u044c\u043d\u044b\u0439 \u043a\u0430\u043d\u0434\u0438\u0434\u0430\u0442 \u0434\u043b\u044f \u043d\u0430\u0448\u0435\u0439 \u0437\u0430\u0434\u0430\u0447\u0438? \u0421\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0430 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u043e\u0441\u0442\u0430\u0435\u0442\u0441\u044f \u0442\u0430\u043a\u043e\u0439 \u0436\u0435, \u043a\u0430\u043a \u0432 \u0441\u043b\u0443\u0447\u0430\u0435 \u0441 \u043f\u0435\u0440\u0432\u044b\u043c \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u043c InnoDB.<\/p>\n<pre><code>Query OK, 10000000 rows affected, 11 warnings (40.39 sec) Records: 10000001  Deleted: 0  Skipped: 1  Warnings: 11 <\/code><\/pre>\n<p>  \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442, \u0431\u0435\u0437\u0443\u0441\u043b\u043e\u0432\u043d\u043e, \u043f\u043e\u043b\u0443\u0447\u0448\u0435, \u0445\u043e\u0442\u044f \u0438 \u043d\u0435 \u043d\u0430 \u043f\u043e\u0440\u044f\u0434\u043e\u043a. \u0422\u044e\u043d\u0438\u043d\u0433\u043e\u043c \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u043a \u043c\u043e\u0436\u043d\u043e \u0434\u043e\u0431\u0438\u0442\u044c\u0441\u044f \u043b\u0443\u0447\u0448\u0438\u0445 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 \u043a\u0430\u043a \u0432 \u0441\u043b\u0443\u0447\u0430\u0435 MyISAM, \u0442\u0430\u043a \u0438 \u0432 \u0441\u043b\u0443\u0447\u0430\u0435 InnoDB, \u043d\u043e \u044d\u0442\u043e \u0442\u0435\u043c\u0430 \u0434\u043b\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0438. \u041d\u0430 \u0434\u0438\u0441\u043a \u0431\u044b\u043b\u043e \u0437\u0430\u043f\u0438\u0441\u0430\u043d\u043e 350 \u041c\u0431, \u0430 \u0440\u0430\u0437\u043c\u0435\u0440 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u2014 286 \u041c\u0431 \u0434\u0430\u043d\u043d\u044b\u0445 + 205 \u041c\u0431 \u0438\u043d\u0434\u0435\u043a\u0441\u0430. \u041f\u043e\u0447\u0435\u043c\u0443, \u0441\u043e\u0433\u043b\u0430\u0441\u043d\u043e \u043f\u0440\u0438\u0431\u043e\u0440\u0430\u043c, \u043d\u0430 \u0434\u0438\u0441\u043a \u0431\u044b\u043b\u043e \u0437\u0430\u043f\u0438\u0441\u0430\u043d\u043e \u043c\u0435\u043d\u044c\u0448\u0435, \u0447\u0435\u043c \u0440\u0430\u0437\u043c\u0435\u0440 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0432 MyISAM, \u044f \u043f\u043e\u043d\u044f\u0442\u044c \u043d\u0435 \u0441\u043c\u043e\u0433. \u0427\u0438\u0442\u0430\u0442\u0435\u043b\u044c \u043c\u043e\u0436\u0435\u0442 \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c \u0432\u043e\u0441\u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0441\u0442\u0438 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442 \u043d\u0430 \u0441\u0432\u043e\u0435\u043c \u0438\u043d\u0441\u0442\u0430\u043d\u0441\u0435 MySQL \u0438 \u0441\u0440\u0430\u0432\u043d\u0438\u0442\u044c \u0446\u0438\u0444\u0440\u044b.<\/p>\n<h3>ClickHouse<\/h3>\n<p>  \u041d\u0443 \u0438 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u043c \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u043c \u0431\u0443\u0434\u0435\u0442 \u0431\u0430\u0437\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 \u043e\u0442 \u044f\u043d\u0434\u0435\u043a\u0441\u0430 \u043f\u043e\u0434 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435\u043c <a href=\"https:\/\/clickhouse.yandex\/\">ClickHouse<\/a>. \u042d\u0442\u043e \u043a\u043e\u043b\u043e\u043d\u043e\u0447\u043d\u0430\u044f \u0431\u0430\u0437\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 \u0441 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u043c \u0440\u0430\u0441\u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u0438\u0432\u0430\u043d\u0438\u0435\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0438 \u043a\u0443\u0447\u0435\u0439 \u0434\u0440\u0443\u0433\u0438\u0445 \u043d\u0438\u0448\u0442\u044f\u043a\u043e\u0432. \u0421\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0442 \u0431\u0438\u043d\u0430\u0440\u043d\u044b\u0435 \u0441\u0431\u043e\u0440\u043a\u0438 \u043f\u043e\u0434 Linux \u0438 \u0434\u0430\u0436\u0435 Docker-\u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u044b \u0438 \u0437\u0430\u044f\u0432\u043b\u0435\u043d\u0430 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0430 macOS. \u0411\u0438\u043d\u0430\u0440\u043d\u044b\u0445 \u0441\u0431\u043e\u0440\u043e\u043a \u043f\u043e\u0434 macOS \u044f \u043d\u0430\u0439\u0442\u0438 \u043d\u0435 \u0441\u043c\u043e\u0433, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0441\u043e\u0431\u0440\u0430\u043b \u0438 \u0432\u044b\u043b\u043e\u0436\u0438\u043b: <a href=\"https:\/\/yadi.sk\/d\/RffdbxaM3GL7Ac\">yadi.sk\/d\/RffdbxaM3GL7Ac<\/a> (\u0441\u0431\u043e\u0440\u043a\u0430 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 gcc-6, \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u0434\u0435\u0441\u044f\u0442\u043a\u043e\u0432 \u0433\u0438\u0433\u0430\u0431\u0430\u0439\u0442 \u043c\u0435\u0441\u0442\u0430 \u0438 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e 2 \u0447\u0430\u0441\u043e\u0432 \u043d\u0430 \u043c\u043e\u0435\u043c \u043d\u043e\u0443\u0442\u0431\u0443\u043a\u0435). \u0422\u0435\u0441\u0442\u044b \u044f \u0431\u0443\u0434\u0443 \u0433\u043e\u043d\u044f\u0442\u044c \u043d\u0430 macOS.<\/p>\n<p>  \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0442\u0430\u0431\u043b\u0438\u0446\u0443:  <\/p>\n<pre><code>CREATE TABLE tours (     tour_id UInt64,      package_id UInt64,      date_start UInt8,      stars UInt8,      pansion UInt8,      nights UInt8,      region_id UInt16,      hotel_id UInt32,      airport_id UInt8,      price UInt16,      date Date MATERIALIZED toDate(date_start) ) ENGINE = MergeTree(date, date_start, 8192) <\/code><\/pre>\n<p>  \u041f\u0440\u0438 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0442\u0438\u043f\u0430 MergeTree (\u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0443\u0435\u0442\u0441\u044f \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e) \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u0441\u0442\u043e\u043b\u0431\u0435\u0446 \u0441 \u0434\u0430\u0442\u043e\u0439 (\u043f\u043e \u043d\u0435\u043c\u0443 \u043e\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0448\u0430\u0440\u0434\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435). \u0417\u0434\u0435\u0441\u044c \u044f \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u043e\u043b\u0435\u043d\u0438\u043b\u0441\u044f \u0438 \u0441\u0434\u0435\u043b\u0430\u043b \u043f\u0440\u043e\u0441\u0442\u043e MATERIALIZED \u0441\u0442\u043e\u043b\u0431\u0435\u0446 date \u0441\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c toDate(date_start). \u0412 \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0430\u043c\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0449\u0435 \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u043e\u0441\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441\u0442\u043e\u043b\u0431\u0435\u0446 date_start \u0441 \u0442\u0438\u043f\u043e\u043c Date \u2014 \u0432 clickhouse \u0434\u0430\u0442\u0430 \u043c\u043d\u043e\u0433\u043e \u043c\u0435\u0441\u0442\u0430 \u043d\u0435 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u0431\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u043a\u043e\u043c\u043f\u0440\u0435\u0441\u0441\u0438\u0438 \u0441\u0442\u043e\u043b\u0431\u0446\u043e\u0432.<\/p>\n<h3>ClickHouse, \u0432\u0441\u0442\u0430\u0432\u043a\u0430 \u0434\u0430\u043d\u043d\u044b\u0445<\/h3>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u0432\u0441\u0442\u0430\u0432\u0438\u043c \u0434\u0430\u043d\u043d\u044b\u0435:<\/p>\n<pre><code>$ cat tours.csv | pv | clickhouse --client --query 'INSERT INTO tours FORMAT CSVWithNames' 524MiB 0:00:04 [ 123MiB\/s] <\/code><\/pre>\n<p>  \u0415\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u0435\u0449\u0451 \u043d\u0435 \u0443\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u0430 \u0443\u0442\u0438\u043b\u0438\u0442\u0430 pv \u2014 \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0443\u044e \u043f\u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c, \u043e\u043d\u0430 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442\u044c \u043f\u0435\u0447\u0430\u0442\u0430\u0442\u044c \u043f\u0440\u043e\u0433\u0440\u0435\u0441\u0441 \u0438\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0439 \u0438 \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442, \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0431\u0430\u0439\u0442 \u043f\u0440\u043e\u0448\u043b\u043e \u0447\u0435\u0440\u0435\u0437 \u043f\u0430\u0439\u043f.<\/p>\n<p>  \u041c\u043e\u0436\u043d\u043e \u0432\u0438\u0434\u0435\u0442\u044c, \u0447\u0442\u043e \u0432\u0441\u0442\u0430\u0432\u043a\u0430 csv-\u0444\u0430\u0439\u043b\u0430 \u043f\u0440\u043e\u0438\u0437\u043e\u0448\u043b\u0430 \u0437\u0430 4 \u0441\u0435\u043a\u0443\u043d\u0434\u044b \u0441\u043e \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c\u044e \u0432\u0441\u0442\u0430\u0432\u043a\u0438 \u043f\u043e\u0440\u044f\u0434\u043a\u0430 100 \u041c\u0431\/\u0441\u0435\u043a (\u043a\u0430\u043a \u0438 \u0437\u0430\u044f\u0432\u043b\u0435\u043d\u043e \u0430\u0432\u0442\u043e\u0440\u0430\u043c\u0438). \u041f\u0440\u0438 \u0432\u0441\u0442\u0430\u0432\u043a\u0435 \u0441\u0435\u0440\u0432\u0435\u0440 \u043f\u043e\u0442\u0440\u0430\u0442\u0438\u043b 7 \u0441\u0435\u043a\u0443\u043d\u0434 \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440\u043d\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438.<\/p>\n<p>  \u0420\u0430\u0437\u043c\u0435\u0440 \u0434\u0430\u043d\u043d\u044b\u0445 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 378 \u041c\u0431, \u0438 \u043d\u0430 \u0434\u0438\u0441\u043a \u0431\u044b\u043b\u043e \u0437\u0430\u043f\u0438\u0441\u0430\u043d\u043e \u0442\u043e\u0436\u0435 378 \u041c\u0431 (\u043f\u043e \u0432\u0441\u0435\u0439 \u0432\u0438\u0434\u0438\u043c\u043e\u0441\u0442\u0438, \u0432\u0435\u0441\u044c \u043e\u0431\u044a\u0435\u043c \u0431\u044b\u043b \u043e\u0442\u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u043d \u0432 \u043f\u0430\u043c\u044f\u0442\u0438 \u0438 \u0437\u0430\u043f\u0438\u0441\u0430\u043d \u043e\u0434\u043d\u0438\u043c \u043a\u0443\u0441\u043a\u043e\u043c).<\/p>\n<p>  \u041a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043d\u0430\u0448\u0438 \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u044b, \u0443 \u043d\u0430\u0441 \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c \u0438\u0437\u0432\u043b\u0435\u0447\u044c \u0437\u043d\u0430\u0447\u0438\u043c\u0443\u044e \u043f\u043e\u043b\u044c\u0437\u0443 \u043e\u0442 \u043a\u043e\u043c\u043f\u0440\u0435\u0441\u0441\u0438\u0438 \u0441\u0442\u043e\u043b\u0431\u0446\u043e\u0432. \u0420\u0435\u0430\u043b\u044c\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0434\u043e\u043b\u0436\u043d\u044b \u0441\u0436\u0438\u043c\u0430\u0442\u044c\u0441\u044f \u043b\u0443\u0447\u0448\u0435, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0438\u0442\u043e\u0433\u043e\u0432\u044b\u0439 \u0440\u0430\u0437\u043c\u0435\u0440 \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u0442\u044c \u0435\u0449\u0451 \u043c\u0435\u043d\u044c\u0448\u0435.<\/p>\n<h3>\u0412\u0440\u0435\u043c\u0435\u043d\u0430 \u0432\u0441\u0442\u0430\u0432\u043a\u0438 \u0434\u0430\u043d\u043d\u044b\u0445, \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u0435<\/h3>\n<p>  \u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0441\u043e\u0431\u0435\u0440\u0435\u043c \u0432\u0441\u0435 \u043f\u043e\u043a\u0430\u0437\u0430\u0442\u0435\u043b\u0438 \u0432\u0441\u0442\u0430\u0432\u043a\u0438 \u0432 \u043e\u0434\u043d\u0443 \u0442\u0430\u0431\u043b\u0438\u0446\u0443:<\/p>\n<table>\n<tr>\n<th>\u041c\u0435\u0442\u043e\u0434<\/th>\n<th>\u0412\u0440\u0435\u043c\u044f<\/th>\n<th>\u0420\u0430\u0437\u043c\u0435\u0440 \u0442\u0430\u0431\u043b\u0438\u0446\u044b<\/th>\n<th>\u0417\u0430\u043f\u0438\u0441\u0430\u043d\u043e \u043d\u0430 \u0434\u0438\u0441\u043a<\/th>\n<\/tr>\n<tr>\n<td>InnoDB<\/td>\n<td>95 \u0441\u0435\u043a\u0443\u043d\u0434<\/td>\n<td>652 \u041c\u0431<\/td>\n<td>3,5 \u0413\u0431<\/td>\n<\/tr>\n<tr>\n<td>InnoDB+PK<\/td>\n<td>73 \u0441\u0435\u043a\u0443\u043d\u0434\u044b<\/td>\n<td>538 \u041c\u0431<\/td>\n<td>3,0 \u0413\u0431<\/td>\n<\/tr>\n<tr>\n<td>MyISAM<\/td>\n<td>40 \u0441\u0435\u043a\u0443\u043d\u0434<\/td>\n<td>491 \u041c\u0431<\/td>\n<td>350 \u041c\u0431?<\/td>\n<\/tr>\n<tr>\n<td>ClickHouse<\/td>\n<td>4 \u0441\u0435\u043a\u0443\u043d\u0434\u044b<\/td>\n<td> 378 \u041c\u0431<\/td>\n<td>378 \u041c\u0431<\/td>\n<\/tr>\n<\/table>\n<h3>\u0412\u044b\u0431\u043e\u0440\u043a\u0430<\/h3>\n<p>  \u041c\u044b \u0431\u0443\u0434\u0435\u043c \u0434\u0435\u043b\u0430\u0442\u044c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0432\u044b\u0431\u043e\u0440\u043e\u043a, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0442 \u0431\u043e\u043b\u0435\u0435-\u043c\u0435\u043d\u0435\u0435 \u043f\u0440\u0430\u0432\u0434\u0438\u0432\u044b\u043c \u0432\u0438\u0434\u0430\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u0438\u0445\u043e\u0434\u044f\u0442 \u0432 \u043f\u043e\u0438\u0441\u043a \u043f\u043e \u0442\u0443\u0440\u0430\u043c:<\/p>\n<pre><code class=\"sql\">-- 1. \u00ab\u0413\u043e\u0440\u044f\u0449\u0438\u0435 \u0442\u0443\u0440\u044b\u00bb SELECT * FROM tours ORDER BY price ASC LIMIT 20;  -- 2. \u00ab\u0413\u043e\u0440\u044f\u0449\u0438\u0435 \u0442\u0443\u0440\u044b\u00bb \u0432 \u0438\u043d\u0442\u0435\u0440\u0432\u0430\u043b\u0435 10 \u0434\u043d\u0435\u0439 (1\/9 \u0432\u0441\u0435\u0445 \u0437\u0430\u043f\u0438\u0441\u0435\u0439) SELECT * FROM tours WHERE date_start BETWEEN 40 AND 50 ORDER BY price ASC LIMIT 20;  -- 3. 5 \u043d\u043e\u0447\u0435\u0439 \u0441 \u0446\u0435\u043d\u043e\u0439 \u043e\u0442 500 \u0434\u043e 600 \u0434\u043e\u043b\u043b\u0430\u0440\u043e\u0432 SELECT * FROM tours WHERE nights = 5 AND price BETWEEN 500 AND 600 ORDER BY price ASC LIMIT 20;  -- 4. \u0446\u0435\u043d\u0430 \u043e\u0442 500 \u0434\u043e 600 \u0434\u043e\u043b\u043b\u0430\u0440\u043e\u0432, \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0438 \u0447\u0438\u0441\u043b\u043e \u0437\u0432\u0435\u0437\u0434 SELECT * FROM tours WHERE price BETWEEN 500 AND 600 ORDER BY nights DESC, stars DESC LIMIT 20;  -- 5. \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0439 \u043e\u0442\u0435\u043b\u044c \u0432 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u044b\u0435 \u0434\u0430\u0442\u044b SELECT * FROM tours WHERE date_start BETWEEN 10 AND 20 AND hotel_id = 767036 ORDER BY price LIMIT 20; <\/code><\/pre>\n<p>  \u0414\u043b\u044f MyISAM \u0432 \u0441\u043a\u043e\u0431\u043a\u0430\u0445 \u0443\u043a\u0430\u0437\u0430\u043d\u044b \u0432\u0440\u0435\u043c\u0435\u043d\u0430 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432, \u0435\u0441\u043b\u0438 \u0443\u043a\u0430\u0437\u0430\u0442\u044c IGNORE INDEX(date_start).<br \/>  \u0414\u043b\u044f ClickHouse \u0432 \u0441\u043a\u043e\u0431\u043a\u0430\u0445 \u0443\u043a\u0430\u0437\u0430\u043d\u044b \u0432\u0440\u0435\u043c\u0435\u043d\u0430 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432, \u0435\u0441\u043b\u0438 \u0432\u044b\u0431\u0438\u0440\u0430\u0442\u044c \u043d\u0435 *, \u0430 \u0442\u043e\u043b\u044c\u043a\u043e tour_id \u0438 price.<\/p>\n<p>  \u0418\u0442\u0430\u043a, \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b:  <\/p>\n<table>\n<tr>\n<th>\u041c\u0435\u0442\u043e\u0434<\/th>\n<th>1, \u043c\u0441<\/th>\n<th>2, \u043c\u0441<\/th>\n<th>3, \u043c\u0441<\/th>\n<th>4, \u043c\u0441<\/th>\n<th>5, \u043c\u0441<\/th>\n<\/tr>\n<tr>\n<td><b>InnoDB<\/b><\/td>\n<td>4300<\/td>\n<td><b>3800<\/b><\/td>\n<td>3800<\/td>\n<td>3800<\/td>\n<td>3700<\/td>\n<\/tr>\n<tr>\n<td><b>InnoDB+PK<\/b><\/td>\n<td>4600<\/td>\n<td><b>600<\/b><\/td>\n<td>4000<\/td>\n<td>4000<\/td>\n<td>540<\/td>\n<\/tr>\n<tr>\n<td><b>MyISAM<\/b><\/td>\n<td>1300<\/td>\n<td><b>1600<\/b> (1000)<\/td>\n<td>800<\/td>\n<td>700<\/td>\n<td>1500 (670)<\/td>\n<\/tr>\n<tr>\n<td><b>ClickHouse<\/b><\/td>\n<td>120 (40)<\/td>\n<td>40 (14)<\/td>\n<td>150 (54)<\/td>\n<td>180 (80)<\/td>\n<td>14 (8)<\/td>\n<\/tr>\n<\/table>\n<p>  \u0418 \u0442\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0441 \u0445\u043e\u043b\u043e\u0434\u043d\u044b\u043c \u043a\u0435\u0448\u043e\u043c (\u043d\u0430 \u043d\u043e\u0443\u0442\u0431\u0443\u0447\u043d\u043e\u043c SSD):  <\/p>\n<table>\n<tr>\n<th>\u041c\u0435\u0442\u043e\u0434<\/th>\n<th>1, \u043c\u0441<\/th>\n<th>2, \u043c\u0441<\/th>\n<th>3, \u043c\u0441<\/th>\n<th>4, \u043c\u0441<\/th>\n<th>5, \u043c\u0441<\/th>\n<\/tr>\n<tr>\n<td><b>InnoDB<\/b><\/td>\n<td>5500<\/td>\n<td><b>5000<\/b><\/td>\n<td>4800<\/td>\n<td>4700<\/td>\n<td>4700<\/td>\n<\/tr>\n<tr>\n<td><b>InnoDB+PK<\/b><\/td>\n<td><b>12700<\/b><\/td>\n<td>1960<\/td>\n<td><b>12100<\/b><\/td>\n<td>12000<\/td>\n<td>1720<\/td>\n<\/tr>\n<tr>\n<td><b>MyISAM<\/b><\/td>\n<td><b>14800<\/b> (1060)<\/td>\n<td>800<\/td>\n<td>920<\/td>\n<td>799<\/td>\n<td>14900 (767)<\/td>\n<\/tr>\n<tr>\n<td><b>ClickHouse<\/b><\/td>\n<td>570 (188)<\/td>\n<td>177 (90)<\/td>\n<td>591 (224)<\/td>\n<td>608 (254)<\/td>\n<td>122 (55)<\/td>\n<\/tr>\n<\/table>\n<h3>\u0410\u043d\u0430\u043b\u0438\u0437<\/h3>\n<p>  \u041c\u043e\u0436\u043d\u043e \u0432\u0438\u0434\u0435\u0442\u044c, \u0447\u0442\u043e, \u0431\u0435\u0437 \u0442\u044e\u043d\u0438\u043d\u0433\u0430, \u0432 MySQL \u043b\u0443\u0447\u0448\u0435 \u0432\u0441\u0435\u0433\u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0438\u0442 MyISAM, \u043f\u0440\u0438\u0447\u0451\u043c \u0438\u043d\u0434\u0435\u043a\u0441 \u043f\u043e date_start \u043d\u0430\u043c \u0434\u0435\u043b\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0445\u0443\u0436\u0435, \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u0432 \u0441\u043b\u0443\u0447\u0430\u0435 \u0445\u043e\u043b\u043e\u0434\u043d\u043e\u0433\u043e \u043a\u0435\u0448\u0430 (\u044d\u0442\u043e \u043e\u0431\u044a\u044f\u0441\u043d\u044f\u0435\u0442\u0441\u044f \u0442\u0435\u043c, \u0447\u0442\u043e \u0432 MyISAM \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u044b\u0439 \u0434\u043e\u0441\u0442\u0443\u043f \u043a \u0441\u0442\u0440\u043e\u043a\u0430\u043c \u0441\u0434\u0435\u043b\u0430\u043d \u043d\u0435 \u0441\u043b\u0438\u0448\u043a\u043e\u043c \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u043e \u2014 \u0432\u0441\u0435\u0433\u0434\u0430 \u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f \u043f\u043e \u043e\u0434\u043d\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u043c \u0432\u044b\u0437\u043e\u0432\u043e\u043c read(), \u0447\u0442\u043e \u0432 \u0441\u043b\u0443\u0447\u0430\u0435 \u0441 \u0445\u043e\u043b\u043e\u0434\u043d\u044b\u043c \u043a\u0435\u0448\u043e\u043c \u0438\u043c\u0435\u0435\u0442 \u043a\u0430\u0442\u0430\u0441\u0442\u0440\u043e\u0444\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u043f\u043e\u0441\u043b\u0435\u0434\u0441\u0442\u0432\u0438\u044f \u0434\u0430\u0436\u0435 \u043d\u0430 SSD). \u041d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u043b\u0443\u0447\u0448\u0435 \u0438\u0441\u043f\u043e\u043b\u043d\u044f\u044e\u0442\u0441\u044f \u0431\u044b\u0441\u0442\u0440\u0435\u0435 \u043d\u0430 \u0441\u0445\u0435\u043c\u0435 InnoDB+PK, \u043d\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430 \u043f\u0440\u043e\u0433\u0440\u0435\u0442\u043e\u043c \u043a\u0435\u0448\u0435. \u0412 \u0441\u043b\u0443\u0447\u0430\u0435 \u0445\u043e\u043b\u043e\u0434\u043d\u043e\u0433\u043e \u0441\u0442\u0430\u0440\u0442\u0430 MyISAM \u043d\u0430\u043c\u043d\u043e\u0433\u043e \u043f\u0440\u0435\u0434\u043f\u043e\u0447\u0438\u0442\u0435\u0442\u0435\u043b\u044c\u043d\u0435\u0439, \u043f\u0440\u0438\u0447\u0451\u043c \u0431\u0435\u0437 \u0438\u043d\u0434\u0435\u043a\u0441\u0430 \u043f\u043e date_start (\u043c\u043e\u0436\u043d\u043e \u0432\u043c\u0435\u0441\u0442\u043e \u044d\u0442\u043e\u0433\u043e \u0440\u0430\u0441\u0448\u0430\u0440\u0434\u0438\u0442\u044c \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u0435\u0449\u0451 \u0438 \u043f\u043e \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u0430\u043c \u0434\u0430\u0442 \u0438 \u043f\u0443\u0441\u043a\u0430\u0442\u044c \u0437\u0430\u043f\u0440\u043e\u0441\u044b \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u043e).<\/p>\n<p>  \u041f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 ClickHouse \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043a\u043e\u043b\u043e\u043d\u043e\u0447\u043d\u043e\u0439 \u0431\u0430\u0437\u043e\u0439, \u0437\u0430\u043f\u0440\u043e\u0441 \u0432\u0438\u0434\u0430 SELECT * \u0434\u043b\u044f \u043d\u0435\u0433\u043e \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0443\u0434\u043e\u0431\u043d\u044b\u043c \u2014 \u044d\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u0432\u0438\u0434\u0435\u0442\u044c \u043f\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0438\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432. \u0415\u0441\u043b\u0438 \u0435\u0441\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c, \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u0431\u0438\u0440\u0430\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0435 \u043a\u043e\u043b\u043e\u043d\u043a\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0443\u0436\u043d\u044b (\u043c\u0435\u0442\u0430-\u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f \u0434\u043b\u044f tour_id \u0432 \u043b\u044e\u0431\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0434\u043e\u043b\u0436\u043d\u0430 \u0434\u0443\u0431\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0435\u0449\u0451 \u0433\u0434\u0435-\u0442\u043e \u0432 \u043d\u0430\u0434\u0435\u0436\u043d\u043e\u043c \u0445\u0440\u0430\u043d\u0438\u043b\u0438\u0449\u0435, \u0438 \u043c\u043e\u0436\u043d\u043e \u043e\u0442\u0442\u0443\u0434\u0430 \u0435\u0451 \u0434\u043e\u0441\u0442\u0430\u0432\u0430\u0442\u044c \u0432\u043c\u0435\u0441\u0442\u043e \u0432\u044b\u0431\u043e\u0440\u043a\u0438 \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0438\u0437 ClickHouse). \u0422\u0430\u043a\u0436\u0435, ClickHouse \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0440\u0430\u0441\u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u0438\u0432\u0430\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u043d\u0430 \u0432\u0441\u0435 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u0435 \u044f\u0434\u0440\u0430, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0441\u043a\u0430\u043d\u0438\u0440\u0443\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0443\u0436\u043d\u044b\u0435 \u043a\u043e\u043b\u043e\u043d\u043a\u0438, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043e\u0447\u0435\u043d\u044c \u0431\u044b\u0441\u0442\u0440\u043e \u043f\u0440\u0438 \u043f\u0440\u043e\u0433\u0440\u0435\u0442\u043e\u043c \u043a\u0435\u0448\u0435. \u0412 \u0441\u043b\u0443\u0447\u0430\u0435 \u0445\u043e\u043b\u043e\u0434\u043d\u043e\u0433\u043e \u0441\u0442\u0430\u0440\u0442\u0430 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u0437\u0430\u043c\u0435\u0442\u043d\u043e, \u043f\u043e\u0447\u0435\u043c\u0443 \u043f\u0440\u0435\u0434\u043f\u043e\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u0435\u0439 \u0432\u044b\u0431\u0438\u0440\u0430\u0442\u044c \u043d\u0435 \u0432\u0441\u0435 \u043a\u043e\u043b\u043e\u043d\u043a\u0438, \u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0443\u0436\u043d\u044b\u0435.<\/p>\n<p>  \u041e\u0434\u043d\u0430\u043a\u043e, \u0434\u0430\u0436\u0435 \u043f\u0440\u0438 \u0445\u043e\u043b\u043e\u0434\u043d\u043e\u043c \u0441\u0442\u0430\u0440\u0442\u0435, ClickHouse \u043b\u0438\u0434\u0438\u0440\u0443\u0435\u0442 \u043f\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0438\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0432\u043e \u0432\u0441\u0435\u0445 \u0441\u043b\u0443\u0447\u0430\u044f\u0445 \u0431\u0435\u0437 \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f.<\/p>\n<h3>\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/h3>\n<p>  \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u043c\u044b \u0441 \u0432\u0430\u043c\u0438 \u043f\u043e\u0441\u0442\u0440\u043e\u0438\u043b\u0438 \u0443\u043f\u0440\u043e\u0449\u0435\u043d\u043d\u0443\u044e \u043c\u043e\u0434\u0435\u043b\u044c \u0434\u043b\u044f \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e \u0442\u0443\u0440\u0430\u043c, \u0431\u0435\u0437 \u0443\u0447\u0435\u0442\u0430 \u0441\u0442\u043e\u043f\u043e\u0432, \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 MySQL (3 \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0445 \u043f\u043e\u0434\u0445\u043e\u0434\u0430) \u0438 ClickHouse, \u0438 \u0432\u043e \u0432\u0441\u0435\u0445 \u0441\u043b\u0443\u0447\u0430\u044f\u0445 \u0431\u0430\u0437\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 \u043e\u0442 \u042f\u043d\u0434\u0435\u043a\u0441\u0430 \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u043b\u0430 \u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0435 \u043f\u0440\u0435\u0438\u043c\u0443\u0449\u0435\u0441\u0442\u0432\u043e \u0432 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u0438, \u0438\u043d\u043e\u0433\u0434\u0430 \u043d\u0430 2-3 \u043f\u043e\u0440\u044f\u0434\u043a\u0430.<\/p>\n<p>  \u041d\u0430\u0434\u0435\u044e\u0441\u044c, \u044d\u0442\u0430 \u0441\u0442\u0430\u0442\u044c\u044f \u043f\u043e\u043c\u043e\u0436\u0435\u0442 \u0443\u0441\u043a\u043e\u0440\u0438\u0442\u044c \u0438 \u0443\u0434\u0435\u0448\u0435\u0432\u0438\u0442\u044c \u043f\u043e\u0438\u0441\u043a \u0442\u0435\u043c, \u043a\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442 \u043f\u043e\u0438\u0441\u043a \u043f\u043e \u0442\u0443\u0440\u0430\u043c, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0434\u0430\u0441\u0442 \u0431\u0430\u0437\u043e\u0432\u043e\u0435 \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u0442\u043e\u0433\u043e, \u0434\u043b\u044f \u043a\u0430\u043a\u0438\u0445 \u0437\u0430\u0434\u0430\u0447 \u0433\u043e\u0434\u0438\u0442\u0441\u044f ClickHouse. \u0421\u043f\u0430\u0441\u0438\u0431\u043e \u0437\u0430 \u0442\u043e, \u0447\u0442\u043e \u043f\u0440\u043e\u0447\u0438\u0442\u0430\u043b\u0438 \u0434\u043e \u043a\u043e\u043d\u0446\u0430, \u0431\u0443\u0434\u0443 \u0440\u0430\u0434 \u0443\u0441\u043b\u044b\u0448\u0430\u0442\u044c \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0438.<\/p>\n<p>  P.S. \u0415\u0441\u043b\u0438 \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u0437\u0430\u0442\u044e\u043d\u0438\u0442\u044c MySQL \u0438 ClickHouse, \u0447\u0442\u043e\u0431\u044b \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b \u0431\u044b\u043b\u0438 \u043b\u0443\u0447\u0448\u0435 \u0438 \u043e\u043f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u0442\u0435 \u0441\u0432\u043e\u0438 \u0431\u0435\u043d\u0447\u043c\u0430\u0440\u043a\u0438, \u0442\u043e \u043f\u0438\u0448\u0438\u0442\u0435 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445, \u044d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043b\u0435\u0437\u043d\u044b\u043c \u0434\u043e\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435\u043c \u043a \u0441\u0442\u0430\u0442\u044c\u0435, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u043c\u043e\u0438 \u0446\u0438\u0444\u0440\u044b \u043b\u0438\u0448\u044c \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u044b, \u0438 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0435 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u043c\u043e\u0433\u0443\u0442 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b \u0432 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0440\u0430\u0437 \u0434\u043b\u044f \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0432\u0438\u0434\u043e\u0432 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432.<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:\/\/habrahabr.ru\/post\/324846\/\"> https:\/\/habrahabr.ru\/post\/324846\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/files\/626\/562\/a17\/626562a17c194dcb84e075c423ef1003.png\" align=\"right\" width=\"320\"\/> \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u043c\u044b \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u044b \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e \u0431\u0430\u0437\u0435 \u0442\u0443\u0440\u043e\u0432 (\u0442\u0443\u0440 \u0438\u0437 \u0441\u0435\u0431\u044f \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u043d\u0430\u0431\u043e\u0440 \u0438\u0437 \u043e\u0442\u0435\u043b\u044f \u0438 \u043f\u0435\u0440\u0435\u043b\u0435\u0442\u0430) \u0438 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0434\u0432\u0435 \u043e\u043f\u0446\u0438\u0438 \u2014 <a href=\"https:\/\/clickhouse.yandex\">ClickHouse<\/a> \u0438 MySQL (\u0434\u0432\u0430 \u0434\u0432\u0438\u0436\u043a\u0430 \u2014 InnoDB \u0438 MyISAM).<\/p>\n<h3>\u0412 \u0447\u0435\u043c \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e \u0442\u0443\u0440\u0430\u043c<\/h3>\n<p>  \u0422\u0443\u0440\u043e\u043f\u0435\u0440\u0430\u0442\u043e\u0440\u044b (TezTour, TUI, Natalie Tours, etc) \u043f\u0440\u043e\u0434\u0430\u044e\u0442 \u0441\u0432\u043e\u0438 \u043f\u0443\u0442\u0435\u0432\u043a\u0438 \u043d\u0435\u043e\u0447\u0435\u0432\u0438\u0434\u043d\u044b\u043c, \u043d\u0430 \u043f\u0435\u0440\u0432\u044b\u0439 \u0432\u0437\u0433\u043b\u044f\u0434, \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c:<\/p>\n<ul>\n<li>\u0440\u0435\u0437\u0435\u0440\u0432\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043d\u043e\u043c\u0435\u0440\u043e\u0432 \u0432 \u043e\u0442\u0435\u043b\u044f\u0445 \u043d\u0430 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u0434\u0430\u0442<\/li>\n<li>\u0432\u044b\u043a\u0443\u043f\u0430\u0435\u0442\u0441\u044f \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0441\u0430\u043c\u043e\u043b\u0435\u0442\u043e\u0432<\/li>\n<li>\u0432\u044b\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f \u043d\u043e\u0432\u044b\u0439 \u043f\u0430\u043a\u0435\u0442 \u0442\u0443\u0440\u043e\u0432, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u0441\u044f \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0438 \u0432\u0441\u0435\u0445 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0445 \u0442\u0438\u043f\u043e\u0432 \u043d\u043e\u043c\u0435\u0440\u043e\u0432, \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0435\u0439 \u043f\u0440\u0435\u0431\u044b\u0432\u0430\u043d\u0438\u044f, \u0433\u043e\u0440\u043e\u0434\u043e\u0432 \u0438 \u0434\u0430\u0442 \u0432\u044b\u043b\u0435\u0442\u0430<\/li>\n<\/ul>\n<p>  \u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0433\u043e \u043f\u043e \u0442\u0430\u043a\u0438\u043c \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u044f\u043c (\u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043c\u043e\u0436\u0435\u0442 \u0438\u0441\u0447\u0438\u0441\u043b\u044f\u0442\u044c\u0441\u044f \u0441\u043e\u0442\u043d\u044f\u043c\u0438 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0438 \u0434\u0430\u0436\u0435 \u043c\u0438\u043b\u043b\u0438\u0430\u0440\u0434\u0430\u043c\u0438) \u043e\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u043e\u0438\u0441\u043a. \u041f\u0440\u0438\u043c\u0435\u0440 \u0444\u043e\u0440\u043c\u044b \u043f\u043e\u0438\u0441\u043a\u0430 \u043c\u043e\u0436\u043d\u043e \u0443\u0432\u0438\u0434\u0435\u0442\u044c \u0443 <a href=\"http:\/\/www.tez-tour.com\/search.html\">TezTour<\/a> \u2014 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0431\u0440\u0430\u0442\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u0438\u043d \u0433\u043e\u0440\u043e\u0434 \u0432\u044b\u043b\u0435\u0442\u0430, \u0442\u0438\u043f \u0440\u0430\u0437\u043c\u0435\u0449\u0435\u043d\u0438\u044f \u0438 \u0441\u0442\u0440\u0430\u043d\u0443, \u0430 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0431\u0438\u0440\u0430\u0442\u044c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u044b\u0435.<\/p>\n<p>  \u041d\u0435\u0441\u043c\u043e\u0442\u0440\u044f \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u043e\u0431\u0449\u0435\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0442\u0443\u0440\u043e\u0432 (\u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0439) \u0438\u0441\u0447\u0438\u0441\u043b\u044f\u0435\u0442\u0441\u044f \u0441\u043e\u0442\u043d\u044f\u043c\u0438 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432, \u043d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u043d\u0430\u0431\u043e\u0440 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 (\u0433\u043e\u0440\u043e\u0434 \u0432\u044b\u043b\u0435\u0442\u0430, \u0442\u0438\u043f \u0440\u0430\u0437\u043c\u0435\u0449\u0435\u043d\u0438\u044f, \u0441\u0442\u0440\u0430\u043d\u0430) \u043f\u0440\u0438\u0445\u043e\u0434\u044f\u0442\u0441\u044f, \u0432 \u0445\u0443\u0434\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432. \u041d\u043e \u0434\u0430\u0436\u0435 \u043f\u043e \u0442\u0430\u043a\u043e\u043c\u0443 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0443 \u0442\u0443\u0440\u043e\u0432 \u043d\u0435 \u0442\u0430\u043a \u043f\u0440\u043e\u0441\u0442\u043e \u043e\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043b\u044f\u0442\u044c \u043f\u043e\u0438\u0441\u043a, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043d\u0443\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438 \u0437\u0430\u043f\u0438\u0441\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0443\u0434\u043e\u0432\u043b\u0435\u0442\u0432\u043e\u0440\u044f\u044e\u0442 \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u044b\u043c \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u044f\u043c, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0437\u0430\u0434\u0430\u044e\u0442 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438, \u0438 \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0431\u043e\u043b\u0435\u0435-\u043c\u0435\u043d\u0435\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u043e\u0439 (\u043a\u0430\u043a \u043f\u0440\u0430\u0432\u0438\u043b\u043e, \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430 \u0434\u0435\u043b\u0430\u0435\u0442\u0441\u044f \u043f\u043e \u0446\u0435\u043d\u0435, \u043d\u043e \u044d\u0442\u043e \u043d\u0435 \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0439 \u043a\u0440\u0438\u0442\u0435\u0440\u0438\u0439). \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u043c\u044b \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u0443\u043f\u0440\u043e\u0449\u0435\u043d\u043d\u0443\u044e \u0430\u0440\u0445\u0438\u0442\u0435\u043a\u0442\u0443\u0440\u0443 \u0440\u0435\u0430\u043b\u0442\u0430\u0439\u043c-\u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e \u0442\u0443\u0440\u0430\u043c \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 MySQL \u0438 ClickHouse, \u0431\u0435\u0437 \u0443\u0447\u0435\u0442\u0430 \u0441\u0442\u043e\u043f\u043e\u0432 (\u0441\u043b\u0435\u043d\u0433\u043e\u0432\u044b\u0439 \u0442\u0435\u0440\u043c\u0438\u043d, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442, \u0447\u0442\u043e \u043f\u043e \u043a\u0430\u043a\u0438\u043c-\u0442\u043e \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430\u043c \u0437\u0430\u043a\u043e\u043d\u0447\u0438\u043b\u0438\u0441\u044c \u043d\u043e\u043c\u0435\u0440\u0430 \u0438\u043b\u0438 \u043c\u0435\u0441\u0442\u0430 \u0432 \u0441\u0430\u043c\u043e\u043b\u0435\u0442\u0435, \u0438 \u0442\u0430\u043a\u0438\u0435 \u0442\u0443\u0440\u044b \u043d\u0443\u0436\u043d\u043e \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0438\u0437 \u0432\u044b\u0434\u0430\u0447\u0438). \u041c\u044b \u043d\u0430\u0443\u0447\u0438\u043c\u0441\u044f \u0434\u0435\u043b\u0430\u0442\u044c \u043f\u043e\u0438\u0441\u043a \u0431\u044b\u0441\u0442\u0440\u044b\u043c \u0438 \u0443\u043c\u0435\u0442\u044c \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b \u0441 \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u043e\u0439 \u043f\u043e \u043b\u044e\u0431\u044b\u043c \u043f\u043e\u043b\u044f\u043c.<\/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-283900","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/283900","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=283900"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/283900\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=283900"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=283900"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=283900"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}