31. 获取select * from employees对应的执行计划
EXPLAIN SELECT * FROM employees
注意EXPLAIN
32. 将employees表的所有员工的last_name和first_name拼接起来作为Name,中间以一个空格区分
SELECT last_name||' '||first_name AS name
FROM employees
SQLite3 中拼接字符串用 ||,MYSQL 中用CONCAT()
33. 创建一个actor表,包含如下列信息
列表 | 类型 | 是否为NULL | 含义 |
actor_id | smallint(5) | not null | 主键id |
first_name | varchar(45) | not null | 名字 |
last_name | varchar(45) | not null | 姓氏 |
last_update | timestamp | not null | 最后更新时间,默认是系统的当前时间 |
CREATE TABLE 'actor'('actor_id' smallint(5) not null,
'first_name' varchar(45) not null,
'last_name' varchar(45) not null,
'last_update' timestamp not null DEFAULT (datetime('now','localtime')),
primary key('actor_id'))
重点是要注意设置默认时间,DEFAULT表示插入默认值,datetime是读取当前时间,‘locatime’的作用是把时区换成本地时区
34. 对于表actor批量插入如下数据
actor_id | first_name | last_name | last_update |
1 | PENELOPE | GUINESS | 2006-02-15 12:34:33 |
2 | NICK | WAHLBERG | 2006-02-15 12:34:33 |
INSERT INTO actor
VALUES
(1,'PENELOPE','GUINESS','2006-02-15 12:34:33'),
(2,'NICK','WAHLBERG','2006-02-15 12:34:33');
批量插入还可以用SELECT
35. 对于表actor批量插入如下数据,如果数据已经存在,请忽略,不使用replace操作
actor_id | first_name | last_name | last_update |
3 | ED | CHASE | 2006-02-15 12:34:33 |
INSERT OR IGNORE INTO actor
SELECT 3,'ED','CHASE','2006-02-15 12:34:33'
因为牛客网用的是SQLite3,所以要用 INSERT OR IGNORE
如果是MYSQL,可以省略OR
如果对重复值进行替换,SQLite3 中可以用 INSERT OR REPLACE,MYSQL 中直接用 REPLACE