zoukankan      html  css  js  c++  java
  • PostgreSQL Obtaining the Result Status

    There are several ways to determine the effect of a command. The first method is to use the GET
    DIAGNOSTICS command, which has the form:
    GET [ CURRENT ] DIAGNOSTICS variable { = | := } item [ , ... ];
    This command allows retrieval of system status indicators. Each item is a key word identifying a
    status value to be assigned to the specified variable (which should be of the right data type to receive
    it). The currently available status items are ROW_COUNT, the number of rows processed by the last
    SQL command sent to the SQL engine, and RESULT_OID, the OID of the last row inserted by the most
    recent SQL command. Note that RESULT_OID is only useful after an INSERT command into a table
    containing OIDs. Colon-equal (:=) can be used instead of SQL-standard = for GET DIAGNOSTICS.
    An example:
    GET DIAGNOSTICS integer_var = ROW_COUNT;
    The second method to determine the effects of a command is to check the special variable named
    FOUND, which is of type boolean. FOUND starts out false within each PL/pgSQL function call. It is
    set by each of the following types of statements:

    • A SELECT INTO statement sets FOUND true if a row is assigned, false if no row is returned.
    • A PERFORM statement sets FOUND true if it produces (and discards) one or more rows, false if no
    row is produced.
    • UPDATE, INSERT, and DELETE statements set FOUND true if at least one row is affected, false if no
    row is affected.
    • A FETCH statement sets FOUND true if it returns a row, false if no row is returned.
    • A MOVE statement sets FOUND true if it successfully repositions the cursor, false otherwise.
    • A FOR or FOREACH statement sets FOUND true if it iterates one or more times, else false. FOUND is
    set this way when the loop exits; inside the execution of the loop, FOUND is not modified by the
    loop statement, although it might be changed by the execution of other statements within the loop
    body.
    • RETURN QUERY and RETURN QUERY EXECUTE statements set FOUND true if the query returns at
    least one row, false if no row is returned.
    Other PL/pgSQL statements do not change the state of FOUND. Note in particular that EXECUTE
    changes the output of GET DIAGNOSTICS, but does not change FOUND.
    FOUND is a local variable within each PL/pgSQL function; any changes to it affect only the current
    function.

    Executing a Query with a Single-row Result

    The result of a SQL command yielding a single row (possibly of multiple columns) can be assigned to
    a record variable, row-type variable, or list of scalar variables. This is done by writing the base SQL
    command and adding an INTO clause. For example,
    SELECT select_expressions INTO [STRICT] target FROM ...;
    INSERT ... RETURNING expressions INTO [STRICT] target;
    UPDATE ... RETURNING expressions INTO [STRICT] target;
    DELETE ... RETURNING expressions INTO [STRICT] target;
    where target can be a record variable, a row variable, or a comma-separated list of simple variables
    and record/row fields. PL/pgSQL variables will be substituted into the rest of the query, and the plan
    is cached, just as described above for commands that do not return rows. This works for SELECT,
    INSERT/UPDATE/DELETE with RETURNING, and utility commands that return row-set results (such as
    EXPLAIN). Except for the INTO clause, the SQL command is the same as it would be written outside
    PL/pgSQL.

    Tip: Note that this interpretation of SELECT with INTO is quite different from PostgreSQL’s regular
    SELECT INTO command, wherein the INTO target is a newly created table. If you want to create
    a table from a SELECT result inside a PL/pgSQL function, use the syntax CREATE TABLE ... AS
    SELECT.

    If a row or a variable list is used as target, the query’s result columns must exactly match the structure
    of the target as to number and data types, or else a run-time error occurs. When a record variable is
    the target, it automatically configures itself to the row type of the query result columns.
    The INTO clause can appear almost anywhere in the SQL command. Customarily it is written either
    just before or just after the list of select_expressions in a SELECT command, or at the end of the
    command for other command types. It is recommended that you follow this convention in case the
    PL/pgSQL parser becomes stricter in future versions.
    If STRICT is not specified in the INTO clause, then target will be set to the first row returned by the
    query, or to nulls if the query returned no rows. (Note that “the first row” is not well-defined unless
    you’ve used ORDER BY.) Any result rows after the first row are discarded. You can check the special
    FOUND variable (see Section 40.5.5) to determine whether a row was returned:
    SELECT * INTO myrec FROM emp WHERE empname = myname;
    IF NOT FOUND THEN
    RAISE EXCEPTION ’employee % not found’, myname;
    END IF;

    If the STRICT option is specified, the query must return exactly one row or a run-time error will be
    reported, either NO_DATA_FOUND (no rows) or TOO_MANY_ROWS (more than one row). You can use
    an exception block if you wish to catch the error, for example:
    BEGIN
    SELECT * INTO STRICT myrec FROM emp WHERE empname = myname;
    EXCEPTION
    WHEN NO_DATA_FOUND THEN
    RAISE EXCEPTION ’employee % not found’, myname;
    WHEN TOO_MANY_ROWS THEN
    RAISE EXCEPTION ’employee % not unique’, myname;
    END;
    Successful execution of a command with STRICT always sets FOUND to true.
    For INSERT/UPDATE/DELETE with RETURNING, PL/pgSQL reports an error for more than one returned
    row, even when STRICT is not specified. This is because there is no option such as ORDER BY
    with which to determine which affected row should be returned.
    If print_strict_params is enabled for the function, then when an error is thrown because the
    requirements of STRICT are not met, the DETAIL part of the error message will include information
    about the parameters passed to the query. You can change the print_strict_params setting for all
    functions by setting plpgsql.print_strict_params, though only subsequent function compilations
    will be affected. You can also enable it on a per-function basis by using a compiler option, for
    example:

    CREATE FUNCTION get_userid(username text) RETURNS int
    AS $$
    #print_strict_params on
    DECLARE
    userid int;
    BEGIN

    SELECT users.userid INTO STRICT userid
    FROM users WHERE users.username = get_userid.username;
    RETURN userid;
    END
    $$ LANGUAGE plpgsql;
    On failure, this function might produce an error message such as
    ERROR: query returned no rows
    DETAIL: parameters: $1 = ’nosuchuser’
    CONTEXT: PL/pgSQL function get_userid(text) line 6 at SQL statement
    Note: The STRICT option matches the behavior of Oracle PL/SQL’s SELECT INTO and related
    statements.
    To handle cases where you need to process multiple result rows from a SQL query, see Section 40.6.4.

  • 相关阅读:
    L1-049 天梯赛座位分配​​​​​​​
    L1-046 整除光棍 大数除法
    天梯赛 L1-043 阅览室
    Hdu 1022 Train Problem I 栈
    蓝桥杯 历届试题 格子刷油漆  (动态规划)
    第九届蓝桥杯省赛真题 日志统计
    2018年第九届蓝桥杯第7题 螺旋折线
    2018年第九届蓝桥杯省赛 递增三元组
    蓝桥杯 历届试题 高僧斗法  (尼姆博弈)
    K-th Number
  • 原文地址:https://www.cnblogs.com/songyuejie/p/5045826.html
Copyright © 2011-2022 走看看