牛客网-数据库SQL实战31-35

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_idsmallint(5)not null主键id
first_namevarchar(45)not null名字
last_name varchar(45)not null姓氏
last_updatetimestampnot 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_idfirst_namelast_namelast_update
1PENELOPEGUINESS2006-02-15 12:34:33
2NICKWAHLBERG2006-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_idfirst_namelast_namelast_update
3EDCHASE2006-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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值