有个ORACLE数据库,以前语句是
1.select * from resgroup where 1=1 start with ID=0 connect by prior ID = 3
2.select * from table_code where rownum <10
3.select rtrim(t.mid, ',') as mid from table_mastermapping t 
现在需要转换为SqlServer,请问对应的语句是什么?谢谢!

解决方案 »

  1.   

    select * from table_code where rownum <10 第二条应该一样select rtrim(t.mid, ',') as mid from table_mastermapping t 这个应该是截取最后的逗号,SELECT LEFT(T.MID,LEN(T.MID)-1)) mid FROM table_mastermapping t
      

  2.   

    第一个和第三个不知道啥意思,第二个这么写
    select TOP 10 * from table_code
      

  3.   


    2.select * from table_code where rownum <10-->select top 10 * from table_code3.select rtrim(t.mid, ',') as mid from table_mastermapping t-->select left(t.mid , charindex(',',t.mid) - 1) as mid from table_mastermapping t第一个没看懂.
      

  4.   

    第一个没用过,以下是相关资料.
    1. Hierarchical Queries: START WITH and CONNECT BY PRIOR clauses 
    -- Hierarchical Queries
    SQL>
    SQL> CREATE TABLE employee (
     2 employee_id INTEGER,
     3 manager_id INTEGER,
     4 first_name VARCHAR2(10) NOT NULL,
     5 last_name VARCHAR2(10) NOT NULL,
     6 title VARCHAR2(20),
     7 salary NUMBER(6, 0)
     8 );
    Table created.
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 1 ,0 , 'James' ,'Smith' ,'CEO',800000);1 row created.
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 2 , 1 ,'Ron' ,'Johnson','Sales Manager',600000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 3 , 2 ,'Fred' ,'Hobbs' ,'Sales Person',200000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 4 , 1 ,'Susan' ,'Jones' ,'Support Manager',500000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 5 , 2 ,'Rob' ,'Green' ,'Sales Person', 40000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 6 , 4 ,'Jane' ,'Brown' ,'Support Person',45000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 7 , 4 ,'John' ,'Grey' ,'Support Manager',30000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 8 , 7 ,'Jean' ,'Blue' ,'Support Person',29000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 9 , 6 ,'Henry' ,'Heyson' ,'Support Person',30000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 10 , 1 ,'Kevin' ,'Black' ,'Ops Manager',100000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 11 , 10 ,'Keith' ,'Long' ,'Ops Person',50000);1 row created.SQL>
    SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 12 , 10 ,'Frank' ,'Howard' ,'Ops Person',45000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 13 , 10 ,'Doreen' ,'Penn' ,'Ops Person',47000);1 row created.SQL> --START WITH and CONNECT BY PRIOR clauses.
    SQL>
    SQL> SELECT employee_id, manager_id, first_name, last_name
     2 FROM employee
     3 START WITH employee_id = 1
     4 CONNECT BY PRIOR employee_id = manager_id;EMPLOYEE_ID MANAGER_ID FIRST_NAME LAST_NAME
    ----------- ---------- ---------- ----------
     1 0 James Smith
     2 1 Ron Johnson
     3 2 Fred Hobbs
     5 2 Rob Green
     4 1 Susan Jones
     6 4 Jane Brown
     9 6 Henry Heyson
     7 4 John Grey
     8 7 Jean Blue
     10 1 Kevin Black
     11 10 Keith Long
     12 10 Frank Howard
     13 10 Doreen Penn13 rows selected.SQL>
    SQL> drop table employee;Table dropped.
      

  5.   

    2. Using a Subquery in a START WITH ClauseSQL> CREATE TABLE employee (
     2 employee_id INTEGER,
     3 manager_id INTEGER,
     4 first_name VARCHAR2(10) NOT NULL,
     5 last_name VARCHAR2(10) NOT NULL,
     6 title VARCHAR2(20),
     7 salary NUMBER(6, 0)
     8 );Table created.SQL>
    SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 1 ,0 , 'James' ,'Smith' ,'CEO',800000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 2 , 1 ,'Ron' ,'Johnson','Sales Manager',600000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 3 , 2 ,'Fred' ,'Hobbs' ,'Sales Person',200000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 4 , 1 ,'Susan' ,'Jones' ,'Support Manager',500000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 5 , 2 ,'Rob' ,'Green' ,'Sales Person', 40000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 6 , 4 ,'Jane' ,'Brown' ,'Support Person',45000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 7 , 4 ,'John' ,'Grey' ,'Support Manager',30000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 8 , 7 ,'Jean' ,'Blue' ,'Support Person',29000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 9 , 6 ,'Henry' ,'Heyson' ,'Support Person',30000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 10 , 1 ,'Kevin' ,'Black' ,'Ops Manager',100000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 11 , 10 ,'Keith' ,'Long' ,'Ops Person',50000);1 row created.SQL>
    SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 12 , 10 ,'Frank' ,'Howard' ,'Ops Person',45000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 13 , 10 ,'Doreen' ,'Penn' ,'Ops Person',47000);1 row created.SQL>
    SQL> --Using a Subquery in a START WITH Clause
    SQL>
    SQL> SELECT LEVEL,
     2 LPAD(' ', 2 * LEVEL - 1) || first_name || ' ' ||
     3 last_name AS employee
     4 FROM employee
     5 START WITH employee_id = (
     6 SELECT employee_id
     7 FROM employee
     8 WHERE first_name = 'Kevin'
     9 AND last_name = 'Black'
     10 )
     11 CONNECT BY PRIOR employee_id = manager_id; LEVEL EMPLOYEE
    ---------- -------------------------
     1 Kevin Black
     2 Keith Long
     2 Frank Howard
     2 Doreen PennSQL>
    SQL>
    SQL>
    SQL> drop table employee;Table dropped.=============3. Including Other Conditions in a Hierarchical QuerySQL> CREATE TABLE employee (
     2 employee_id INTEGER,
     3 manager_id INTEGER,
     4 first_name VARCHAR2(10) NOT NULL,
     5 last_name VARCHAR2(10) NOT NULL,
     6 title VARCHAR2(20),
     7 salary NUMBER(6, 0)
     8 );Table created.SQL>
    SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 1 ,0 , 'James' ,'Smith' ,'CEO',800000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 2 , 1 ,'Ron' ,'Johnson','Sales Manager',600000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 3 , 2 ,'Fred' ,'Hobbs' ,'Sales Person',200000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 4 , 1 ,'Susan' ,'Jones' ,'Support Manager',500000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 5 , 2 ,'Rob' ,'Green' ,'Sales Person', 40000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 6 , 4 ,'Jane' ,'Brown' ,'Support Person',45000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 7 , 4 ,'John' ,'Grey' ,'Support Manager',30000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 8 , 7 ,'Jean' ,'Blue' ,'Support Person',29000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 9 , 6 ,'Henry' ,'Heyson' ,'Support Person',30000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 10 , 1 ,'Kevin' ,'Black' ,'Ops Manager',100000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 11 , 10 ,'Keith' ,'Long' ,'Ops Person',50000);1 row created.SQL>
    SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 12 , 10 ,'Frank' ,'Howard' ,'Ops Person',45000);1 row created.SQL>
    SQL> insert into employee (EMPLOYEE_ID, MANAGER_ID,FIRST_NAME,LAST_NAME,TITLE,SALARY)
     2 values( 13 , 10 ,'Doreen' ,'Penn' ,'Ops Person',47000);1 row created.SQL>
    SQL>
    SQL>
    SQL>
    SQL> select * from employee;EMPLOYEE_ID MANAGER_ID FIRST_NAME LAST_NAME TITLE SALARY
    ----------- ---------- ---------- ---------- -------------------- ----------
     1 0 James Smith CEO 800000
     2 1 Ron Johnson Sales Manager 600000
     3 2 Fred Hobbs Sales Person 200000
     4 1 Susan Jones Support Manager 500000
     5 2 Rob Green Sales Person 40000
     6 4 Jane Brown Support Person 45000
     7 4 John Grey Support Manager 30000
     8 7 Jean Blue Support Person 29000
     9 6 Henry Heyson Support Person 30000
     10 1 Kevin Black Ops Manager 100000
     11 10 Keith Long Ops Person 50000
     12 10 Frank Howard Ops Person 45000
     13 10 Doreen Penn Ops Person 4700013 rows selected.SQL>
    SQL>
    SQL> -- Including Other Conditions in a Hierarchical Query
    SQL>
    SQL> SELECT LEVEL,
     2 LPAD(' ', 2 * LEVEL - 1) || first_name || ' ' ||
     3 last_name AS employee, salary
     4 FROM employee
     5 WHERE salary <= 50000
     6 START WITH employee_id = 1
     7 CONNECT BY PRIOR employee_id = manager_id; LEVEL EMPLOYEE SALARY
    ---------- ------------------------- ----------
     3 Rob Green 40000
     3 Jane Brown 45000
     4 Henry Heyson 30000
     3 John Grey 30000
     4 Jean Blue 29000
     3 Keith Long 50000
     3 Frank Howard 45000
     3 Doreen Penn 47000
    8 rows selected.
    SQL> drop table employee;
    Table dropped.
      

  6.   

    第一个就是个树的查询.参考如下:
    第一个就是树的查询.
    /*
    标题:查询指定节点及其所有子节点的函数
    作者:爱新觉罗·毓华(十八年风雨,守得冰山雪莲花开) 
    时间:2008-05-12
    地点:广东深圳
    */create table tb(id varchar(3) , pid varchar(3) , name varchar(10))
    insert into tb values('001' , null  , '广东省')
    insert into tb values('002' , '001' , '广州市')
    insert into tb values('003' , '001' , '深圳市')
    insert into tb values('004' , '002' , '天河区')
    insert into tb values('005' , '003' , '罗湖区')
    insert into tb values('006' , '003' , '福田区')
    insert into tb values('007' , '003' , '宝安区')
    insert into tb values('008' , '007' , '西乡镇')
    insert into tb values('009' , '007' , '龙华镇')
    insert into tb values('010' , '007' , '松岗镇')
    go--查询指定节点及其所有子节点的函数
    create function f_cid(@ID varchar(3)) returns @t_level table(id varchar(3) , level int)
    as
    begin
      declare @level int
      set @level = 1
      insert into @t_level select @id , @level
      while @@ROWCOUNT > 0
      begin
        set @level = @level + 1
        insert into @t_level select a.id , @level
        from tb a , @t_Level b
        where a.pid = b.id and b.level = @level - 1
      end
      return
    end
    go--调用函数查询001(广东省)及其所有子节点
    select a.* from tb a , f_cid('001') b where a.id = b.id order by a.id
    /*
    id   pid  name       
    ---- ---- ---------- 
    001  NULL 广东省
    002  001  广州市
    003  001  深圳市
    004  002  天河区
    005  003  罗湖区
    006  003  福田区
    007  003  宝安区
    008  007  西乡镇
    009  007  龙华镇
    010  007  松岗镇(所影响的行数为 10 行)
    */--调用函数查询002(广州市)及其所有子节点
    select a.* from tb a , f_cid('002') b where a.id = b.id order by a.id
    /*
    id   pid  name       
    ---- ---- ---------- 
    002  001  广州市
    004  002  天河区(所影响的行数为 2 行)
    */--调用函数查询003(深圳市)及其所有子节点
    select a.* from tb a , f_cid('003') b where a.id = b.id order by a.id
    /*
    id   pid  name       
    ---- ---- ---------- 
    003  001  深圳市
    005  003  罗湖区
    006  003  福田区
    007  003  宝安区
    008  007  西乡镇
    009  007  龙华镇
    010  007  松岗镇(所影响的行数为 7 行)
    */drop table tb
    drop function f_cid@@ROWCOUNT:返回受上一语句影响的行数。
    返回类型:integer。
    注释:任何不返回行的语句将这一变量设置为 0 ,如 IF 语句。
    示例:下面的示例执行 UPDATE 语句并用 @@ROWCOUNT 来检测是否有发生更改的行。UPDATE authors SET au_lname = 'Jones' WHERE au_id = '999-888-7777'
    IF @@ROWCOUNT = 0
       print 'Warning: No rows were updated'结果:(所影响的行数为 0 行)
    Warning: No rows were updated