oracle的pl/sql,不使用to_char,有办法把小数点前不显示的0显示出来吗?

declare
v_name varchar2(50);
v_sal number(7,2);
v_pin number(7,2);
c_psa constant number(3,2):=0.03;
begin
select ename,sal into v_name,v_sal from emp where empno=&请输入员工编号;
v_pin:=v_sal*c_psa;
dbms_output.put_line('姓名:'||v_name);
dbms_output.put_line('工资:'||v_sal);
dbms_output.put_line('个人所得税:'||v_pin);
dbms_output.put_line('税率:'||c_psa);
end;

税率的部分显示的.03,小数点前面少0
不使用to_char格式化,也不使用比较麻烦的函数,有办法显示吗?

没什么好方法,只能用to_char
dbms_output.put_line('税率:'|| to_char(c_psa,'fm9999999990.00'));
或者在前边定义变量的时候就设置为varchar2类型
或者decode函数,但是无法用在dbms_output.put_line中
decode(substr(c_psa,1,1),'.','0'||c_psa,c_psa)
温馨提示:答案为网友推荐,仅供参考
相似回答