(1) try catch 配合 Transactions 使用

--打开try catch功能
set xact_abort on
begin try
begin tran
insert into tableName(ID) values(1)
commit tran
print 'commited'
end try
begin catch
rollback
print 'rolled back'
end catch

(2)获取当前月前一个月有多少天(DatePart( date ,  datetime)  DateAdd(date , 数字 ,datetime) Cast(exp  as  datetime))

select DatePart
(day,DateAdd(DAY,-1,
Cast(cast(YEAR(getdate()) as nvarchar)+'-'+
cast(month(getdate()) as nvarchar)+'-01' as datetime))
)

(3)取到小数第二位四舍五入(类型转换)

Select Convert(Numeric(20,2), IsNull(50.01634,0))

结果:50.02

(4)获取时间

[1]一个月第一天:select DateAdd(mm,DateDiff(mm,0,getdate()),0)

--DateAdd当添加的值和初试值均为0时,返回的时间为1900-01-01 00:00:000

select DATEADD(mm,0,0);

[2]本年:year(getdate())

[3]本月:month(getdate())

[4]本日:Day(getDate())

[5]昨天的记录:datediff(day,[Datetime],getdate())=1  把Datetime换为你的相应字段,getdate()-Datetime即为时间差。

[6]本月/周/日记录:DateDiff(month/week/day,[dateadd],getdate())=0

[7]本周的星期一:Select  DateAdd(wk, DateDiff(wk,0,getdate()),  0)

[8]季度的第一天:Select  DateAdd(qq,  DateDiff(qq,0,getdate()),  0)

[9]当天的凌晨(半夜):Select  DateAdd(dd,  DateDiff(dd,0,getdate()),  0)

[10]本年的第一天::select  DateAdd(YY,DateDiff(yy,0,getdate()),0)

[11]去年的最后一天(今年的第一天减去3毫秒):select DateAdd(ms,-3,DateAdd( yy,  DateDiff( yy, 0, getdate()),  0))

[12]本月的第一天:select DateAdd( mm, DateDiff( mm, 0 , GetDate()), 0);

[13]本月的最后一天:select DateAdd(ms,-3, DateAdd(mm, DateDiff(mm,0,getdate()), 0))

[14]本年的最后一天:Select  DateAdd(ms,-3, DateAdd(yy,  DateDiff(yy, 0, getdate()) +1,  0))

[15]本月的第一个星期一:select  DateAdd(wk, DateDiff(wk,0, DateAdd(dd,6 - Datepart(day,getdate()) ,getdate()) ),  0)

[16]显示星期几:select DateName(weekday , getdate() );

[17]显示本月的天数:select DateDiff(dd , getdate() , DateAdd(mm , 1 , getdate()) );

[18]显示某年某月有多少天

create   Function DaysInMonth1(@datetime datetime)
returns int
as
begin
return Day( Datepart( dd, DateAdd( ms, -3, DateAdd(mm ,DateDiff(mm,0,@datetime)+1 , 0) ) ))
end
调用select dbo.DaysInMonth1('2012-2-13');

(5)获取当前数据库中所有用户的表

select * from sysobjects where xtype='U' 

(6)随机取出3条数据

Select  top 3 *  from Table  order by NewId()

(7)查找表中多余的重复记录

Select  *  from Table where ID  in( select SID from Table  group by ID having Count(Name)>1)

(8)关键字waitfor 主要有waitfor delay(推迟执行),waitfor time (特定时间执行)

waitfor delay '00:00:08'

print('Hello ,Im waitfrom delay')

waitfor time '20:49:50'

print('Hello,Im waitfor time')

(9)检测数据是否存在

[1]检测数据库是否存在

if( Exists(select * from sys.databases where name='School'))

select * from Student

go

[2]检测数据表是否存在

if( exists(select * from sys.objects where name='Student'))

select * from Student order by SID desc

go

[3]检测数据列是否存在

if(exists(select * from sys.all_columns where object_id=object_id('Student') and name='Sname'))

select * from Student

go

(10)表连接

--同时无条件的查询两个不相关的表,所得新表字段为两表字段之和,信息条数为两个信息条数的乘积 (即为:两表的笛卡尔积)

select  T.* , Student.*  from  T , Student

--交叉连接即为上边所讲的那种连接

select T.*,Student.* from T Cross Join Student

--随机数均可以产生0-1之间的随机数

Select   Rand();    select Rand( CheckSum(NewId()) )

--随机数0-9

select ABS(Rand());   select ABS(CheckSum(NewId()))%10

--随机数a-b之间

select a+ABS(checksum(newid()))%(b-a+1)

select 1+ABS(checksum(newid()))%100

字符串操作

--SubString字符串截取(str ,StartIndex , Length)

select SubString( 'Olive116', 1, 5)

--left/right从左边截取字符串

select Left/Right ( 'Olive', 3 )

--字符串替换Replace( str, str1, str2)

select Replace('OOLive','o','1')

--反转排序

select Reverse('Olive')

--删除指定的长度并在指定的起点处插入另一组字符

select Stuff('OliveOOO',6,3,'Hello')

--以指定的次数重复字符串的值

select Replicate('Olive',3)

--返回表达式中第一次出现的位置

select PatIndex('%Olive%','Hello!Olive')

--返回字符串中指定表达式的开始位置

select CharIndex('O','Hello,Olive')

--返回输入表达式的第一个字符的整数值

select UniCode('o')

--返回由数字数据转换来的字符数据

select STR(123.1314,4),LEN(STR(123.3212,321))

select STR(123.1334,4,4)

--发音匹配度

select Sname,SOUNDEX(Sname) from Student

--Difference()简化两个字符串发音相似度,返回0-4之间的值来反应两个字符的相似度,值越大就越相似

select Sname,SOUNDEX(Sname), Difference (Sname,'Olive') from Student

--查询重复记录

select * from Table where SID in (select SID from Table group by SID having COUNT(SID)>0)

--删除重复的记录(并保留SID最小的记录)

delete from Table where

SID in (select SID  from Table group by SID having COUNT(SID)>0)

and SID not in(select MIN(SID) from Student group by SID having count(SID)>0)

--双引号

select '''''' as result

--isnumeric()判断是否是数字是为1否为0

select IsNumeric('a')

--isdate()判断是否为日期是为1否为0

select IsDate('2012-3-2')

DataBase 之 常用操作的更多相关文章

  1. mysql常用操作语句

    mysql常用操作语句 1.mysql -u root -p   2.mysql -h localhost -u root -p database_name 2.列出数据库: 1.show datab ...

  2. Oracle常用操作——创建表空间、临时表空间、创建表分区、创建索引、锁表处理

    摘要:Oracle数据库的库表常用操作:创建与添加表空间.临时表空间.创建表分区.创建索引.锁表处理 1.表空间 ■  详细查看表空间使用状况,包括总大小,使用空间,使用率,剩余空间 --详细查看表空 ...

  3. DBA必备:MySQL数据库常用操作和技巧

    DBA必备:MySQL数据库常用操作和技巧 2011-02-25 15:31 kaduo it168 字号:T | T MySQL数据库可以说是DBA们最常见和常用的数据库之一,为了方便大家使用,老M ...

  4. [转]Mysql命令行常用操作

    Mysql命令行常用操作 一.从命令行登录MySQL数据库服务器 1.登录使用默认3306端口的MySQL /usr/local/mysql/bin/mysql -u root -p 2.通过TCP连 ...

  5. MySQL常用操作总结

    MySQL常用操作 前提条件:已安装MySQL. 学习目标:用一条sql语句写出A和B的剩余数量 AA表 BB表 以上为一道面试题,接下来由这道面试题来回顾一些数据库的基本操作. 登录MySQL su ...

  6. mongodb的常用操作

    对于nosql之前工作中有用到bekerlydb,最近开始了解mongodb,先简单写下mongodb的一些常用操作,当是个总结: 1.mongodb使用数据库(database)和集合(collec ...

  7. Linux常用操作练习

    Linux常用操作练习 练习一:安装CentOS 1.设置为1G内存(才有图形界面).10G硬盘 2.分给交换分区2G(4G一下2G,8G-32G分4G-8G) 练习二:安装CentOS迷你版 1.安 ...

  8. MongoDB副本集的常用操作及原理

    本文是对MongoDB副本集常用操作的一个汇总,同时也穿插着介绍了操作背后的原理及注意点. 结合之前的文章:MongoDB副本集的搭建,大家可以在较短的时间内熟悉MongoDB的搭建和管理. 下面的操 ...

  9. Linux下mysql的常用操作

    Linux下mysql的常用操作: 显示数据库 show databases; 选择数据库 use 数据库名; 显示数据库中的表 show tables; 显示数据表的结构 describe 表名; ...

随机推荐

  1. JS数组(Array)操作汇总

    1.去掉重复的数组元素.2.获取一个数组中的重复项.3.求一个字符串的字节长度,一个英文字符占用一个字节,一个中文字符占用两个字节.4.判断一个字符串中出现次数最多的字符,统计这个次数.5.数组排序. ...

  2. 利用Javascript获取当前日期的农历日期

    来源:http://www.ido321.com/926.html JavaScript代码 1: /*设置农历日期*/ 2: var CalendarData=new Array(100); 3: ...

  3. mybatis系列-13-resultMap总结

    resultType: 作用: 将查询结果按照sql列名pojo属性名一致性映射到pojo中. 场合: 常见一些明细记录的展示,比如用户购买商品明细,将关联查询信息全部展示在页面时,此时可直接使用re ...

  4. mybatis系列-07-输出映射

    7.1     resultType 使用resultType进行输出映射,只有查询出来的列名和pojo中的属性名一致,该列才可以映射成功. 如果查询出来的列名和pojo中的属性名全部不一致,没有创建 ...

  5. 关于登录的会话控制, 终极解决方案 - chunyu

    登录是用cookie还是session实现,一直有争议,普遍认为session更安全,可是有些功能,用cookie最方便也最高效,比如“记住我一周”.   cookie还是session,我的答案是两 ...

  6. 怎么在 html 中 动态的加载一个 script

    var script = document.createElement( 'script' );script.type = 'text/javascript';script.src = bodyStr ...

  7. HDU 4884 TIANKENG’s rice shop (模拟)

    TIANKENG's rice shop 题目链接: http://acm.hust.edu.cn/vjudge/contest/123316#problem/J Description TIANKE ...

  8. 在JS和.NET中使用JSON (以及使用Linq to JSON定制JSON数据)

    转载原地址: http://www.cnblogs.com/mcgrady/archive/2013/06/08/3127781.html 阅读目录 JSON的两种结构 认识JSON字符串 在JS中如 ...

  9. CodeForces 707A Brain's Photos (水题)

    题意:给一张照片的像素,让你来确定是黑白的还是彩色的. 析:很简单么,如果有一种颜色不是黑白灰,那么就一定是彩色的. 代码如下: #pragma comment(linker, "/STAC ...

  10. 框架学习笔记:深度解析StrangeIoC内部运行机制

    StrangeIoC的设计和RobotLegs一致,所以我的解析会对照RobotLegs来看. 整个框架使用的是MVCS的模式,关于MVCS模式大家可以点这里进行查看,这里就不谈了,既然Strange ...