常用的数据库sql工作记录

在sql server 中 定义一个值 

declare @pur_type varchar(10)='OrderDetail';

between and 日期类 的话   A  between  ‘q年w月e日’ and  ‘a年s月d日’  则从q年w月e日 00:00:00 到 a年s月d日 23:59:59

查看触发器

select * from sysobjects where xtype='TR'

查看触发器内容

exec sp_helptext tr_rm_vip_cls_discount_delete

With (NoLock) 处理数据库死锁的异常时候使用NOLOCK 或者READPAST

它们区别:NOLOCK 可能把没有提交事务的数据也显示出来

READPAST会把锁住的行不显示出来

使用 案例  SELECT  字段名 FROM 表名 WITH (NOLOCK) 

 CASE WHEN THEN

(case pay_flag when 1 then '冻结' when 1 then '正常'  else '正常' end ) as pay_flag

NULLIF、NULL、ISNULL、COALESCE、IIF

BULLIF(除数为0的sql判断):

NULLIF(Expression1,Expression2):给定两个参数Expression1和Expression2,如果两个参数相等,则返回NULL;否则就返回第一个参数。等价于:Case WHEN Expression1=Expression2 Then NULL ELSE Expression1。
例如Select NULLIF(1,1)返回NULL,Select NULLIF(1,2)返回1。
有一个实际的应用,例如防止除0操作的放生,可以使用a/NULLIF(b,0),这样就不怕b是0了,当然除0操作也可以通过别的方式判断。

NULL: 是个神奇的东西,表示空值,未知值,任何数与它加减乘除都返回NULL。

ISNULL: ISNULL(Expression1,Expression2):给定两个参数Expression1和Expression2,如果Expression1是NULL,那么返回Expression2,否则返回Expression1。 等价于:Case WHEN Expression1 is NULL Then Expression2 ELSE Expression1。  例如Select ISNULL(NULL,1)返回1,Select ISNULL(1,2)返回1。   

有一个实际的应用,可以对空值进行默认值替代,例如SELECT ISNULL(email,'没有填写email') from table1,所有email为null的,用'没有填写email'来替代。

COALESCE:

COALESCE(Expression1,Expression2,Expression3,......):接受一系列的表达式或列,返回第一个非空的值。 例如SELECT COALESCE(NULL,NULL,4,NULL,NULL,5),那么返回,如果里面的参数都为NULL,那么会报错。

 

事务:BEGIN TRANSACTION   sql逻辑   END TRANSACTION 

修改表字段类型长度  alter table t_pm_sheet_detail alter column memo varchar(200)
GO 

更新表字段信息

if exists(SELECT sys_var_value FROM t_sys_system  WHERE sys_var_id ='MoneyMask' and sys_var_value not like '%0%')
    update t_sys_system set sys_var_value='#,###,###,##0.00'  WHERE sys_var_id ='MoneyMask'
   GO

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值