#yasql使用指导

# 查看帮助和版本信息

使用yasql -H命令可查看帮助和版本信息。

$ yasql -H

使用yasql -V命令可查看版本信息。

$ yasql -V

# 命令格式

$ yasql [-S] username/password@host:port [-c "SQL" | -f [-e]  filename[.ext] | @filename[.ext]] 
$ yasql [-S] / as sysdba [-c "SQL" | -f [-e]  filename[.ext] | @filename[.ext]]
$ yasql <command>

-S

用于指定静默登录,需确保-S为首个参数,该参数不区分大小写。

username/password/

指定登录或连接数据库的数据库用户名和密码。若用户名/密码包含特殊符号需使用双引号包围并对双引号进行转义(例如\"user@name\"/\"pwd@name\")或外加单引号(例如'"user@name"/"pwd@name"')进行包围。另外,在Linux系统中,若用户名/密码包含$符号则还需额外转写成\$再加转义符(例如user$namepwd$name应输入为'"user\$name"/"pwd\$name"')。

通过操作系统认证方式登录时,可省略用户名和密码,但不能省略“/”。操作系统认证方式登录需配置后才可使用,配置操作请查阅数据库管理手册中的操作系统身份认证配置

host:port

指定登录或连接数据库的连接方式,详情请查阅登录与连接

as sysdba

通过操作系统认证方式登录时的标识。

-c "SQL"

用于登录并执行单条SQL语句(执行完后立即退出),详情请查阅执行SQL语句

-f [-e] filename[.ext]

用于执行SQL文件,详情请查阅执行SQL文件

@filename[.ext]

用于执行SQL文件,详情请查阅执行SQL语句

command

具体的命令语句,包括/nolog、set命令等。

# 功能介绍

# 登录与连接

登录方式可分为以下几种:

  • 方式一:直接登录,命令格式为yasql username/password@host:port

  • 方式二:静默登录,命令格式为yasql -S username/password@host:port,使用该方式登录并连接数据库不返回命令行提示、命令回显信息、登录提示信息和版本信息。

  • 方式三:操作系统认证登录,命令格式为yasql / as sysdbayasql username/password as sysdba,使用该方式登录无需配置连接方式,只能登录到本地YASDB_DATA环境变量对应的数据库实例。

  • 方式四:分步登录:
    1. 使用/nolog命令启动yasql,命令格式为yasql /nolog,此时仅打开登录窗口但不连接数据库。

    2. 使用connect或conn命令连接并登录数据库,命令格式为connect username/password@host:portconn username/password@host:port

  • 方式五:切换登录,即登录后使用connect或conn命令切换至其它用户登录。

连接方式可分为以下几种:

  • 方式一:有URL的IPv4连接,例如@192.168.1.2:1688

  • 方式二:有URL的IPv6连接,IP必须使用中括号包围,链路本地IPv6地址还需使用百分号标识网络接口名。系统网卡需要支持IPv6的连接,目前支持:

    • IPv6环回地址,例如@[::1]:1688

    • 链路本地地址,例如@[fe80::a89b:8fdb:2c28:35ce%ens192]:1688

    • 唯一本地地址,例如@[fc00:7::126]:1688

    • 未指定地址,例如@[::]:1688

    • 全球单播地址,例如@[2001:250:4000:4000:f80f:6d4c:4310:35ce]:1688

    • IPv4映射的IPv6地址,例如@[::ffff:192.168.7.126]:1688

  • 方式三:有URL的域名连接,例如@yashandb123.vip:1688。域名需支持解析到存在数据库服务器的IP地址,若当前域名解析到多个IP地址,则将按照解析顺序依次尝试连接这些IP地址直至成功。

  • 方式四:无URL的连接,表示连接到本地YASDB_DATA环境变量对应的数据库实例。使用该方式连接数据库属于高权限操作,请合理使用。

  • 方式五:别名连接,例如@alias。需先在${YASDB_HOME}/client/yasc_service.ini中定义别名。

示例

# 直接登录+有URL的IPv4连接方式
$ yasql sales/sales@192.168.1.2:1688
YashanDB SQL Enterprise Edition Release 23.2 x86_64

Connected to:
YashanDB Server Enterprise Edition Release 23.2 x86_64 - X86 64bit Linux
SQL>

# 直接登录+有URL的IPv6环回地址连接方式
$ yasql sales/sales@[::1]:1688
YashanDB SQL Enterprise Edition Release 23.2 x86_64

Connected to:
YashanDB Server Enterprise Edition Release 23.2 x86_64 - X86 64bit Linux
SQL>

# 静默登录+有URL的域名连接方式
$ yasql -S sales/sales@123.com:1688

# 操作系统认证登录
$ yasql / as sysdba
YashanDB SQL Enterprise Edition Release 23.2 x86_64

Connected to:
YashanDB Server Enterprise Edition Release 23.2 x86_64 - X86 64bit Linux
SQL>

# 直接登录+别名连接
$ cat ${YASDB_HOME}/client/yasc_service.ini
local = 127.0.0.1:1688
$ yasql sales/sales@local
Connected to:
YashanDB Server Enterprise Edition Release 23.2 x86_64 - X86 64bit Linux
SQL>

# 分步登录
$ yasql /nolog
YashanDB SQL Enterprise Edition Release 23.2 x86_64
SQL> conn sales/sales@192.168.1.2:1688
YashanDB SQL Enterprise Edition Release 23.2 x86_64

Connected to:
YashanDB Server Enterprise Edition Release 23.2 x86_64 - X86 64bit Linux
-- 登录成功

-- 切换登录:通过用户密码+无URL的连接方式切换至另一个用户
SQL> conn sales1/sales1

-- 切换登录:通过用户密码+有URL的IPv4连接方式切换至另一个用户
SQL> conn sales1/sales1@192.168.1.3:1688

# 执行SQL语句

方式一:登录后执行SQL语句

登录数据库后,在yasql命令行界面可直接执行SQL语句。

示例

$ yasql sales/sales@192.168.1.2:1688
YashanDB SQL Enterprise Edition Release 23.2 x86_64

Connected to:
YashanDB Server Enterprise Edition Release 23.2 x86_64 - X86 64bit Linux
SQL> CREATE TABLE customer(cno INT, cname VARCHAR(50));
 
 
SQL> INSERT INTO customer VALUES(1, 'customer1');
 
 
SQL> SELECT cno,cname FROM customer;
 
         CNO CNAME                                                
------------ -----------------------------------------------------
           1 customer1                                           
 

方式二:执行单条SQL语句并退出

通过参数-c "SQL"可以直接在操作系统层面连接登录到数据库执行单条SQL语句,执行完后不保留登录状态(直接退出)。

示例

$ yasql sales/sales -c "select 1 from dual";
           1
------------
           1

# 执行SQL文件

方式一:通过-f[-e]参数

通过参数-f [-e] filename[.ext]可以直接在操作系统层面连接登录到数据库执行一个SQL文件,后缀名可省略。

  • -f用于指定需执行的SQL文件。

  • -e用于显示文件中被执行的具体语句。

当SQL文件位于yasql工具同目录时无需指定文件路径,否则需指定文件所在路径(绝对路径或相对路径均可)。

示例

-- s.sql在yasql同目录下
$ yasql sales/sales -f s.sql
SQL> SELECT 1 FROM dual;
 
           1
------------
           1
 
 
SELECT 2 FROM dual;
 
           2
------------
           2
 

方式二:通过@或@@方式

通过@filename[.ext]或@@filename[.ext]命令可以执行本地SQL文件,后缀名可省略。具体使用方式如下:

  • 登录数据库后,在yasql命令行界面直接执行@filename[.ext]@@filename[.ext]

  • 直接在操作系统层面执行yasql username/password@host:port @filename[.ext]yasql username/password@host:port @@filename[.ext]连接登录到数据库执行本地SQL文件,执行完后会保留登录状态和yasql命令行界面。

在以交互方式输入@file_name.ext@@file_name.ext时,@或@@会在当前工作目录下查找所需要被调用的文件。当SQL文件位于yasql工具当前工作目录时无需指定文件路径,否则需指定文件所在路径(绝对路径或相对路径均可)。

示例

-- s.sql在yasql同目录下
@s.sql
 
           1
------------
           1
 
 
 
           2
------------
           2
 
 
 
-- 绝对路径
@/home/yasdb/s.sql
 
           1
------------
           1
 
 
 
           2
------------
           2
 
 
-- 相对路径
@../s.sql
 
           1
------------
           1
 
 
 
           2
------------
           2
 

在不存在脚本嵌套调用时,@与@@命令等价。

在脚本s_1.sql中写入含有@@ s_2.sql的命令后,再使用@s_1.sql或@@s_1.sql调用s_1.sql脚本嵌套调用s_2.sql时,@@会在s_1.sql所在路径中查找嵌套脚本s_2.sql,而不是当前工作目录。

# 输出保存为文件

SPOOL命令用于将yasql会话中的输出内容保存到文件中,命令格式:

SPO[OL] [file_name[.ext] [CRE[ATE] | REP[LACE] | APP[END]] | OFF]

file_name[.ext]

指定用于保存输出结果的文件名,名称规则如下:

  • 若file_name包含空格,则必须使用引号包围file_name。
  • 文件后缀名可省略,省略后默认拓展名为.LST(Windows系统中为全大写)或.lst(Linux系统中为全小写)。

文件后缀名不会附加到/dev/null和/dev/stderr等系统文件。

CRE[ATE]

创建指定名称的新文件,此时file_name[.ext]不能与已有文件重名。

REP[LACE]

使用输出结果的文件替换已有文件,此时file_name[.ext]需指定为已有文件的名称。

当未指定[CRE[ATE] | REP[LACE] | APP[END]]选项时,默认为REP[LACE],即SPO[OL] [file_name[.ext]等同于SPO[OL] [file_name[.ext] REP[LACE]

APP[END]

在已有文件后追加输出结果内容,此时file_name[.ext]需指定为已有文件的名称。

OFF

停止保存输出内容到文件中。

在yasql会话中使用SPOOL命令的流程通常如下:

  1. 执行SPO[OL] file_name[.ext] [CRE[ATE] | REP[LACE] | APP[END]命令开启保存为文件。
  2. 执行其他SQL语句(例如SELECT语句等),所有输出结果都会被保存到指定文件中。
  3. 执行SPO[OL] OFF命令停止保存。

若执行SPO[OL] file_name[.ext] [CRE[ATE] | REP[LACE] | APP[END]后再重复执行该命令,效果等同于在两次SPOOL命令之间执行过SPO[OL] OFF命令。

示例

spool employees.txt create
SELECT * FROM employees;
spool off

执行上述示例后,会创建一个名为employees.txt的文件并将查询结果将会保存到该文件中。

# 执行PL语句

登录数据库后,在yasql命令行界面可直接执行PL语句,执行PL语句时需要在过程体后加“/”。

示例

SET serveroutput ON
  
DECLARE
i INT;
BEGIN
i := 0;
IF i < 5 THEN
i := i + 1;
DBMS_OUTPUT.PUT_LINE ('This is: '||i);
END IF;
END;
  /
 
This is: 1

# 执行shell命令

在yasql命令行界面,通过!可以执行操作系统层面的shell命令。

示例

-- 在yasql中执行外部OS命令date 
!date
Tue Aug  3 14:11:39 CST 2021

# 终止执行SQL操作

终止当前执行的SQL进程有以下方法:

  • 在yasql命令行界面按Ctrl+C,如果当前存在正在执行的SQL语句,yasql会发送cancel消息到服务端,由服务端终止当前SQL。

  • yasql登录的进程在操作系统层面被终止时,直接退出。

# 查看参数信息

  • 通过show TIMI[NG] | AUTO[COMMIT] | SERVEROUT[PUT] | DIRE[CTEXECUTE] | NUM[WIDTH] |FEED[BACK] | HEA[DING]可以查看yasql的参数信息。

  • 通过show parameter param_name可以查看YashanDB的配置参数信息。

示例

SHOW SERVEROUT
serveroutput OFF
 
SHOW PARAMETER DB_BLOCK_SIZE;
NAME                   VALUE    
---------------------- ----------
DB_BLOCK_SIZE          8192

# 设置显示宽度

在输出浮点类型和NUMBER类型数据时,可通过set num[width] <1~128>命令设置显示宽度,该宽度默认为10,取值范围为[1,128]。

示例

show num
numwidth 10

CREATE TABLE item(ino INT, price DOUBLE);
 
 
INSERT INTO item VALUES(1, 57.6783924);
 
 
SELECT INO,PRICE FROM item;
 
         INO       PRICE
------------ -----------
           1  5.768E+001
 
 
SET num 20
SELECT INO,PRICE FROM item;
 
         INO                 PRICE
------------ ---------------------
           1       5.76783924E+001
 

# 事务自动提交

通过set auto[commit] on|off命令可以设置是否开启自动提交,默认为off。当autocommit为on时,每执行完一条SQL语句都将自动提交事务,可使用show autocommit查看当前配置。

示例

SET autocommit ON
SET autocommit OFF
SET auto ON
SET auto OFF

show autocommit
autocommit OFF

# 获取执行耗时

通过set timi[ng] on|off可以设置是否开启执行耗时统计,默认为off,耗时显示格式为"Elapsed: hh:mm:ss.ff"。

示例

SET timing ON
SELECT open_mode FROM V$DATABASE;
 
OPEN_MODE        
-----------------
READ_WRITE      
 
 
Elapsed: 00:00:00.000

SET timing OFF
SELECT open_mode FROM V$DATABASE;
 
OPEN_MODE        
-----------------
READ_WRITE      
 

# 设置一次执行

通过set DIRE[CTEXECUTE] on|off可以设置是否开启SQL语句的一次执行,默认为on。

  • on:一条SQL语句执行一次报文交互。

  • off:一条SQL语句执行两次报文交互。

示例

SET directexecute ON
SET directexecute OFF

show directexecute
directexecute OFF

# 替换占位符

通过set DEF[INE] ON或OFF可以设置是否开启扫描并替换命令中的占位符“&”变量,默认为on。可使用show DEF[INE]查看当前配置。

  • on:替换占位符。

  • off:不替换占位符。

示例

SET define ON
SET define OFF

show define
define OFF

DEFINE开关为ON时,yasql会扫描并替换命令中的占位符“&”变量。

若提前通过DEFINE为变量赋值,则不会出现提示,否则yasql会提示需要输入相应的值赋给变量。

示例

SELECT '&yasql' FROM dual;
Enter value for yasql: YashanDB
old     1: SELECT '&yasql' FROM dual
new     1: SELECT 'YashanDB' FROM dual

'YASHANDB'
----------
YashanDB

# 变量赋值

通过DEFINE指令为变量赋值(CHAR值),然后在SQL语句中使用该变量。

输入不带子句的DEFINE以列出所有替换变量的值和类型。

如果为变量赋值了数字20,yasql会指定一个CHAR值,该值由2和0两个字符组成。

若提前通过DEFINE为变量赋值,则不会出现提示,否则yasql会提示需要输入相应的值赋给变量。

示例

-- 定义变量
DEFINE POS = MANAGER
DEFINE DEPARTMENT_ID = 20
-- 查询变量
DEFINE
DEFINE DEPARTMENT_ID           = "20" (CHAR)
DEFINE POS             = "MANAGER" (CHAR)
-- 使用变量
SELECT '&POS' FROM dual;
old     1: SELECT '&POS' FROM dual
new     1: SELECT 'MANAGER' FROM dual

'MANAGER'
---------
MANAGER


SELECT '&DEPARTMENT_ID' FROM dual;
old     1: SELECT '&DEPARTMENT_ID' FROM dual
new     1: SELECT '20' FROM dual

'20'
-----
20

# 显示反馈信息

通过set FEED[BACK] on|off可以设置是否显示反馈信息,默认为on。

  • on:显示反馈信息。

  • off:不显示反馈信息。

反馈信息可能为“Succeed.”、“PL/SQL Succeed.”或“ROW_NUM row/rows affected.”,不包含错误码。

示例

SET feedback ON
SELECT * FROM dual;
 
DUMMY
-----
X
 
 
SET feedback OFF
SELECT * FROM dual;
DUMMY
-----
X

show feedback
feedback OFF

# 打印列标题

通过set HEA[DING] on|off可以设置是否打印显示报告中的列标题,默认为on。

  • on:打印列标题。

  • off:不打印列标题。SET HEADING OFF不会影响显示的列宽。

示例

SET heading ON
SELECT * FROM dual;
 
DUMMY
-----
X
 
 
SET heading OFF
SELECT * FROM dual;
 
X
 
 
show heading
heading OFF

# 列显示属性

# 指定列显示属性

指定目标列的显示属性。通过列名确定目标,如果从不同的表中查询具有相同名称的列,则该列名的COLUMN命令将应用于所有具有相同名称的列。

命令格式:

-- 格式1
COL/COLUMN <column name> FOR/FORMAT <format string>

-- 格式2
COL/COLUMN "<column name>" FOR/FORMAT "<format string>"

-- 格式3
COL/COLUMN '<column name>' FOR/FORMAT '<format string>'
  • COLUMN命令大小写不敏感,无通配符。

  • 通常使用单/双引号包围或无引号均可,但当其值存在特殊符号时则必须使用引号包围。

  • 如需在COLUMN命令中使用表达式,必须与SELECT命令中的表达式完全相同。例如SELECT命令中的表达式为a+b,COLUMN命令中则必须为a+b,不得改为b+a、(a+b)或其他。

  • "<column name>"长度范围为[1,64]个字节。

指定列显示属性的使用规则如下:

  • 目前仅支持对字符列使用COLUMN命令,且其默认宽度为数据库中列的宽度,如需将调整显示宽度需使用FORMAT An,其中n取[1,32000]区间的整数。当指定的宽度小于字符串长度时,默认直接截断(truncate)列中的元素进行显示。

  • 若对数值列使用COLUMN命令,该列将会显示为“#”字符串。

示例

SELECT deparment_no,department_name FROM department;

DEPARMENT_NO DEPARTMENT_NAME
------------ ---------------------
000          不分部门
010          销售部
008          采购部
002          财务部


col department_name format a8;
SELECT deparment_no,department_name FROM department;

DEPARMENT_NO DEPARTMENT_NAME
------------ ---------------------
000          不分部门
010          销售部
008          采购部
002          财务部


col department_name format a4;
SELECT deparment_no,department_name FROM department;

DEPARMENT_NO DEPA
------------ ----
000          不分
010          销售
008          采购
002          财务

# 查看列显示属性

  • 通过COL/COLUMN <column name>命令可以查看指定单列的当前显示属性。

  • 通过COL/COLUMN命令可以查看所有列的当前显示属性。

示例

-- 显示单列的显示属性值
col col1
COLUMN	 col1 ON
FORMAT	 a11

-- 显示所有列的显示属性值
col
COLUMN	 col1 ON
FORMAT	 a11

# 重置/清除列显示属性

  • 通过COLUMN命令的CLEAR子句可以重置单列的显示属性。

  • 通过CL/CLEAR COL/COLUMN/COLUMNS可以将COLUMN命令设置的列显示属性重置为所有列的默认设置。 示例

-- 将单列的显示属性值清除
col col2 clear
col
COLUMN	 col1 ON
FORMAT	 a11

-- 将所有列的显示属性值清除
CLEAR COLUMNS
columns cleared

# 获取描述信息

可以通过describe或desc <table name>|<view name>命令获取数据库对象的描述信息。

示例

desc v$database
NAME                                                             NULL?     DATATYPE                          
---------------------------------------------------------------- --------- --------------------------------- 
DATABASE_ID                                                                BIGINT                            
DATABASE_NAME                                                              VARCHAR(64)                       
CREATE_TIME                                                                DATE                              
LOG_MODE                                                                   VARCHAR(16)                       
OPEN_MODE                                                                  VARCHAR(16)                       
PROTECTION_MODE                                                            VARCHAR(32)                       
PROTECTION_LEVEL                                                           VARCHAR(32)                       
DATABASE_ROLE                                                              VARCHAR(16)                       
BLOCK_SIZE                                                                 INTEGER                           
CURRENT_SCN                                                                BIGINT                            
STATUS                                                                     VARCHAR(32)                       
RCY_POINT                                                                  VARCHAR(32)                       
FLUSH_POINT                                                                VARCHAR(32)                       
RESET_POINT                                                                VARCHAR(32)                       
PLATFORM_NAME                                                              VARCHAR(256)                      
HOST_NAME                                                                  VARCHAR(256)                      
RESTORE_TIME                                                               DATE                              
SWITCHOVER_STATUS                                                          VARCHAR(32)                       
SUPPLEMENTAL_LOG_DATA_MIN                                                  VARCHAR(8)                        
SUPPLEMENTAL_LOG_DATA_PK                                                   VARCHAR(8)                        
SUPPLEMENTAL_LOG_DATA_ALL                                                  VARCHAR(8)                        
SUPPLEMENTAL_LOG_TABLE_TYPE                                                VARCHAR(16)                        

# 退出登录

# 手动退出

通过EXIT [SUCCESS | FAILURE | WARNING | n ] [COMMIT | ROLLBACK]命令可退出yasql,并执行相应操作。

EXIT能够指定操作系统返回代码。关键字SUCCESS、WARNING和FAILURE表示与操作系统相关的值。在Linux上,返回代码只有一个字节的存储空间;因此,操作系统返回代码的范围受到限制,返回代码的范围被限制为0到255。

执行EXIT默认为执行EXIT SUCCESS COMMIT。如果在EXIT选项中出现语法错误或使用非数字变量,yasql将执行EXIT FAILURE COMMIT。

-- 直接退出
EXIT

-- 执行回滚操作后退出,并返回99
EXIT 99 rollback

-- 提交所有未提交的事务后退出,并返回最后执行的SQL命令或PL块的错误代码
EXIT SQL.SQLCODE

-- 以成功状态退出,并返回值为0表示成功
EXIT SUCCESS

-- 以失败状态退出,并返回值为1表示失败
EXIT FAILURE

-- 以警告状态退出,并返回值为2表示警告
EXIT WARNING

# 报错自动退出

通过WHENEVER SQLERROR EXIT [SUCCESS | FAILURE | WARNING | n] [COMMIT | ROLLBACK]命令可以启动报错自动退出,即当SQL命令或PL块生成错误时执行相应的EXIT操作,此处的EXIT语法与主动退出的EXIT语句完全一致。

Note:

仅在错误码为YAS的错误场景生效,且仅在当前yasql进程生效,在错误码为YASQL的错误场景不生效。开启set serveroutput on后,匿名块中的error occurred不生效。

-- 遇到报错后直接退出
WHENEVER SQLERROR EXIT
INSERT test;

[1:8]YAS-04115 "INTO" expected but missing

-- 遇到报错后执行回滚操作后再退出,并返回99
WHENEVER SQLERROR EXIT 99 rollback
INSERT test;

[1:8]YAS-04115 "INTO" expected but missing

-- 遇到报错后提交所有未提交的事务后再退出,并返回最后执行的SQL命令或PL块的错误代码
WHENEVER SQLERROR EXIT SQL.SQLCODE
INSERT test;

[1:8]YAS-04115 "INTO" expected but missing

# 断开连接

使用disconnect命令或disc命令断开与数据库的连接,断开连接后将无法执行SQL语句,可通过conn命令重新登录。

disc