How to avoid multiple insert in PostgreSQL

后端 未结 2 1475
醉梦人生
醉梦人生 2021-01-26 16:36

In my query im using for loop. Each and every time when for loop is executed, at the end some values has to be inserted into table. This is time consuming because for loop has m

2条回答
  •  余生分开走
    2021-01-26 17:16

    One possible solution is to build a large VALUES String. In Java, something like

    StringBuffer buf = new StringBuffer(100000); // big enough?
    for ( int i=1; i<=10000; ++i ) {
        buf.append("(")
           .append(j)
           .append(",")
           .append(predicted_node)
           .append("),"); // whatever j and predict_node are
    }
    buf.setCharAt(buf.length()-1, ' '); // kill last comma
    String query = "INSERT INTO datas.tb VALUES " + buf.toString() + ";"
    // send query to DB, just once
    

    The fact j and predict_node appear to be constant has me a little worried, though. Why are you putting a constant in 100000 times?

    Another approach is to do the predicting in a Postgres procedural language, and have the DB itself calculate the value on insert.

提交回复
热议问题