-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSQLQuery1 (3).sql
More file actions
122 lines (102 loc) · 2.52 KB
/
SQLQuery1 (3).sql
File metadata and controls
122 lines (102 loc) · 2.52 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
CREATE FUNCTION udf_DiffWeek (@StartDate DATETIME, @EndDate DATETIME)
RETURNS INT
AS
BEGIN
DECLARE @projectWeeks INT;
IF(@EndDate IS NULL)
BEGIN
SET @EndDate = GETDATE()
END
SET @projectWeeks = DATEDIFF(WEEK, @StartDate, @EndDate)
RETURN @projectWeeks;
END
go
CREATE FUNCTION ufn_GetSalaryLevel(@salary INT)
RETURNS NVARCHAR(10)
AS
BEGIN
DECLARE @salaryLevel VARCHAR(10)
IF (@salary < 30000)
SET @salaryLevel = 'Low'
ELSE IF(@salary >= 30000 AND @salary <= 50000)
SET @salaryLevel = 'Average'
ELSE
SET @salaryLevel = 'High'
RETURN @salaryLevel
END;
go
CREATE PROC dbo.usp_SelectEmployeesBySeniority
AS
SELECT *
FROM Employees
WHERE DATEDIFF(Year, HireDate, GETDATE()) > 5
GO
EXEC usp_SelectEmployeesBySeniority
drop proc dbo.usp_SelectEmployeesBySeniority
go
CREATE PROC usp_SelectEmployeesBySeniority(@minYearsAtWork int = 5)
AS
SELECT FirstName, LastName, HireDate,
DATEDIFF(Year, HireDate, GETDATE()) as Years
FROM Employees
WHERE DATEDIFF(Year, HireDate, GETDATE()) > @minYearsAtWork
ORDER BY HireDate
GO
EXEC usp_SelectEmployeesBySeniority 10
go
EXEC usp_SelectEmployeesBySeniority
go
CREATE PROCEDURE sp_AssignProject (@EmployeeID INT, @ProjectID INT)
AS
BEGIN
DECLARE @maxEmployeeProjectsCount INT = 3
DECLARE @employeeProjectsCount INT
SET @employeeProjectsCount = (SELECT COUNT(*)
FROM [dbo].[EmployeesProjects] AS ep
WHERE ep.EmployeeId = @EmployeeID)
BEGIN TRAN
INSERT INTO [dbo].[EmployeesProjects] (EmployeeID, ProjectID)VALUES (@EmployeeID, @ProjectID)
IF(@employeeProjectsCount >= @maxEmployeeProjectsCount)
BEGIN
RAISERROR('The employee has too many projects!', 16, 1)
ROLLBACK
END
ELSE
COMMIT
END
exec sp_AssignProject 15, 15
select count(1) from EmployeesProjects where EmployeeID=62
go
CREATE TRIGGER tr_TownsInsert ON Towns FOR Insert
AS
IF (EXISTS(
SELECT * FROM inserted
WHERE Name IS NULL OR LEN(Name) = 0))
BEGIN
RAISERROR('Town name cannot be empty.', 16, 1)
ROLLBACK
RETURN
END
go
drop trigger tr_TownsUpdate
UPDATE Towns SET Name='' WHERE TownId=1
insert into Towns
values ('abcd'), ('');
go
CREATE TRIGGER tr_TownsInsertBad ON Towns FOR Insert
AS
IF (EXISTS(
SELECT * FROM inserted
WHERE Name IS NULL OR LEN(Name) = 0 or Name LIKE 'Hell%'))
BEGIN
RAISERROR('Town name cannot be empty.', 16, 1)
ROLLBACK
RETURN
END
go
drop trigger tr_TownsInsertBad
insert into Towns
values ('abcd'), ('Hella'), ('hahaha'), ('abcdef');
delete from Towns
where TownID %2=0
select * from inserted