MySQL:行列轉換、增刪改查、日期計算等經典SQL語句。

1.--行列轉換

原表:  
姓名     科目   成績
張三     語文    80
張三     數學    90
張三     物理    85
李四     語文    85
李四     物理    82
李四     英語    90
李四     政治    70
王五     英語    90sql

轉換後的表: 
姓名       數學    物理     英語    語文    政治 
李四        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  .net

實例:
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,1orm

建立一個合併的函數
--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 ClassNoget


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')io


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 colidtable

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))

相關文章
相關標籤/搜索