-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTSQLHacks.sql
110 lines (78 loc) · 2.96 KB
/
TSQLHacks.sql
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
/*
Tips for use:
1. These comments /* */ start a new section
2. These comments -- explain the steps and process
3. Feel free to use!
*/
USE [DATABASE]
GO
/* This example keeps the most recent value (by date) and removes any extra rows
To use this example on your own table, you could replace the A, B and #remove values with your own.
At the end of this example is a live example of this in action related to grades and dates. */
-- Creates a temp table
CREATE TABLE #remove (A INT, B INT, Date DATETIME)
-- Insert values into the temp table
INSERT INTO #remove VALUES(1,1,getdate())
INSERT INTO #remove VALUES(1,1,DATEADD(DD,-2,getdate()))
INSERT INTO #remove VALUES(1,1,DATEADD(DD,-5,getdate()))
INSERT INTO #remove VALUES(1,2,DATEADD(DD,-10,getdate()))
INSERT INTO #remove VALUES(1,2,DATEADD(DD,-15,getdate()))
INSERT INTO #remove VALUES(3,1,getdate())
SELECT A
, B
, Date
, ROW_NUMBER() OVER (PARTITION BY A, B ORDER BY Date DESC) AS CTable
FROM #remove
SELECT A
, B
, Date
, ROW_NUMBER() OVER (PARTITION BY A, B ORDER BY Date DESC) AS CTable
FROM #remove
WHERE A = 1 AND B = 1
WITH CTE AS (
SELECT A
, B
, Date
, ROW_NUMBER() OVER (PARTITION BY A, B ORDER BY Date DESC) AS CTable
FROM #remove
WHERE A = 1 AND B = 1)
DELETE CTE WHERE CTable > 1
-- Clean up
DROP TABLE #remove
-- Live example keeping only the most recent grade by date
WITH CTE AS (
SELECT Grade
, DateAdded
, ROW_NUMBER() OVER (PARTITION BY Phone, DateAdded ORDER BY DateAdded DESC) AS Grades
FROM dbo.Grades)
DELETE CTE WHERE Grades > 1
/* Remove the leading 1 off a phone number formatted like 18005551212 so that you can return 10 digits (ie: 8005551212) */
UPDATE [Table]
SET Phone = RIGHT(Phone, LEN(Phone)-1)
WHERE LEFT(Phone,1) = 1
/* Format a 8005551212 phone number like (800) 555-1212 */
SELECT '(' + SUBSTRING(Phone,1,3) + ') ' + SUBSTRING(Phone,4,3) + '-' + SUBSTRING(Phone,7,4) AS "Phone Number"
FROM [Table]
/* Compare Table Types */
-- Build a temporary table for comparing tables
CREATE TABLE #quickcompare ([Table Name] varchar(100),[Column Name] varchar(100), [Data Type] varchar(25), [Length] INT)
-- Just change the name of "YourFirstTable" to the first table's name.
-- You can also then do this for the second table name and insert it as well or use the next one for this.
INSERT INTO #quickcompare ([Table Name],[Column Name],[Data Type],[Length])
SELECT table_name 'Table Name',
column_name 'Column Name',
data_type 'Data Type',
character_maximum_length 'Length'
FROM information_schema.columns
WHERE table_name = 'YourFirstTable'
INSERT INTO #quickcompare ([Table Name],[Column Name],[Data Type],[Length])
SELECT table_name 'Table Name',
column_name 'Column Name',
data_type 'Data Type',
character_maximum_length 'Length'
FROM information_schema.columns
WHERE table_name = 'YourSecondTable'
-- Compare
SELECT * FROM #quickcompare
-- Drop the temp table
DROP TABLE #quickcompare