-- 查询区分大小写: 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 Create、Alter 和 Drop 语句,以及执行类似 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