小技巧

1.Float 转 varchar

前两天选择一个FLOAT型的字段,要转换为VARCHAR,可是小数点后面的都自动被删去了。。。后查得可以通过如下转换获得:

SELECT CAST(CAST(字段 AS DECIMAL(20,7)) AS VARCHAR(20)) FROM 要查的表
或者

SELECT CONVERT(VARCHAR(20),CONVERT(DECIMAL(20,7),字段)) FROM 要查的表

2.isdate 日起判断函数与nullif 前者等于后者则赋值 为null 连用

isdate(nullif([BadDebtTransferDate],‘‘))=0

SELECT COUNT(*) FROM dbo.[_rawATB]

WHERE

ISDATE(nullif([BadDebtTransferDate],‘‘))=0

AND

BadDebtTransferDate!=0 and BadDebtTransferDate != ‘‘

3.用法新颖的values

select i from  ( values(1),(2),(3),(4),(5),(6)) t(i)

4.获取某月最后一天日期(到底是30 还是31)此算法实际上是前一个月加一个月再减去一天

DECLARE @PostDateID INT

set @PostDateID = (select cast(convert(varchar,

(select DATEADD(mm,-1,PostDate) from dbo.logImportInfo where ID =(select top 1 ImportInfo_ID from dbo.cvtTXNS_CHGS)),112) as int)/100)

PRINT @PostDateID

SELECT DATEADD(DAY,-1,DATEADD(mm,1,CAST(CAST(@PostDateID AS VARCHAR(20) )+‘01‘ AS DATE)))

SELECT CAST(CONVERT(VARCHAR(20),GETDATE(),112) AS DATE)

DECLARE @PostDateID INT

set @PostDateID = (select cast(convert(varchar,

(select DATEADD(mm,-1,PostDate) from dbo.logImportInfo where ID =(select top 1 ImportInfo_ID from dbo.cvtTXNS_CHGS)),112) as int)/100)

PRINT @PostDateID-----

SELECT CAST(CAST(@PostDateID AS VARCHAR(20) )+‘01‘ AS DATE),DATEADD(DAY,-1,DATEADD(mm,1,CAST(CAST(@PostDateID AS VARCHAR(20) )+‘01‘ AS DATE)))

5.运用系统表查询列名,该列数据类型名,允许的长度

SELECT col.name,typ.name,typ.max_length FROM sys.all_columns col JOIN

sys.types  typ ON col.system_type_id=typ.system_type_id

WHERE col.object_id=object_id(‘cvtATB‘) AND col.name LIKE ‘%facility%‘

6.延时,定时技巧

a.延时三秒执行

waitfor delay ‘00:00:03‘

      select * from DimAccount

b.定时到这个时候执行

测试着玩:

alter  proc usp_intervalCall as

waitfor time ‘19:14:01‘

execute usp_ParseXMLFile

usp_intervalCall

7.Goto , Try catch

1.
比方说某库中有N个存储过程:
select name from sysobjects where xtype = ‘P‘;

name                                                                ------------------------------------------------------------------------------------------------------- 
SO_updateorderdetail
HR_ykf05p_calc
GL_uninit_comp_acct_must
……
……
(N row(s) affected)

那幺如何在不用光标不用循环的情况下用T-SQL语句将这个数据库中的所有存储过程删除?

2.
有一个字符串:  a,bc,d,abce,ddz
现在用T-SQL语句把这一字符串变成这种样子:
item       
---------- 
a
bc
d
abce
ddz

(5 row(s) affected)

(如果不用Cursor和循环,那幺有什幺好办法?)

第1题:
declare @v_sql varchar(8000)
set @v_sql = ‘ ‘                -- 这一句是必须的.
select @v_sql = @v_sql + ‘,‘ + name from sysobjects where xtype = ‘P‘
set @v_sql = ‘drop procdure ‘ + right(@v_sql,len(@v_sql)-1)--stuff(@v_sql,1,1,‘‘)替换逗号
print @v_sql
--exec (@v_sql)                        -- 这一句注释打开的话你就会把当前库中所有的存储过程删掉.

第2题:
declare @str varchar(20),@strSql varchar(8000)
set @str = ‘a,bc,d,abce,ddz‘        -- 此处的字符串可以随心所欲的更改
if object_id(‘tempdb.dbo.#temp1‘) is null
        create table #temp1(item varchar(20))
else
        truncate table #temp1
SELECT @strSql=‘insert into #temp1 values(‘‘‘+REPLACE(@str,‘,‘,‘‘‘) 
insert into #temp1 values(‘‘‘)+‘‘‘)‘
print @strSql
exec (@strSql)
select * from #temp1

在使用 row_number() 时候加上 with (no lock)

1.Float 转 varchar

前两天选择一个FLOAT型的字段,要转换为VARCHAR,可是小数点后面的都自动被删去了。。。后查得可以通过如下转换获得:

SELECT CAST(CAST(字段 AS DECIMAL(20,7)) AS VARCHAR(20)) FROM 要查的表
或者

SELECT CONVERT(VARCHAR(20),CONVERT(DECIMAL(20,7),字段)) FROM 要查的表

2.isdate 日起判断函数与nullif 前者等于后者则赋值 为null 连用

isdate(nullif([BadDebtTransferDate],‘‘))=0

SELECT COUNT(*) FROM dbo.[_rawATB]

WHERE

ISDATE(nullif([BadDebtTransferDate],‘‘))=0

AND

BadDebtTransferDate!=0 and BadDebtTransferDate != ‘‘

3.用法新颖的values

select i from  ( values(1),(2),(3),(4),(5),(6)) t(i)

4.获取某月最后一天日期(到底是30 还是31)此算法实际上是前一个月加一个月再减去一天

DECLARE @PostDateID INT

set @PostDateID = (select cast(convert(varchar,

(select DATEADD(mm,-1,PostDate) from dbo.logImportInfo where ID =(select top 1 ImportInfo_ID from dbo.cvtTXNS_CHGS)),112) as int)/100)

PRINT @PostDateID

SELECT DATEADD(DAY,-1,DATEADD(mm,1,CAST(CAST(@PostDateID AS VARCHAR(20) )+‘01‘ AS DATE)))

SELECT CAST(CONVERT(VARCHAR(20),GETDATE(),112) AS DATE)

DECLARE @PostDateID INT

set @PostDateID = (select cast(convert(varchar,

(select DATEADD(mm,-1,PostDate) from dbo.logImportInfo where ID =(select top 1 ImportInfo_ID from dbo.cvtTXNS_CHGS)),112) as int)/100)

PRINT @PostDateID-----

SELECT CAST(CAST(@PostDateID AS VARCHAR(20) )+‘01‘ AS DATE),DATEADD(DAY,-1,DATEADD(mm,1,CAST(CAST(@PostDateID AS VARCHAR(20) )+‘01‘ AS DATE)))

5.运用系统表查询列名,该列数据类型名,允许的长度

SELECT col.name,typ.name,typ.max_length FROM sys.all_columns col JOIN

sys.types  typ ON col.system_type_id=typ.system_type_id

WHERE col.object_id=object_id(‘cvtATB‘) AND col.name LIKE ‘%facility%‘

6.延时,定时技巧

a.延时三秒执行

waitfor delay ‘00:00:03‘

      select * from DimAccount

b.定时到这个时候执行

测试着玩:

alter  proc usp_intervalCall as

waitfor time ‘19:14:01‘

execute usp_ParseXMLFile

usp_intervalCall

7.Goto , Try catch

1.
比方说某库中有N个存储过程:
select name from sysobjects where xtype = ‘P‘;

name                                                                ------------------------------------------------------------------------------------------------------- 
SO_updateorderdetail
HR_ykf05p_calc
GL_uninit_comp_acct_must
……
……
(N row(s) affected)

那幺如何在不用光标不用循环的情况下用T-SQL语句将这个数据库中的所有存储过程删除?

2.
有一个字符串:  a,bc,d,abce,ddz
现在用T-SQL语句把这一字符串变成这种样子:
item       
---------- 
a
bc
d
abce
ddz

(5 row(s) affected)

(如果不用Cursor和循环,那幺有什幺好办法?)

第1题:
declare @v_sql varchar(8000)
set @v_sql = ‘ ‘                -- 这一句是必须的.
select @v_sql = @v_sql + ‘,‘ + name from sysobjects where xtype = ‘P‘
set @v_sql = ‘drop procdure ‘ + right(@v_sql,len(@v_sql)-1)--stuff(@v_sql,1,1,‘‘)替换逗号
print @v_sql
--exec (@v_sql)                        -- 这一句注释打开的话你就会把当前库中所有的存储过程删掉.

第2题:
declare @str varchar(20),@strSql varchar(8000)
set @str = ‘a,bc,d,abce,ddz‘        -- 此处的字符串可以随心所欲的更改
if object_id(‘tempdb.dbo.#temp1‘) is null
        create table #temp1(item varchar(20))
else
        truncate table #temp1
SELECT @strSql=‘insert into #temp1 values(‘‘‘+REPLACE(@str,‘,‘,‘‘‘) 
insert into #temp1 values(‘‘‘)+‘‘‘)‘
print @strSql
exec (@strSql)
select * from #temp1

在使用 row_number() 时候加上 with (no lock)

时间: 2024-12-24 09:49:47

小技巧的相关文章

做预解释题的一点小方法和小技巧

在JavaScript中的函数理解中预解释是一个比较难懂的话题.原理虽然简单,寥寥数言,但其内涵却有深意,精髓难懂.如何在轻松活跃的头脑中将它学会,现在针对我在学习中的一点小窍门给大家分享一下,希望能给大家一些帮助: 万事需遵循"原理"--"预解释"无节操和"this"指向:(可先看例题解析然后结合原理进行学习) (感谢蕾蕾老师给归纳的预解释无节操原理:) 如果函数传参数则先于以下执行,就相当于在函数私有作用域下var了一个变量:根据作用域原理,

给你一个云端的大脑01:印象笔记小技巧

我在上课时,很多学员们给我的反馈都是:老师你讲的太精彩啦,但我记不住.我最重视的就是学员的反馈,因为我是一个完美主义者,凡事既然做就要做到最好.而学员就像我的一面镜子,反馈是我改进的方向. 很久以前,我听到这样的反馈第一反应就是自己还是讲得不够好,但后来我的讲课都能hold住全场300多人的时候,我发现这个反馈仍然频繁出现,这不是我的问题而是学员们不会学习的问题,这样的学员在工作中也是缺乏自我培养的能力. 所以从今天起,我的平台又加入一个主题:给你一个云端的大脑.告诉你如何记笔记,如何整理大脑记

思科命令配置小技巧三:alias 命令

大家都用过手机上的快捷拨号设置 思科设备是否支持命令的快捷键定义呢 答案是肯定的 suzhouxiaoniu(config)#alias exec xx show ip inter bri  xx是自定义的快捷键名称,可以是数字 suzhouxiaoniu#xx 直接敲定义好的名称Interface                  IP-Address      OK? Method Status                ProtocolFastEthernet1/0          

思科命令配置小技巧四:用ACL控制debug 输出

使用debug命令可以帮助我们TS,但是使用debug命令往往会输出一大堆信息,很多是我们不需要用的,也会造成CPU高负荷,这种情况下我们可以限制debug的输出 可以应用ACL到debug以限定仅输出要求的debug信息. 如仅查看从1.1.1.1到1.1.1.2的ICMP包: Router(config)# access-list 100 permit icmp host 1.1.1.1 host 1.1.1.2 Router# debug ip packet detail 100 思科命令

在Axure中使用FontAwesome替换你的网站图标[axure小技巧]

你是不是还在为你的网站做一个很小的图标而忙碌着?你是不是还在为找一个图标导出百度或者谷歌?你有没有想过可以用字体来做一个图标代替普通的图片图标?这两天给公司做案例,由于自己又对设计不熟悉,寻找图标的苦差可不是很好做.同事分享了一个用字体代替图片做网站图标的资源,在此非常感谢!Font Awesome,原只为Bootstrap而设计的字体图标,不过,现在你可以单独用它来为你的网站工作.丢掉图片图标吧,跟我一起来用Font Awesome. 使用方法: 1. 下载 Font Awesome 官方网站

Fiddler小技巧-测试上传文件接口&多参数并传情况

写了多年的API了,fidder还真是方便至极相对于postman来说. 两种常用方式: 抓包:app通过代理方式,就可以在pc端看到fidder的请求了 因为会监控好多跟我们需要的没关系的HTTP请求, 就要开启过滤了 主动调试API&上传文件参数&其它参数 拷贝点击"upload file"上传之后自动生成的body然后修改: ---------------------------acebdf13572468 Content-Disposition: form-da

移动端样式小技巧

平时在移动端开发拼页面的过程中总会遇到一些问题,主要是各手机webview样式显示效果不一致造成的.以下总结了一些常见坑和一些小技巧,希望对看官有所帮助! 本文只针对两大手机阵营 Android和IOS 中的魅蓝metal 和 iPhone6进行样式对比. 一.line-height line-height经常用于文字居中,当然也有小伙伴会用上下padding去写.but!不管你用padding还是line-height,不同手机显示效果还是-不一样. 一般会这样写 .demo{ height:

Windows Phone开发(8):关于导航的小技巧

前文用几个例子对导航做了简单介绍,在一般应用中,使用上一篇文章中说到的方法,其实也够用了,不过,为了能够处理一些特殊的情况,有几个小技巧还是有必要了解一下的. 一.到底该不该设置"后退"操作?因为手机的硬件层就有一个"回退"按钮,按理说我们不需要在程序中再添加什么回退按钮之类的,不过,还是有必要看看如何手动加入回退功能. 1.新建一个WP应用项目.2.除默认的主页外,新建一个页面Page2.xaml.3.在主页上放一个按钮,编写Click事件处理代码,导航到Page

不为人知的python request小技巧

关于 Python requests ,在使用中,总结了一些小技巧把,记录下. 1:保持请求之间的Cookies,我们可以这样做. 2:请求时,会加上headers,一般我们会写成这样 唯一不便的是之后的代码每次都需要这么写,代码显得臃肿,所以我们可以这样: 3:默认requests请求失败后不会重试,但是我们跑case时难免遇到一些网络或外部原因导致case失败,我们可以在Session实例上附加HTTPAdapaters 参数,增加失败重试次数. 这样,之后的请求,若失败,重试3次. 4:重

Playground 你不知道的小技巧, CoreData 的使用

Playground 的出现无疑是大大的提高了开发效率,可以节省大量的编译时间. 这里介绍在 Playground 中使用 CoreData 的小技巧. 我们新建一个工程 iOS 项目工程. 点击 File -> New -> File , 在工程中新建文件 Data Model 文件  在 model 中添加一个 Entitle,如下图  编译工程后,在 Product 选择生成的 .app 文件,找到该目录,如下图  查看包中的文件,如图  可以看到一个 Mode.momd 文件, 如图