工作常用SQL

进击的乌拉發表於2024-07-26

工作常用SQL

Excel生成SQL

這個好用

="insert into t_gk_mapping(id,gk_project_name,gk_project_code,main_project_name,main_project_code) values ('"&J2&"','"&I2&"','"&K2&"','"&L2&"','"&M2&"');"

name欄位拼接 值

update user set name = concat(name,'test') where 1=1

REPLACE()字串函式 替換函式

UPDATE 
	student 
SET 
	name = REPLACE(name,'小明','小紅') 
WHERE 
	id = '1';

關聯表,將匹配到的資料另一個表的欄位set到當前表欄位中

update t1,t2 set t1.`name` = t2.class_name where t1.id = t2.id

將表中一個欄位的值更新為另一個欄位的值 (自連線)

update student a,student b set a.name = b.class
where a.id = b.id

根據number刪除重複記錄,保留code較小的資料


delete from t1 where id in
(
select * from 
(select id from t1
where number  in (select  number  from t1  group  by  number   
having  count(number) > 1)
and code not in (select min(code) from  t1  group by number  having 
count(number)>1)

) as a)

去除某個欄位前後空格

在MySQL中,如果你想要刪除某個欄位的前後空格,你可以使用TRIM()函式。TRIM()函式用於刪除字串的前導和尾隨空格。

UPDATE current_transactions_count  
SET communication_subject = TRIM(communication_subject);

去除某個欄位中的換行

UPDATE users
SET description = REPLACE(description, '\n', '');

行列轉換

select 

 unitName as unitName,
 MAX(CASE WHEN management_objects = 'a' THEN count  END) AS a, 
 MAX(CASE WHEN management_objects = 'b' THEN count END) AS b,
 MAX(CASE WHEN management_objects = 'c' THEN count  END) AS c

 from 
	project
group by unitName

將子表多條資料的某些欄位提到副表某個欄位上

如果你需要將副表中的兩個欄位拼接,並且當存在多個相關記錄時,這些拼接後的字串之間用逗號分隔,你可以使用GROUP_CONCAT函式來同時拼接這兩個欄位,並在它們之間使用一個自定義的分隔符(例如一個空格或者沒有分隔符)。

假設你的sub_table有兩個欄位field1field2,你想要將它們拼接起來,並且對於main_table中的每一行,所有相關的sub_table行都會被拼接並且用逗號分隔,你可以這樣做:

SELECT   
    main_table.*,  
    (  
        SELECT GROUP_CONCAT(CONCAT(sub_table.field1, ' ', sub_table.field2) SEPARATOR ', ')  
        FROM sub_table  
        WHERE sub_table.id = main_table.id  
    ) AS concatenated_values  
FROM main_table;

在這個查詢中,CONCAT(sub_table.field1, ' ', sub_table.field2)負責將field1field2欄位的值拼接起來,並在它們之間插入一個空格(如果你不需要空格,可以去掉它)。然後,GROUP_CONCAT(... SEPARATOR ', ')將這些拼接後的字串用逗號和一個空格分隔開。