批处理模式
openGauss支持从文本文件执行SQL语句。openGauss提供了gsql工具实现SQL语句的批量处理。
以下场景建议使用批处理:
- 如果您重复运行查询(例如,每天或每周),将其设为脚本可以让您避免每次进行重复输入。
- 您可以通过复制和编辑脚本文件从现有的相似查询生成新查询。
- 对于多行语句或多语句序列,如果中间出现错误,不必重新键入所有内容,只需编辑脚本以更正错误,然后再次执行它。
- 您可以将脚本分发给其他人,以便他们也可以运行这些语句。
- 某些情况不允许交互式使用时,您必须使用批处理模式。
语法格式
gsql -d dbname -p port -f filename
参数说明
-
dbname
指定想要连接的数据库名称。
-
port
指定数据库服务器的端口号。
-
-f filename
使用文件作为命令源而不是交互式输入。该参数指定读取文本文件的路径以及名称。
示例
-
创建本地sql文本文件。文件内容如下:
CREATE TABLE customer ( c_customer_sk integer, c_customer_id char(5), c_first_name char(6), c_last_name char(8), Amount integer ); INSERT INTO customer(c_customer_sk, c_customer_id, c_first_name,Amount) VALUES (3769, 'hello', 'Grace', 1000); INSERT INTO customer (c_customer_sk, c_first_name) VALUES (3769, 'Grace'); INSERT INTO customer (c_customer_sk, c_customer_id, c_first_name) VALUES (3769, 'hello', DEFAULT); INSERT INTO customer (c_customer_sk, c_customer_id, c_first_name,Amount) VALUES (6885, 'maps', 'Joes',2200), (4321, 'tpcds', 'Lily',3000), (9527, 'world', 'James',5000);
-
使用如下命令执行sql.txt中的SQL语句。
gsql -d postgres -p 21013 -f /home/user/sql.txt
结果如下。
CREATE TABLE INSERT 0 1 INSERT 0 1 INSERT 0 1 INSERT 0 3