Sqlserver复杂查询
--联表修改
update xyzrb
set xyzrb.xy_card=tablsb.card
from xyzrb left join tablsb on xyzrb.xybh=tablsb.xybh
--取重复数据的各最大一条
select x.comment as comment,x.fidcoachid as fidcoachid from xcb_comment x
right join
(select max(id) as id,fidcoachid from xcb_comment group by fidcoachid) as mc
on mc.id=x.id;
--查询出多行数据合并成一行
SELECT s.*, B.name AS fidDModelName,
subjects = (stuff((SELECT ',' + h.name FROM xcb_coachattr t LEFT JOIN hrm_BaseData h ON h.id = t.fiddata AND t .code = 'subjects' WHERE t .fidcoachid = s.id FOR xml path('')), 1, 1, '')),
regions = (stuff((SELECT ',' + h.name FROM xcb_coachattr t LEFT JOIN hrm_BaseData h ON h.id = t.fiddata AND t .code = 'Region' WHERE t .fidcoachid = s.id FOR xml path('')), 1, 1, ''))
FROM xcb_coach s LEFT JOIN hrm_BaseData B ON S.fidDModel = B.id AND B.Code = 'DModel' WHERE 1 = 1
--高级多表联表查询
select
s.chrstuno as schrstuno,
s.chrname as schrname,
s.chrphone as schrphone,
B.name as fidDModelName,
c.chrname as cchrname,
c.chrphone as cchrphone,
c.carNo as ccarNo,
B1.name as fidsubjectname,
B2.name as fidRegionname,
CONVERT(varchar(10),o.orderdate,23) as orderdate,
case when o.paytype =1 then '现金支付'
when o.paytype = 2 then '课时支付'
end as paytype,
from xcb_order o
left join hrm_BaseData B on o.fidDModel=B.id and B.Code='DModel'
left join hrm_BaseData B1 on o.fidsubject=B1.id and B1.Code='subjects'
left join hrm_BaseData B2 on o.fidRegion=B2.id and B2.Code='Region'
left join xcb_students s on o.fidstudent=s.id
left join xcb_coach c on o.fidcoachid=c.id
where o.fidcorp=1 and o.statue in(1,2,3,4,5,6)
--生成Java实体对象
SELECT
case
when isnullable='' then '@NotNull'+CHAR(10)+CHAR(13)
else ''
end+
case
when xtype='' or xtype='' or xtype='' or xtype='' or xtype=''
then '@Size(max = '+convert(varchar(12),length)+')'+CHAR(13)+CHAR(10)+'@Column(name = "'+Name+'")'+CHAR(13)+CHAR(10)+'private String '
when xtype='' or xtype='' or xtype=''
then '@Column(name = "'+Name+'")'+CHAR(13)+CHAR(10)+'private int '
when xtype='' or xtype=''
then '@Column(name = "'+Name+'")'+CHAR(13)+CHAR(10)+'private BigDecimal '
when xtype='' or xtype=''
then '@Column(name = "'+Name+'")'+CHAR(13)+CHAR(10)+'@Temporal(TemporalType.TIMESTAMP)'+CHAR(13)+CHAR(10)+'private Date '
end+Name+';',xtype FROM SysColumns WHERE id=Object_Id('xcb_clglb')
--int类型字段拼接字符转换
select convert(varchar(30),id)+'' from xcb_students where id=11; --查询所有表名
select 'select * from '+ name+'; --' from sysobjects where xtype='u' order by name; --查询表所有字段
select name+',' FROM SysColumns WHERE id=Object_Id('xyfyb') ;
--查看表字段及说明
SELECT t.[name] AS 表名,c.[name] AS 字段名,cast(ep.[value] as varchar(100)) AS [字段说明]
FROM sys.tables AS t
INNER JOIN sys.columns AS c ON t.object_id = c.object_id
LEFT JOIN sys.extended_properties AS ep
ON ep.major_id = c.object_id AND ep.minor_id = c.column_id WHERE t.name='TableName'
--快速查询表数据结构
SELECT CASE WHEN col.colorder = 1 THEN obj.name ELSE '' END AS 表名,
col.colorder AS 序号 ,
col.name AS 列名 ,
ISNULL(ep.[value], '') AS 列说明 ,
t.name AS 数据类型 ,
col.length AS 长度 ,
ISNULL(COLUMNPROPERTY(col.id, col.name, 'Scale'), 0) AS 小数位数 ,
CASE WHEN COLUMNPROPERTY(col.id, col.name, 'IsIdentity') = 1 THEN '√' ELSE '' END AS 标识 ,
CASE WHEN EXISTS ( SELECT 1 FROM dbo.sysindexes si INNER JOIN dbo.sysindexkeys sik ON si.id = sik.id AND si.indid = sik.indid INNER JOIN dbo.syscolumns sc ON sc.id = sik.id AND sc.colid = sik.colid INNER JOIN dbo.sysobjects so ON so.name = si.name AND so.xtype = 'PK' WHERE sc.id = col.id AND sc.colid = col.colid ) THEN '√' ELSE '' END AS 主键 ,
CASE WHEN col.isnullable = 1 THEN '√' ELSE '' END AS 允许空 ,
ISNULL(comm.text, '') AS 默认值 FROM dbo.syscolumns col
LEFT JOIN dbo.systypes t ON col.xtype = t.xusertype
inner JOIN dbo.sysobjects obj ON col.id = obj.id AND obj.xtype = 'U' AND obj.status >= 0
LEFT JOIN dbo.syscomments comm ON col.cdefault = comm.id
LEFT JOIN sys.extended_properties ep ON col.id = ep.major_id AND col.colid = ep.minor_id AND ep.name = 'MS_Description'
LEFT JOIN sys.extended_properties epTwo ON obj.id = epTwo.major_id AND epTwo.minor_id = 0 AND epTwo.name = 'MS_Description' WHERE obj.name = 'cartab'--表名
ORDER BY col.colorder ;
--生成Java实体类(含字段说明)
SELECT
case
when c.is_nullable='' then '@NotNull'
else ''
end+
case
when c.user_type_id='' or c.user_type_id='' or c.user_type_id='' or c.user_type_id='' or c.user_type_id=''
then '@Size(max = '+convert(varchar(12),c.max_length)+')'+'@Column(name = "'+c.name+'")'+'private String '
when c.user_type_id='' or c.user_type_id='' or c.user_type_id=''
then '@Column(name = "'+c.name+'")'+'private int '
when c.user_type_id='' or c.user_type_id=''
then '@Column(name = "'+c.name+'")'+'private BigDecimal '
when c.user_type_id='' or c.user_type_id=''
then '@Column(name = "'+c.name+'")'+'@Temporal(TemporalType.TIMESTAMP)'+'private Date '
end+c.name+';//'+cast(ISNULL(ep.[value],'') as varchar(100)) FROM sys.tables AS t
INNER JOIN sys.columns AS c ON t.object_id = c.object_id
LEFT JOIN sys.extended_properties AS ep ON ep.major_id = c.object_id AND ep.minor_id = c.column_id
WHERE t.name='basedata';
Sqlserver复杂查询的更多相关文章
- SqlServer 一个查询语句以致tempdb增大55G (转载)
SqlServer 一个查询语句导致tempdb增大55G 今天操作着服务器,突然右下角提示“C盘空间不足”! 吓一跳!~ 看看C盘,还有7M!!!这么大的C盘空间怎么会没了呢?搞不好等下服务器会动不 ...
- SQLServer中查询的数字列前面补0返回指定长度的字符串
SQLServer中查询的数字列前面补0返回指定长度的字符串: 如: 角本如下: /****** Script for SelectTopNRows command from SSMS ******/ ...
- SQLServer分页查询存储过程
项目中用到的SQLServer分页查询存储过程. [存储过程] create PROCEDURE prcPageResult -- 获得某一页的数据 -- @currPage int = 1, ...
- SQLServer 分组查询相邻两条记录的时间差
原文:SQLServer 分组查询相邻两条记录的时间差 首先,我们通过数据库中表的两条记录来引出问题,如下图 以上为一个记录操作记录的表数据.OrderID为自增长列,后面依次为操作类型,操作时间,操 ...
- SqlServer 一个查询语句导致tempdb增大55G(转载)
SqlServer 一个查询语句导致tempdb增大55G 今天操作着服务器,突然右下角提示“C盘空间不足”! 吓一跳!~ 看看C盘,还有7M!!!这么大的C盘空间怎么会没了呢?搞不好等下服务器会动不 ...
- 图解SQLSERVER联合查询和连接查询的区别
相信很多人都会用SQLSERVER联合查询和连接查询,但是用起来不一定都得心应手,对于其中的原理可能就模糊不清了,要想很牢固地掌握和运用SQL联合查询和连接查询机制,必须对其根本原理有很清晰认识, ...
- SQLServer导出查询结果带表头(标题行)
SQLServer导出查询结果带表头(标题行) 平时我们经常会需要将SQLSERVER查询的结果复制到EXCEL文档中进行分析处理,但是有一件事很头痛,就是复制结果网格的数据到EXCEL之后,都是没有 ...
- SQLServer数据库查询语法
SQLServer数据库查询语法 前言: SQLServer数据库介绍: SQLServer数据库是微软公司推出的一款关系型数据库系统,SQL Server是一个可扩展的.高性能的.为分布式客户机/服 ...
- 高效的SQLSERVER分页查询的几种示例分析
Sqlserver数据库分页查询一直是Sqlserver的短板,闲来无事,想出几种方法,假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页查询 ...
- 真正高效的SQLSERVER分页查询(多种方案)
Sqlserver数据库分页查询一直是Sqlserver的短板,闲来无事,想出几种方法,假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页查询 ...
随机推荐
- 【leetcode】757. Set Intersection Size At Least Two
题目如下: 解题思路:贪心算法.首先把intervals按第二个元素从小到大排序,然后遍历intervals,如果集合S和intervals[i]没有交集,那么把intervals[i]的最大值和次大 ...
- websocket 中使用Service层的方法
创建公共Utils 类 ApplicationContextRegister @Component @Lazy(false) public class ApplicationContextRegist ...
- css float 浮动
CSS Float(浮动) 什么是 CSS Float(浮动)?大理石平台价格 CSS 的 Float(浮动),会使元素向左或向右移动,其周围的元素也会重新排列. Float(浮动),往往是用于图像, ...
- 探索Redis设计与实现13:Redis集群机制及一个Redis架构演进实例
本文转自互联网 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial ...
- 修改Mysql procedure,function and view definer
1 一次性修改遇到错误 update mysql.proc set definer='root@%'; update mysql.proc set definer='root@%'; ERROR 10 ...
- Linux基础-命令概述
概述 很多人可能在电视或电影中看到过类似的场景,黑客面对一个黑色的屏幕,上面飘着密密麻麻的字符,梆梆一顿敲,就完成了窃取资料的任务,是不是很帅!我们作为一个开发者, 即使不为了成为上述的人, 也需要会 ...
- activiti7业务表示Businesskey
启动流程实例时,指定的businesskey,就会在act_ru_execution #流程实例的执行表中存储businesskey. Businesskey:业务标识,通常为业务表的主键,业务标识和 ...
- PHP中使用raw格式发送POST请求
如果请求的参数格式是原生(raw)的内容,应该如何为程序构造一个POST请求函数呢? function http_post($url, $data_string) { $ch = curl_init( ...
- 转 MySQL乐观锁和悲观锁
悲观锁(Pessimistic Lock) 顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁.传统的关系型数据库 ...
- Python37不能启动pyspider
报错内容: Traceback (most recent call last): File "/usr/local/var/pyenv/versions/3.7.3/bin/pyspider ...