行列轉換等經典SQL語句

 

1.--行列轉換
原表:   姓名     科目   成績
           張三     語文    80
           張三     數學    90
           張三     物理    85
           李四     語文    85
           李四     物理    82
           李四     英語    90
           李四     政治    70
           王五     英語    90

 

轉換後的表:     姓名       數學      物理      英語    語文     政治 
                       李四          0         82        90      85       70
                       王五          0           0        90        0         0
                       張三        90         85          0      80         0

 

實例:
create table cj  --創建表cj
(
    ID       Int IDENTITY (1,1)     not null, --創建列ID,並且每次新增一條記錄就會加1
    Name     Varchar(50),  
    Subject  Varchar(50),
    Result   Int, 
    primary key (ID)      --定義ID爲表cj的主鍵     
);
--Truncate table cj
--Select * from cj
Insert into cj
Select '張三','語文',80 union all
Select '張三','數學',90 union all
Select '張三','物理',85 union all
Select '李四','語文',85 union all
Select '李四','物理',82 union all
Select '李四','英語',90 union all
Select '李四','政治',70 union all
Select '王五','英語',90


--行列轉換
Declare @sql varchar(8000)
Set @sql = 'Select Name as 姓名'
Select @sql = @sql + ',sum(case Subject when '''+Subject+''' then Result else 0 end) ['+Subject+']'
from (select distinct Subject from cj) as cj  --把所有唯一的科目的名稱都列舉出來
Select @sql = @sql+' from cj group by name'
Exec (@sql)

 


2. 行列轉換--合併
原表:   班級    學號    
            1          1  
            1          2
            1          3
            2          1
            2          2
            3          1


轉換後的表:   班級  學號           
                       1   1,2,3
                       2   1,2
                       3   1  

實例:
Create table ClassNo  --創建表ClassNo
(
    ID Int IDENTITY(1,1)  not null,  --創建列ID,並且每次新增一條記錄就會加1
    Class  Varchar(50),    --班級列
    Number Varchar(50),    --學號列
    Primary Key(ID)        --定義ID爲表ClassNo的主鍵
);
--Truncate Table ClassNo
--Select * from ClassNo
Insert Into ClassNo
Select 1,1 Union all
Select 1,2 Union all
Select 1,3 Union all
Select 2,1 Union all
Select 2,2 Union all
Select 3,1

創建一個合併的函數
--Drop Function KFReturn
Create Function KFReturn(@Class Varchar(50))
Returns Varchar(8000)
as
Begin
Declare @str Varchar(8000)
Set @str = ''
Select @str = @str + cast(Number as Varchar(50))  + ',' from ClassNo Where Class = @Class
Set @str = SubString(@str,1,len(@str)-1)
Return(@str)
End

--調用自定義函數得到結果
Select Distinct Class,dbo.KFReturn(Class) From ClassNo

 


3:列轉行
--Drop Table ColumnToRow
Create table ColumnToRow
(
   ID Int IDENTITY(1,1)  not null,  --創建列ID,並且每次新增一條記錄就會加1
   a  int,
   b  int,
   c  int,
   d  int,
   e  int,
   f  int,
   g  int,
   h  int,
   Primary Key(ID)        --定義ID爲表ColumnToRow的主鍵     
);
--Truncate Table ColumnToRow
--Select * from ColumnToRow
Insert Into ColumnToRow
Select 15,9,1,0,1,2,4,2 Union all
Select 22,34,44,5,6,7,8,7 Union all
Select 33,44,55,66,77,88,99,12

Declare @sql Varchar(8000)
Set @sql = ''
Select @sql = @sql + rtrim(name) + ' from ColumnToRow union all Select ' from SysColumns Where id = object_id('ColumnToRow')
Set @sql = SubString(@sql,1,len(@sql)-70)
--70的長度就是這個字符串'from ColumnToRow union all Select ID from ColumnToRow union all Select ',因爲它會把ID這一列的值也算進去,所以要把它截掉
Exec ('Select ' + @sql + ' from ColumnToRow')

 


4. 如何取得一個數據表的所有列名
方法如下:先從sysobjects系統表中取得數據表的systemid,然後再syscolumns表中取得該數據表的所有列名。
SQL語句如下:
Declare @objid int,@objname char(40)
set @objname = 'ColumnToRow'


--第1種方法
select @objid = id from sysobjects where id = object_id(@objname)
select 'Column_name' = name from syscolumns where id = @objid order by colid
--或也可以寫成
select name as 'Column_name' from syscolumns where id = @objid order by colid


--第2種方法:
Select name as 'Column_Name' from SysColumns where id = object_id(@objname) Order by colid

 

 

5. 通過SQL語句來更改用戶的密碼
修改別人的,需要sysadmin role
Exec Sp_password '原始密碼','更改後密碼','賬號'
Exec sp_password null,ok,sa

 

 

6. 怎麼判斷出一個表的哪些字段不允許爲空?
Declare @objname Varchar(50)
set @objname = 'ColumnToRow'
Select Column_Name from information_schema.Columns where is_nullable = 'No' and Table_Name = @objname

 

 

7. 如何在數據庫裏找到含有相同字段的表?
a. 查已知列名的情況
Select a.name as Columnname,b.name as tablename from SysColumns a inner join sysobjects b on a.id = b.id
and b.type = 'U' and a.name = '您要查找的字段名'


b. 未知列名查所有在不同表出現過的列名
Select s.name as tablename,s1.name as columnname from SysColumns s1,Sysobjects s
Where s1.id = s.id and s.Type = 'U' and Exists (Select 1 from syscolumns s2 where s1.name = s2.name and s1.id <> s2.id)

 

 

8.查詢第N行數據
假設id是主鍵:
select *
from (select top N * from 表) aa
where not exists(select 1 from (select top N-1 * from 表) bb where aa.id=bb.id)

 

 

9. SQL Server日期計算
a. 一個月的第一天
SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)


b. 本週的星期一
SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)


c. 一年的第一天
SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)


d. 季度的第一天
SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)


e. 上個月的最後一天
SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))


f. 去年的最後一天
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))


g. 本月的最後一天
SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))


h. 本月的第一個星期一
select DATEADD(wk, DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0)


i. 本年的最後一天
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))

 

 

發佈了46 篇原創文章 · 獲贊 0 · 訪問量 4817
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章