批处理模式

openGauss支持从文本文件执行SQL语句。openGauss提供了gsql工具实现SQL语句的批量处理。

以下场景建议使用批处理:

  • 如果您重复运行查询(例如,每天或每周),将其设为脚本可以让您避免每次进行重复输入。
  • 您可以通过复制和编辑脚本文件从现有的相似查询生成新查询。
  • 对于多行语句或多语句序列,如果中间出现错误,不必重新键入所有内容,只需编辑脚本以更正错误,然后再次执行它。
  • 您可以将脚本分发给其他人,以便他们也可以运行这些语句。
  • 某些情况不允许交互式使用时,您必须使用批处理模式。

语法格式

  1. gsql -d dbname -p port -f filename

参数说明

  • dbname

    指定想要连接的数据库名称。

  • port

    指定数据库服务器的端口号。

  • -f filename

    使用文件作为命令源而不是交互式输入。该参数指定读取文本文件的路径以及名称。

示例

  1. 创建本地sql文本文件。文件内容如下:

    1. CREATE TABLE customer
    2. (
    3. c_customer_sk integer,
    4. c_customer_id char(5),
    5. c_first_name char(6),
    6. c_last_name char(8),
    7. Amount integer
    8. );
    9. INSERT INTO customer(c_customer_sk, c_customer_id, c_first_name,Amount) VALUES (3769, 'hello', 'Grace', 1000);
    10. INSERT INTO customer (c_customer_sk, c_first_name) VALUES (3769, 'Grace');
    11. INSERT INTO customer (c_customer_sk, c_customer_id, c_first_name) VALUES (3769, 'hello', DEFAULT);
    12. INSERT INTO customer (c_customer_sk, c_customer_id, c_first_name,Amount) VALUES
    13. (6885, 'maps', 'Joes',2200),
    14. (4321, 'tpcds', 'Lily',3000),
    15. (9527, 'world', 'James',5000);
  2. 使用如下命令执行sql.txt中的SQL语句。

    1. gsql -d postgres -p 21013 -f /home/user/sql.txt

    结果如下。

    1. CREATE TABLE
    2. INSERT 0 1
    3. INSERT 0 1
    4. INSERT 0 1
    5. INSERT 0 3