#for xml path(param)--将查询结果以xml格式输出 select id,name from table1 for xml path --id和name为table1的真实字段 - path后面没有参数时,每行数据被默认<row>标签包裹,每行列数据被被其列名标签包裹. 上面sql的结果可如下: <row> <id></id> <name>holab</name> </row> <row> &…
1.使用函数(sql2000以上) )) ) AS BEGIN ) select @v = isnull(@v + ',','')+code FROM dict WHERE type=@filter RETURN @v END GO 调用如下: SELECT dbo.dictCodesConcatByType('Status') 如果你希望做成通用函数,类似如下:(其实是不可行的) ),),)) ) AS BEGIN ),) SET @v = '' set @sqlStr=' select @v…
复杂查询(下):子查询 8. 1 非关联子查询:返回的值可以被外部查询使用.子查询可以独立执行的(且仅执行一次). 8.1.1 单行单列子查询,子查询仅返回一个值,也称为标量子查询,采用单行比较运算符(>,<,=,<>,>=,<=) 例:内部SELECT子句只返回一行结果 SQL>select ename,salfrom empwhere sal > ( select sal from emp where ename='JONES')/例:和…
我们在做sql查询的时候,有时候需要将查询的列作为表名,去引用,然后再次查询 declare @table_name varchar(20) select @table_name=table_name from a where <条件> exec('select * from '+@a) 此sql其实就是先将sql拼接成字符串,然后再将字符串转成sql指令,如果查询到的结果只有一列的时候,我们可以这样做,如果 @table_name的值有多个,则无法运用此方法 但是,如果碰到这种情况,我们查询…