VimIy微民网,让世界倾听微民的声音! 设为首页 | 加入收藏 | 网站地图
当前位置:主页 > 微博精选 >

[sql] [求高人]码农数据库求教啊

整理时间:2012-07-25 12:56 热度:°C

问个SQL语句
   字段里面的数据用逗号隔开的,想将他们转化成单独的列,语句怎么整
   
   
   就是1,2,3,4,5
   
   转成
   1
   2
   3
   4
   5大学的时候学过,现在我不会了。友情挽尊怒挽,求指教一个sql能搞定?这是多条记录了吧,楼主写个函数或过程转吧。或者把整个问题贴出来
   请百度 oracle split
   
   一个sql能搞定?这是多条记录了吧,楼主写个函数或过程转吧。或者把整个问题贴出来
   
   
   一个表字段没看懂什么意思。
   
   是表里某个字段名称 ,把里面用逗号隔开的字符当做一个新字段,建张新表?
   
   还是将查询的结果集里,把用逗号分开的记录再次拆分,形成新记录?取到后台用程序搞定不好么?就是某个字段 是1,2,3,4
   然后要把她变成
   字段 1
   字段 2
   字段 3
   字段 4
   对吧?
   不会...
   这个纯SQL不知道咋实现
   笨办法是复制一个表
   然后删除这一列
   然后把那个字段的对应值提出来 用字符处理 把他们根据逗号分割
   一个一个插进去...
   求高人解答 Post by lq307013304 (2012-07-24 12:53)
   
   对,就是这个意思 Post by wushigan13 (2012-07-24 12:54)
   
   纯SQL
   不知道怎么判断逗号..而且也不知道怎么进行复杂的逻辑..只能用SQL语句么- -PL/SQL 中没有split函数,需要自己写。
   
   create or replace type type_split as table of varchar2(50); --创建一个type,如果为了使split函数具有通用性,请将其size 设大些。
   
   
   --创建function
   create or replace function split
   (
    p_list varchar2,
    p_sep varchar2 := ','
   ) return type_split pipelined
    is
    l_idx pls_integer;
    v_list varchar2(50) := p_list;
   begin
    loop
    l_idx := instr(v_list,p_sep);
    if l_idx > 0 then
    pipe row(substr(v_list,1,l_idx-1));
    v_list := substr(v_list,l_idx+length(p_sep));
    else
    pipe row(v_list);
    exit;
    end if;
    end loop;
    return;
   end split;
   测试:
   
   
   
   SQL> select * from table(split('northsnow,塞北的雪',','));
   
   COLUMN_VALUE
   --------------------------------------------------
   northsnow
   塞北的雪
   
   SQL>
   
   -----PIPELINED关键字是什么意思?
   ---- pipe row是什么意思?
   
   pipelined声名此function是pipe的,如果这么声名了,就必须使用pipe row的方式把数据返回,常规函数最后的"return 变量",就变成了"return".
   
   pipelined的function主要是为了提高效率,不用等所有的数据都处理完成了才返回客户端,它是边处理边返回.适用于大数据量的交互.上面有人提出oracle split
   
   撸主如果你用oracle的话,用这个功能应该可以实现用excel,分隔符分列,然后复制、选择性粘贴,转置,搞定
   
   没看懂什么意思。
   
   是表里某个字段名称 ,把里面用逗号隔开的字符当做一个新字段,建张新表?
   
   ?
   
   是这 个select substr(col,1,instr(col,',') as col from table楼上的真犀利
   
   PL/SQL 中没有split函数,需要自己写。
   
   create or replace type type_split as table of varchar2(50); --创建一个  type  ,如果为了使split函数具有通用性,请将其size 设大些。
   
   
   --创建function
   create or replace function split
   (
    p_list varchar2,
    p_sep varchar2 := ','
   ) return type_split pipelined
    is
    l_idx pls_integer;
    v_list varchar2(50) := p_list;
   begin
    loop
    l_idx := instr(v_list,p_sep);
    if l_idx > 0 then
    pipe row(substr(v_list,1,l_idx-1..
   
   太深奥,我看看,多谢你要的是横表转纵表吧,我只会建中间表一点点倒过去

关于网站 | 网站声明 | 用户反馈 | 合作伙伴 | 联系我们
Copyright 2012年2月8日 苏ICP备12030052号-3