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条(客户真实数据,量不大),分页查询 ...
随机推荐
- PHP如何使用AES加密和解密
AES加密在php5的版本中使用的mcrypt_decrypt 函数,该函数已经在php7.1后弃用了,取而代之的是openssl的openssl_encrypt和openssl_decrypt,并且 ...
- 给元素绑定 class
<div id="app04"> <label v-bind:class="{'Class1':Class1}">sasjadjagd& ...
- SparkStreaming反压机制
一.背景 在默认情况下,Spark Streaming 通过 receivers (或者是 Direct 方式) 以生产者生产数据的速率接收数据.当 batch processing time > ...
- hdu 5885 XM Reserves (FFT建模)
Problem Description As an eligible Ingress Resistance Agent you should know your power source, the E ...
- Security基础(一):Linux基本防护措施、使用sudo分配管理权限、提高SSH服务安全
一.Linux基本防护措施 目标: 本案例要求练习Linux系统的基本防护措施,完成以下任务: 修改用户zhangsan的账号属性,设置为2015-12-31日失效(禁止登录) 锁定用户lisi的账户 ...
- webpack+vue+koa+mongoDB,从零开始搭建一个网站
github 地址 https://github.com/wangxiaoxi... webpakc+vue的搭建1.新建项目文件夹(see-films);2.npm init //初始化项目3.搭建 ...
- java.lang.String中的replace方法到底替换了一个还是全部替换了。
你没有看错我说的就是那个最常用的java.lang.String,String可以说在Java中使用量最广泛的类了. 但是我却发现我弄错了他的一个API(也可以说是两个API),这个API是关于字符串 ...
- JS-ValidForm:介绍
ylbtech-JS-ValidForm:介绍 1.返回顶部 1. 关于Validform Validform:一行代码搞定整站的表单验证! 1 $(".demoform").Va ...
- 94、tensorflow实现语音识别0,1,2,3,4,5,6,7,8,9
''' Created on 2017年7月23日 @author: weizhen ''' #导入库 from __future__ import division,print_function,a ...
- ivew Table 固定列设置后,底部拖拽的横轴被覆盖拉不动
原因:设置了max-height=500px:表格最大高度,单位 px,设置后,如果表格内容大于此值,会固定表头.去掉即可.