SQL SERVER 日志记录

-- 查询区分大小写: WHERE COLLATE Chinese_PRC_CS_AI

-- 建立索引
CREATE INDEX IDX_DRP_HN_RLB_1
    ON DRP_HN_RLB (SHOP_CODE, FSCL_DATE)

CREATE INDEX IDX_DRP_HN_RLB_2
    ON DRP_HN_RLB (SHOP_CODE, V5_ORDER_NUM)

CREATE INDEX IDX_DRP_HN_RLB_DTL_1
    ON DRP_HN_RLB_DTL (V5_ORDER_NUM, PROD_CODE)

CREATE INDEX IDX_DRP_HN_RLB_PAY_1
    ON DRP_HN_RLB_PAY (V5_ORDER_NUM)
    
    
-- 删除主键约束
    ALTER TABLE DRP_HN_RLB DROP CONSTRAINT DRP_HNN_RLB
-- 增加主键约束 
ALTER TABLE DRP_HN_RLB ADD CONSTRAINT PK_DRP_HN_RLB PRIMARY KEY(SHOP_CODE,V5_ORDER_NUM)
-- 增加字段
ALTER TABLE DRP_HN_RLB_DTL ADD SHOP_CODE VARCHAR(25)
ALTER TABLE DRP_HN_RLB_PAY ADD SHOP_CODE VARCHAR(25)

-- ALTER TABLE DRP_HN_RLB_DTL ADD CONSTRAINT PK_DRP_HN_RLB_DTL PRIMARY KEY(SHOP_CODE,V5_ORDER_NUM)
-- ALTER TABLE DRP_HN_RLB_PAY ADD CONSTRAINT PK_DRP_HN_RLB_PAY PRIMARY KEY(SHOP_CODE,V5_ORDER_NUM)    

-- 增加字段指定值约束
ALTER TABLE DRP_HN_RLB WITH CHECK ADD CONSTRAINT [CKC_RLB_HANDLED] CHECK (([HANDLED]=F OR [HANDLED]=T))
ALTER TABLE DRP_HN_RLB CHECK CONSTRAINT [CKC_RLB_HANDLED]

ALTER TABLE DRP_HN_RLB_DTL WITH CHECK ADD CONSTRAINT [CKC_RLB_DTL_HANDLED] CHECK (([HANDLED]=F OR [HANDLED]=T))
ALTER TABLE DRP_HN_RLB_DTL CHECK CONSTRAINT [CKC_RLB_DTL_HANDLED]

ALTER TABLE DRP_HN_RLB_PAY WITH CHECK ADD CONSTRAINT [CKC_RLB_PAY_HANDLED] CHECK (([HANDLED]=F OR [HANDLED]=T))
ALTER TABLE DRP_HN_RLB_PAY CHECK CONSTRAINT [CKC_RLB_PAY_HANDLED]

-----------------------

alter table SCM_UNIT_GRID alter column ROW_BG VARCHAR(1000); 
DROP INDEX IDX_MTU_2 ON MTU;

CREATE INDEX IDX_MTU_2 ON dbo.MTU (DELIV_UNIT_ID, DELIV_WAREH_ID);

alter table mtu alter column deliv_wareh_id numeric(6) NOT NULL;


-------------------- for xml path -----------------------

SELECT b.code_type,ccc FROM 
( SELECT code_type,
                  ( SELECT description+ |  FROM SYS_CODE_DTL  WHERE CODE_TYPE = a.code_type FOR XML path(‘‘)
                  ) AS ccc 
  FROM SYS_CODE_DTL A 
  GROUP BY code_type 
) B 

-------------END-----------

---- 查询结果排序 ---------

SELECT 昨日 AS S_DD,昨至今前十门店:  AS S_NAME,convert(VARCHAR(10),rn)+. + shop_name AS V_SHOP,qty AS S_NUM,val AS S_VAL,DISC as DISC 
 FROM (

       SELECT row_number() OVER(ORDER BY val DESC) rn,c.*  -- 按金额降序
        FROM (
               SELECT shop_name,sum(qty) qty,sum(val) val,avg(DISC_rate) DISC FROM dao_au_sale
                WHERE convert(varchar(10),doc_date,120) >= convert(VARCHAR(10),getdate()-1,120)
                GROUP BY shop_name
         
             ) c
      ) c WHERE rn <= 11 -- 展现前 11 行
-------------------END-----------------------------

------------- 数值转字符 | 时段|环比|同比 -------------- BETWEEN :FROM_DATE AND :TO_DATE [时段参数]

SELECT 时段 AS S_DD,日期选择:  AS S_NAME,
       SALE 其中 V:    + (SELECT convert(VARCHAR(50),cast(sum(qty) as int)) +  / +convert(VARCHAR(50),sum(val)) -- 数值转字符
                              FROM dao_au_sale 
                             WHERE doc_date BETWEEN :FROM_DATE AND :TO_DATE
                               AND prsnl_code IS NOT NULL
                           ) AS V_SHOP, 
       sum(qty) AS S_NUM,sum(val) AS S_VAL,avg(DISC_rate) DISC FROM dao_au_sale WHERE doc_date BETWEEN :FROM_DATE AND :TO_DATE
       
       
UNION ALL 

SELECT 环比 AS S_DD,日期选择:  AS S_NAME,
       SALE 其中 V:    + (SELECT convert(VARCHAR(50),cast(sum(qty) as int)) +  / +convert(VARCHAR(50),sum(val)) 
                              FROM dao_au_sale 
                             WHERE doc_date BETWEEN DateAdd(month, -1, :FROM_DATE) AND DateAdd(month, -1, :TO_DATE)    --- 环比【上月同一时段】
                               AND prsnl_code IS NOT NULL
                           ) AS V_SHOP, 
        sum(qty) AS S_NUM,sum(val) AS S_VAL,avg(DISC_rate) DISC FROM dao_au_sale WHERE doc_date BETWEEN DateAdd(month, -1, :FROM_DATE) AND DateAdd(month, -1, :TO_DATE)
        
UNION ALL 

SELECT 同比 AS S_DD,日期选择:  AS S_NAME,
       SALE 其中 V:    + (SELECT convert(VARCHAR(50),cast(sum(qty) as int)) +  / +convert(VARCHAR(50),sum(val)) 
                              FROM dao_au_sale 
                             WHERE doc_date BETWEEN DateAdd(year, -1, :FROM_DATE) AND DateAdd(year, -1, :TO_DATE)       --- 同比 【上年同一时段】
                               AND prsnl_code IS NOT NULL
                           ) AS V_SHOP, 
       sum(qty) AS S_NUM,sum(val) AS S_VAL,avg(DISC_rate) DISC FROM dao_au_sale WHERE doc_date BETWEEN DateAdd(year, -1, :FROM_DATE) AND DateAdd(year, -1, :TO_DATE)
             
----------------------- END --------------------------------------------------********************

是数字 NOT LIKE %[^0-9]%
是字母 NOT LIKE %[^A-Za-z]%


-- < 日期 >

-- getdate() 获得当前日期函数

SELECT getdate()


-- dateadd() 指定增加日期函数
-- 在指定的日期值上增加指定的日期值 ( mm 月 ,yy 年 ,dd 日 )

select dateadd(mm,3,getdate()) 
select dateadd(dd,40,getdate())
select dateadd(mm,-3,getdate())

-- datediff(,,)差异日期函数 | 获得两个指定日期之间的差异值

select Age, Classid,datediff(yyyy,Birthday,getdate()) from Teacher 

-- 查询年龄在15-20岁之间的女生信息

 select * from Teacher where datediff(yyyy,Birthday,getdate()) between 15 and 20 and Gender = False
 select datediff(ss,1999-9-9,getdate())
 
-- dateName()返回日期中部分字符串函数 | 得到日期的字符串部分

select Datename(weekday,getdate())
select Datename(month,getdate())

-- datepart()返回日期中指定日期部分的整数形式函数 | 日期中指定日期部分的整数形式

select DatePart(day,getdate())
select datepart(day,2018-10-16)


今天的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())=0

昨天的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())=1

7天内的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())<=7

30天内的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())<=30

本月的所有数据:select * from 表名 where DateDiff(mm,datetime类型字段,getdate())=0

本年的所有数据:select * from 表名 where DateDiff(yy,datetime类型字段,getdate())=0

 

查询今天是今年的第几天: select datepart(dayofyear,getDate())

查询今天是本月的第几天:1. select datepart(dd, getDate()) 

                        2.select day(getDate())

查询本周的星期一日期是多少 (注意:指定日期不能是周日,如果是周日会计算到下周一去。所以如果是周日要减一天) SELECT DATEADD(wk,DATEDIFF(wk,0,getdate()),0)

 

查询昨天日期:select convert(char,dateadd(DD,-1,getdate()),111//111是样式号,(100-114)

 

查询本月第一天日期:Select DATEADD(mm, DATEDIFF(mm,0,getdate()), 0) as firstday

查询本月最后一天日期:Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0)) as lastday      //修改-3的值会有相应的变化

 

本月有多少天:select datepart(dd,dateadd(dd,-1,dateadd(mm,1,cast((cast(year(getdate()) as varchar)+-+cast(month(getdate()) as varchar)+-01 ) as datetime ))))

 

求两个时间段相差几天:select datediff(day,2012/8/1,2012/8/20) as daysum

在指定的日期上±N天:select convert(char,dateadd(dd,1,2012/8/20),111) as riqi    //输出2012/8/21

在指定的日期上±N分钟:select dateadd(mi,-15,getdate())  //查询当前时间15分钟之前的日期
--------------------- 

-- **************************************************************************************** --




-- 输出转换 cast() | convert()

PRINT 1+1

PRINT 56/8

PRINT 我的成绩是: + cast(100 as char(13))  + into 

print 我的生日是:+1999-9-9
print我的生日是:+convert(char(20),1999-9-9,100)

print我的生日是:+convert(char(20),getdate(),100) --100 日期显示的格式不同
print我的生日是:+convert(char(20),getdate(),101)
print我的生日是:+convert(char(20),getdate(),102)
print我的生日是:+convert(char(20),getdate(),103)


-- 字符串函数 charindex() | len() | upper() / lower() 大小写转换 | ltrim() / rtrim() 左右去空格 |

select charindex(am,I am a boy,0)
select charindex(am,I am a boy,3)
select charindex(am,I am a boy,5)
select charindex(atm,I am a boy)

select len(I am a boy)


-- right()

select right (I am a boy ,3)

-- substring()

select substring (I trust you will say I am a boy,charindex(am,Trust me ,I am really a boy!),2)

-- replace()

select REPLACE(I am a smart boy , smart, clever)    

-- stuff() 在一个字符串中,从指定位置删除指定长度的字符,并在该位置插入一个新的字符 ,从1开始。参数1:字符串 参数2:指定位置,参数3:删除指定长度,参数4:插入的新字符串

select stuff(I am a clever boy,8,6,elegant)

-- 声明变量

DECLARE @age INT

-- 变量赋值

SET @age = 26

-- while 循环

DECLARE @i int 
SET @i= 1 
WHILE @i <= 10
    BEGIN 
       @i= @i + 1 
       PRINT @i
    END 

declare @x int
set @x = 1
while(@i <= 3)  
begin
set @x = @x + 1
print @x
end

-- if else 

    if @i>10
        begin
            print 大于10
        end
    else if @i>5
        begin
            print 大于5
        end
    else
        begin
            print 小于等于5
        END
        
-- 系统变量

    @@version: 返回  SQL Server的当前安装的系统和生成信息。
    @@error: 上一条sql语句出错,会有错误号;上一条sql执行没出错,则为0。
    @@lanuage: 返回当前所用语言的名称。

    @@max_connections:  返回 SQL Server实例允许同时进行的最大用户连接数。(实际允许的用户连接数还依赖于所安装的  SQL Server的版本以及应用程序和硬件的限制)
    @@Rowcount: 上一条sql语句影响的行数。
    @@servername: 返回正在运行  SQL Server的本地服务器的名称。

    @@connections: 此函数返回  SQL Server自上次启动以来尝试的连接数,无论连接是成功还是失败。

-- 事务

    一个事务中,不能一个sql语句执行成功,一个执行失败。只要有一个sql语句执行失败,就是失败。

    自动提高事务:当执行一条sql语句,数据库自动打开一个事务,执行成功->自动提交,执行失败->自动回滚。

    隐式事务:当执行一条sql语句,数据库自动打开一个事务,需要手动提交,手动回滚。(打开隐式事务:set implicit_Transactions ON)

    显式事务:需要手动打开事务,手动提交,手动回滚。

    打开一个事务:
    
    begin transaction
        declare @sum int=0
        update tableA set Name=大胡子 where id=2
        set @sum=@sum+@@error
        update tableB set Name=大胡子 where id=2
        set @sum=@sum+@@error
        if @sum<>0
            begin
                rollback --回滚,也可写rollback transaction
            end
        else
            begin
                commit  --提交,也可写commit transaction
            END
            
-- 游标 cursor

    declare Mycursor cursor for
        select UserName,Age,Email from tbUsers
        
        open Mycursor
        declare @uName varchar(50)
        declare @uAge int
        declare @uEmail varchar(50)
        fetch next from Mycursor into @uName,@uAge,@uEmail
        if (@@fetch_status=0)
        begin
            print @uName
            print @uAge
            print @uEmail
        end
    close Mycursor
    

-- 触发器 trigger

  触发器是数据库服务器中发生事件时自动执行的一种特殊存储过程。

  DML触发器:如果用户要通过数据操作语言 (DML) 事件编辑数据,则执行 DML 触发器。

        表或视图的 insert, delete, update语句(不支持select)。

  DDL触发器:DDL 触发器用于响应各种数据定义语言 (DDL) 事件。

        这些事件主要对应于  Transact-SQL CreateAlterDrop 语句,以及执行类似 DDL 操作的某些系统存储过程。

  登录触发器: 登录触发器在遇到 Login 事件时触发,该事件是在建立用户会话时引发的。

  创建触发器:
  
     create trigger trg_In ON tbUsers
      after delete
      as
        begin
            insert into tbUsers_backup(Name,Age,Email) select Name,Age,Email from deleted
        end 
    
-- ******************************************************** --

-- 获取本周周一

SELECT DATEADD(Day,(@i+1)-(DATEPART(Weekday,getdate())+@@DATEFIRST-1)%7,getdate()) 


---- datediff()

datepart    缩写
年    yy, yyyy
季度    qq, q
月    mm, m
年中的日    dy, y
日    dd, d
周    wk, ww
星期    dw, w
小时    hh
分钟    mi, n
秒    ss, s
毫秒    ms
微妙    mcs
纳秒    ns

-----------------

全局变量使用@@来表示,一般都是系统预定义的一些全局变量。常用的全局变量有

@@ERROR            最后一个SQL错误的错误号

@@IDENTITY         最后一次插入的标识值

@@LANGUAGE         当前使用的语言的名称

@@MAX_CONNECTIONS  可以创建的同时连接的最大数目

@@ROWCOUNT         受上一个SQL语句影响的行数

@@SERVERNAME       本地服务器的名称

@@TRANSCOUNT       当前连接打开的事物数

@@VERSION          SQL Server的版本信息

----------------------

PRINT @@VERSION

SELECT @@TRANCOUNT
SELECT @@ERROR 


------- SQL 透视用法 ------


SELECT <非透视的列>,
    [第一个透视的列] AS <列名称>,
    [第二个透视的列] AS <列名称>,
    ...
    [最后一个透视的列] AS <列名称>,
FROM
    TABLE_NAME
PIVOT
(
    <聚合函数>(<要聚合的列>)
FOR
[<包含要成为列标题的值的列>]
    IN ([第一个透视的列], [第二个透视的列],
    ... [最后一个透视的列])
) AS <透视表的别名>
<可选的 ORDER BY 子句>


-- 例:

SELECT [2020春],[2020夏]
  FROM (SELECT season,sum(qty) AS qty FROM dao_au_sale WHERE datediff(dd,DOC_DATE,getdate()) = 1 GROUP BY season) a
  PIVOT 
  (sum(qty) FOR season IN ([2020春],[2020夏])) pt 


 
 
 

 

SQL SERVER 日志记录

上一篇:MongoDB DBA常用的NoSQL语句


下一篇:Python操作数据库读书笔记