Thread: Send multiple statements to pg server at once

Send multiple statements to pg server at once

From
Andy Fan
Date:

Hi,

I want to simulate a case where server receive "SELECT 1;SELECT 2;" at
once, so when executing exec_simple_query, the query_string is
"SELECT 1;SELECT 2;"  However I found it is not easy to simulate, does
anyone has a suggestion?

I tried 'psql -f', checking 'psql/settings.h', at last I see below code
in psql/mainloop.c, I guess it is impossible in psql.


    /*
     * Send command if semicolon found, or if end of line and we're in
     * single-line mode.
     */
    if (scan_result == PSCAN_SEMICOLON ||
        (scan_result == PSCAN_EOL && pset.singleline))
    {


-- 
Best Regards
Andy Fan




Re: Send multiple statements to pg server at once

From
Pavel Stehule
Date:
Hi

út 11. 3. 2025 v 8:23 odesílatel Andy Fan <zhihuifan1213@163.com> napsal:


Hi,

I want to simulate a case where server receive "SELECT 1;SELECT 2;" at
once, so when executing exec_simple_query, the query_string is
"SELECT 1;SELECT 2;"  However I found it is not easy to simulate, does
anyone has a suggestion?

I tried 'psql -f', checking 'psql/settings.h', at last I see below code
in psql/mainloop.c, I guess it is impossible in psql.


        /*
         * Send command if semicolon found, or if end of line and we're in
         * single-line mode.
         */
        if (scan_result == PSCAN_SEMICOLON ||
                (scan_result == PSCAN_EOL && pset.singleline))
        {


If I remember well, you can use \; for this case


Regards

Pavel
 

--
Best Regards
Andy Fan



Re: Send multiple statements to pg server at once

From
Andy Fan
Date:
Pavel Stehule <pavel.stehule@gmail.com> writes:

>
> If I remember well, you can use \; for this case
>
> https://www.postgresql.org/docs/current/app-psql.html
>
> Regards

Thank you Pavel, it works! This is so handy!


-- 
Best Regards
Andy Fan