PL-SQL存储过程拆分字符串

时间:2017-01-20 09:19:21

标签: sql stored-procedures plsql

我想做的是:

在java中,我有一个像''AB','BC','CD','DE'这样的数组,我想把它连接成类似“AB,BC,CD,DE”的东西并将它发送给程序作为一个论点。

在程序中,我的想法是,我想做类似

的事情
v_passedArgs --(AB,BC,CD,DE)

SELECT * FROM SOME_TABLE WHERE SOME_COL IN (v_passedArgs.split(','))

是否可以做类似的事情,或者你有另一个想法? 谢谢

2 个答案:

答案 0 :(得分:0)

您可以在数据库中创建一个split函数,并使用它在SQL中拆分包含分隔符的字符串(','在您的示例中)

Is there a function to split a string in PL/SQL?

请参阅上面的链接以创建拆分功能并在select语句中使用它

答案 1 :(得分:0)

你必须创建自己的功能。

您可以使用 Oracle PL/SQL collection ;这是一段代码,用于从具有给定分隔符(p_list)的输入字符串列表(p_sep)返回此类集合:

CREATE OR REPLACE TYPE t_my_list AS TABLE OF VARCHAR2(100);
CREATE OR REPLACE
FUNCTION cto_table(p_sep in Varchar2, p_list IN VARCHAR2)
  RETURN t_my_list
AS
  l_string VARCHAR2(32767) := p_list || p_sep;
  l_sep_index PLS_INTEGER;
  l_index PLS_INTEGER := 1;
  l_tab t_my_list     := t_my_list();
BEGIN
  LOOP
    l_sep_index := INSTR(l_string, p_sep, l_index);
    EXIT
  WHEN l_sep_index = 0;
    l_tab.EXTEND;
    l_tab(l_tab.COUNT) := TRIM(SUBSTR(l_string,l_index,l_sep_index - l_index));
    l_index            := l_sep_index + 1;
  END LOOP;
  RETURN l_tab;
END cto_table;
/

然后如何将其与TABLE中的SELECT关键字一起使用 - TABLE关键字将集合转换为Oracle SQL查询中可用的对象:

SELECT * FROM SOME_TABLE WHERE SOME_COL IN (
      select * from TABLE(cto_table(',', v_passedArgs))
)