【躍遷之路】【424天】刻意練習系列183—SQL(2018.04.05)

@(躍遷之路)專欄html

叨叨兩句

  1. 技術的精進不能只是簡單的刷題,而應該是不斷的「刻意」練習
  2. 該系列改版後正式歸入【躍遷之路】專欄,持續更新

刻意練習——MySQL

2018.04.02

題目描述sql

DROP TABLE IF EXISTS test1;
CREATE TABLE test1 (
id int(11) NOT NULL AUTO_INCREMENT,
username varchar(20) NOT NULL,
course varchar(20) NOT NULL,
score bigint(20) NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;spa

INSERT INTO test1 VALUES ('1', '張三', '數學', '34');
INSERT INTO test1 VALUES ('2', '張三', '語文', '44');
INSERT INTO test1 VALUES ('3', '張三', '英語', '54');
INSERT INTO test1 VALUES ('4', '李四', '數學', '134');
INSERT INTO test1 VALUES ('5', '李四', '語文', '144');
INSERT INTO test1 VALUES ('6', '李四', '英語', '154');
INSERT INTO test1 VALUES ('7', '王五', '數學', '234');
INSERT INTO test1 VALUES ('8', '王五', '語文', '244');
INSERT INTO test1 VALUES ('9', '王五', '英語', '254');code

查出如下結果
sqlite

法1htm

SELECT
    A.username,A.score as '數學',B.score as '語文',C.score as '英語'
FROM 
(select username,course,score from test1 where course = '數學') A,
(select username,course,score from test1 where course = '語文') B,
(select username,course,score from test1 where course = '英語') C
WHERE
    A.username = B.username
and B.username = C.username

法2【推薦】blog

select
    username,sum(case course when '數學' then score else 0 end ) as '數學',
sum(case course when '語文' then score else 0 end ) as '語文',
sum(case course when '英語' then score else 0 end ) as '英語'
FROM
    test1
group by username

2018.04.03

題目描述rem

在audit表上建立外鍵約束,其emp_no對應employees_test表的主鍵id。
CREATE TABLE employees_test(
ID INT PRIMARY KEY NOT NULL,
NAME TEXT NOT NULL,
AGE INT NOT NULL,
ADDRESS CHAR(50),
SALARY REAL
);數學

CREATE TABLE audit(
EMP_no INT NOT NULL,
create_date datetime NOT NULL
);it

DROP TABLE audit;
CREATE TABLE audit(
    EMP_no INT NOT NULL,
    create_date datetime NOT NULL,
    FOREIGN KEY(EMP_no) REFERENCES employees_test(ID)
);

2018.04.04

因爲視圖 emp_v 的記錄是從 employees 中導出的,因此要判斷二者中相等的數據,只須要判斷emp_no相等便可。
方法一:用 WHERE 選取兩者 emp_no 相等的記錄

SELECT em.* FROM employees AS em, emp_v AS ev WHERE em.emp_no = ev.emp_no
方法二:用 INTERSECT 關鍵字求 employees 和 emp_v 的交集
可參考:http://www.sqlite.org/lang_select.html

SELECT * FROM employees INTERSECT SELECT * FROM emp_v
方法三:仔細一想,emp_v的所有記錄均由 employees 導出,所以能夠投機取巧,直接輸出 emp_v 全部記錄

SELECT * FROM emp_v
【錯誤方法:】用如下方法直接輸出 *,會獲得兩張表中符合條件的重複記錄,所以不合題意,必須在 * 前加表名做限定

SELECT * FROM employees, emp_v WHERE employees.emp_no = emp_v.emp_no

2018.04.05

題目描述
將全部獲取獎金的員工當前的薪水增長10%。
create table emp_bonus(
emp_no int not null,
recevied datetime not null,
btype smallint not null);
CREATE TABLE salaries (
emp_no int(11) NOT NULL,
salary int(11) NOT NULL,
from_date date NOT NULL,
to_date date NOT NULL, PRIMARY KEY (emp_no,from_date));

UPDATE salaries SET salary = salary * 1.1 WHERE emp_no IN
(SELECT s.emp_no FROM salaries AS s INNER JOIN emp_bonus AS eb 
ON s.emp_no = eb.emp_no AND s.to_date = '9999-01-01')
相關文章
相關標籤/搜索