How to create index in servral sql condition?












0















Data is like starttime, endtime, id, a, b, c, d, e, f, g...



How to create index on clickhouse, most sql is as follows:




1.select starttime,endtime,id,a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and id=?



2.select a,c,sum(f),avg(g) from tbl1
where starttime>=? and endtime<=?
group by a,c
order by sum(f) desc
limit 20



3.select starttime,endtime,id,a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and a=?
limit 20



4.select a,c,sum(f),avg(g) from tbl1
where starttime>=? and endtime<=? and a=? and c=?
group by a,c
order by sum(f) desc
limit 20



5.select a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and a=? and d=? and e=?
order by a,d,e
limit 20




tips:

a) always have starttime, endtime



b) some SQL have an id to search small data, example 1. but others to search large data, example 2,3,4,5










share|improve this question

























  • Please format your question better. Putting everything in one line is not good.

    – onetwo12
    Nov 21 '18 at 11:28











  • Are those time ranges between starrtime and enddtime narrow (like minutes) or wide (days/weeks/month)?

    – Ivan Blinkov
    Dec 10 '18 at 8:01


















0















Data is like starttime, endtime, id, a, b, c, d, e, f, g...



How to create index on clickhouse, most sql is as follows:




1.select starttime,endtime,id,a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and id=?



2.select a,c,sum(f),avg(g) from tbl1
where starttime>=? and endtime<=?
group by a,c
order by sum(f) desc
limit 20



3.select starttime,endtime,id,a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and a=?
limit 20



4.select a,c,sum(f),avg(g) from tbl1
where starttime>=? and endtime<=? and a=? and c=?
group by a,c
order by sum(f) desc
limit 20



5.select a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and a=? and d=? and e=?
order by a,d,e
limit 20




tips:

a) always have starttime, endtime



b) some SQL have an id to search small data, example 1. but others to search large data, example 2,3,4,5










share|improve this question

























  • Please format your question better. Putting everything in one line is not good.

    – onetwo12
    Nov 21 '18 at 11:28











  • Are those time ranges between starrtime and enddtime narrow (like minutes) or wide (days/weeks/month)?

    – Ivan Blinkov
    Dec 10 '18 at 8:01
















0












0








0








Data is like starttime, endtime, id, a, b, c, d, e, f, g...



How to create index on clickhouse, most sql is as follows:




1.select starttime,endtime,id,a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and id=?



2.select a,c,sum(f),avg(g) from tbl1
where starttime>=? and endtime<=?
group by a,c
order by sum(f) desc
limit 20



3.select starttime,endtime,id,a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and a=?
limit 20



4.select a,c,sum(f),avg(g) from tbl1
where starttime>=? and endtime<=? and a=? and c=?
group by a,c
order by sum(f) desc
limit 20



5.select a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and a=? and d=? and e=?
order by a,d,e
limit 20




tips:

a) always have starttime, endtime



b) some SQL have an id to search small data, example 1. but others to search large data, example 2,3,4,5










share|improve this question
















Data is like starttime, endtime, id, a, b, c, d, e, f, g...



How to create index on clickhouse, most sql is as follows:




1.select starttime,endtime,id,a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and id=?



2.select a,c,sum(f),avg(g) from tbl1
where starttime>=? and endtime<=?
group by a,c
order by sum(f) desc
limit 20



3.select starttime,endtime,id,a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and a=?
limit 20



4.select a,c,sum(f),avg(g) from tbl1
where starttime>=? and endtime<=? and a=? and c=?
group by a,c
order by sum(f) desc
limit 20



5.select a,b,c,d,e,f,g from tbl1
where starttime>=? and endtime<=? and a=? and d=? and e=?
order by a,d,e
limit 20




tips:

a) always have starttime, endtime



b) some SQL have an id to search small data, example 1. but others to search large data, example 2,3,4,5







clickhouse






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 22 '18 at 1:14







HelloWorld001

















asked Nov 21 '18 at 11:09









HelloWorld001HelloWorld001

11




11













  • Please format your question better. Putting everything in one line is not good.

    – onetwo12
    Nov 21 '18 at 11:28











  • Are those time ranges between starrtime and enddtime narrow (like minutes) or wide (days/weeks/month)?

    – Ivan Blinkov
    Dec 10 '18 at 8:01





















  • Please format your question better. Putting everything in one line is not good.

    – onetwo12
    Nov 21 '18 at 11:28











  • Are those time ranges between starrtime and enddtime narrow (like minutes) or wide (days/weeks/month)?

    – Ivan Blinkov
    Dec 10 '18 at 8:01



















Please format your question better. Putting everything in one line is not good.

– onetwo12
Nov 21 '18 at 11:28





Please format your question better. Putting everything in one line is not good.

– onetwo12
Nov 21 '18 at 11:28













Are those time ranges between starrtime and enddtime narrow (like minutes) or wide (days/weeks/month)?

– Ivan Blinkov
Dec 10 '18 at 8:01







Are those time ranges between starrtime and enddtime narrow (like minutes) or wide (days/weeks/month)?

– Ivan Blinkov
Dec 10 '18 at 8:01














1 Answer
1






active

oldest

votes


















0














Clickhouse is a COLUMN oriented database with one Primary Key, he store each column on separate optimized "storage" which doesn't need secondary indexes



you can choose *MergeTree table engine with starttime and endtime in primary key
every kind of MergeTree engine describe here https://clickhouse.yandex/docs/en/operations/table_engines/mergetree/



All your queries will run as fast as possible






share|improve this answer























    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53410837%2fhow-to-create-index-in-servral-sql-condition%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    0














    Clickhouse is a COLUMN oriented database with one Primary Key, he store each column on separate optimized "storage" which doesn't need secondary indexes



    you can choose *MergeTree table engine with starttime and endtime in primary key
    every kind of MergeTree engine describe here https://clickhouse.yandex/docs/en/operations/table_engines/mergetree/



    All your queries will run as fast as possible






    share|improve this answer




























      0














      Clickhouse is a COLUMN oriented database with one Primary Key, he store each column on separate optimized "storage" which doesn't need secondary indexes



      you can choose *MergeTree table engine with starttime and endtime in primary key
      every kind of MergeTree engine describe here https://clickhouse.yandex/docs/en/operations/table_engines/mergetree/



      All your queries will run as fast as possible






      share|improve this answer


























        0












        0








        0







        Clickhouse is a COLUMN oriented database with one Primary Key, he store each column on separate optimized "storage" which doesn't need secondary indexes



        you can choose *MergeTree table engine with starttime and endtime in primary key
        every kind of MergeTree engine describe here https://clickhouse.yandex/docs/en/operations/table_engines/mergetree/



        All your queries will run as fast as possible






        share|improve this answer













        Clickhouse is a COLUMN oriented database with one Primary Key, he store each column on separate optimized "storage" which doesn't need secondary indexes



        you can choose *MergeTree table engine with starttime and endtime in primary key
        every kind of MergeTree engine describe here https://clickhouse.yandex/docs/en/operations/table_engines/mergetree/



        All your queries will run as fast as possible







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 23 '18 at 8:32









        SlachSlach

        658514




        658514
































            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53410837%2fhow-to-create-index-in-servral-sql-condition%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            MongoDB - Not Authorized To Execute Command

            Npm cannot find a required file even through it is in the searched directory

            in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith