日期转换,补充(建表、DML),简单函数,多表连接

  • binary添加在列名之前是区分大小写的意思

补充(建表、DML)

#建表
#新建一张表
create table 表名(
...
)

#子查询建表 (只继承结构和数据,约束无法拷贝)
create table emp_copy
as
select * from emp

create table emp_copy1
as
select empno 工号,ename,sal from emp where deptno = 10

#利用拷贝建一张空表
create table emp_copy1
as
select * from emp where 100 = 1000

#修改工作地点在NEW YORK或CHICAGO的员工工资,工资增加500(利用查询作为结果)
update emp set sal = sal + 500
where deptno in(select deptno from dept where loc in ('NEW YORK','CHICAGO'))

#删除工作在NEW YORK的员工记录(利用查询作为结果)
delete from emp
where deptno in(select deptno from dept where loc in ('NEW YORK'))

简单函数

#函数 函数名(参数)
#虚表
select abs(-19) from dual#虚表
select pi() from dual

#round(x,y)将x精确到小数点后y位
select round(99.456,2),round(95.554,0),round(95.554)#y如果省略,四舍五入整数
from dual

#truncate(x,y)截断,往后清零
select truncate(99.456,2),truncate(95.554,0),truncate(95.554,-1)
from dual

#字符串函数
#substr(str,pos,length) str是操作的字符串,pos位置从1开始,length是截取的长度
select substr('helloworld',1,3) from dual

#查询姓名以s开头的员工信息
select ename from emp where substr(ename,1,1) = 's'

#查询姓名正好为5个字符的员工姓名,工资,部门号
select ename,sal,deptno from emp where length(ename) = 5

select concat(substr(ename,1,1),lower(substr(ename,2))) 名字,length(ename)
from emp

#日期函数
#mysql  5.6版本以后支持日期作为默认值
create table test7(
regtime datetime default now()
)
#curdate()和current_date():获取当前日期函数
#now():返回服务器的当前时间和日期
select curdate(),current_date(),now()
from dual

#DATE_FORMAT(date,format):格式化日期
# %y--年
# %m--月
# %d--日
# %h--时24小时H
# %i--分
# %s--秒
select date_format(now(),'%y-%m-%d %h:%i:%s') from dual
#datediff(expr1,expr2):放回两个日期相减相差的天数
select datediff(curdate(),hiredate)
from emp

#extract(unit from date)提取时间,年月日
select hiredate,extract(year from hiredate)
from emp

select * from emp where extract(year from hiredate)='1981'
select * from emp where extract(month from hiredate)='5'
select * from emp where extract(day from hiredate)='17'
select hiredate, extract(hour from now()) from emp;
select hiredate, extract(minute from now()) from emp;
select hiredate, extract(second from now()) from emp;


#重点函数
#now()年月日时分秒,curdate()年月日,curtime()时分秒 返回系统当前时间
#date_format(date,format)
#datediff(大,小)

#一般函数
#SUBSTR(str,pos,length)
#ROUND,truncate

#1、查询服务器时间
select new() from DUAL
#2、查询部门10,20的员工截止到2000.1.1,工作多少个月,入职月份
select timestampdiff(month,'2019-3-5','2019-9-30')
from dual
select timestampdiff(month,hiredate,date_format(hiredate,'%m'))
from dual




-- 1.查询服务器当前时间
select now() from dual
-- 2.查询部门10,20的员工截止到2000年1月1日,工作了多少个月,入职的月份
-- TIMESTAMPDIFF(按照什么求差,日期1,日期2)
select TIMESTAMPDIFF(MONTH,hiredate,now()),EXTRACT(MONTH FROM hiredate),DATE_FORMAT(hiredate,'%m')
from emp
where deptno in (10,20)

#如果员工试用期6个月,查询职位不是MANAGER的员工姓名,
#入职日期,转正日期,入职日期是第多少月

select ename,hiredate 入职日期,date_format(hiredate,'%m') 入职月份,DATE_ADD(hiredate, INTERVAL 6 MONTH) 转正日期 from emp where job !='MANAGER' 

#流程控制函数
#case
#decode
#查询员工姓名,工资,部门编号,部门名称
select ename,sal,deptno,
(case deptno when 10 then '开发部' when 20 then '实施部' when 30 then '测试部' else '小卖部' end )dname from emp


#计算2000年1月1日到现在有多少月,多少周
select timestampdiff(month,'2000-1-1',now()),timestampdiff(week,'2000-1-1',now()) from dual

#查询ename的第三个字母是A的员工的信息
select * from emp where ename like '__A%'
#将员工工资按如下格式显示:123,234.00 RMB
select concat(sal,'RMB') from emp

#查询员工的姓名以及其经理编号,要求对于没有经理的现实“no Manager”字符串
select ename,ifnull(mgr,'No Manager') mgr from emp
#将员工的参加工作日期按如下格式显示:月份/年份
select date_format(hiredate,'%m/%Y') from emp
#在员工表中查询出员工的工资,并计算应交税款:如果工资小于1000,税率为0,
#如果工资大于等于1000并小于2000,税率为10%,如果工资大于等于2000并小于3000
#税率为15%,如果工资大于等于3000,税率为20%

SELECT sal,(case 
                        when sal<1000 then 0
                        when sal>=1000 and sal<2000 then sal*0.1
                        when sal >=2000 and sal <3000 then sal *0.15
                        else sal*0.2 end)tax
from emp
#方法二
SELECT sal,(case truncate(sal/1000,0)
                        when 0 then 0
                        when 1  then sal*0.1
                        when 2 then sal *0.15
                        else sal*0.2 end)tax
from emp

#重要排名
#重要
#date_format(date,format)
#now() curdate() curtime()

#最好记
#case xx when xx then xx
#ifnull(如果空,返回)
#timestampdiff(month|year|week,日期1,日期2)  datediff(日期1,日期2)
#date_add|date_SUB(date,interval 6 month)

#废柴
#concat
#length,lpad|rpad....

多表连接

#问题
#查询语句,查询员工姓名、部门名称、工作地点
select ename,dname,loc from emp,dept where emp.deptno=dept.deptno 

#涉及的表是一张以上,两张表就会自动发生连接
#连接规则:笛卡尔积,一张表所有记录与另一张表记录全部连接的情况
select ename,dname,loc from emp,dept where emp.deptno=dept.deptno and loc='chicago'

#注意:
#①同名列必须要加表名作为前缀;
#②只要涉及一张以上表别落下连接条件否则笛卡尔积
#③表名也可以起别名,方便写前缀

#查询所有员工编号,姓名,部门编号,工作地点
#Column 'deptno' in field list is ambiguous:列名冲突,没写前缀
select empno,ename,dept.deptno,loc from emp,dept where emp.deptno=dept.deptno

#查询工作地点在NEW YORK的员工编号,姓名,部门,工作地点
select empno,ename,d.deptno,loc from emp e ,dept d
where e.deptno=d.deptno and loc ='new york'

#写一个查询,显示所有员工姓名,部门编号,部门名称。
select ename,e.deptno,d.dname from emp e,dept d where e.deptno =d.deptno
select ename,e.deptno,d.dname 
from emp e join dept d on e.deptno = d.deptno


#写一个查询,显示所有工作在chicago并且奖金不为空的员工姓名,工作地点,奖金
select ename,d.loc,comm from emp e,dept d where e.deptno = d.deptno and comm is not null and loc = 'chicago'
select ename,d.loc,comm 
from emp e 
join dept d 
on e.deptno = d.deptno 
where  comm is not null and loc = 'chicago'


#写一个查询,显示所有姓名中含有A字符的员工姓名,工作地点
select ename,loc from emp e,dept d where e.deptno=d.deptno and ename like '%A%'
select ename,loc
from emp e
join dept d
on e.deptno = d.deptno
where ename like '%A%'

#工资等级表
#1 0-600
#2 601-1500
#3 1501-2500
#4 2501-4000
#5 4001-10000
create table salgrade(
grade int auto_increment,
losal decimal(7,2) default 0,
hisal decimal(7,2) default 0,
primary key(id)
)
#查询员工姓名,工资,奖金,工资等级
select ename,comm,grade,sal,losal,hisal
from emp
join salgrade
on sal between losal and hisal

#查询员工姓名,工资,奖金,工资等级,部门名称,要求只显示工资等级2以上的,按照工资等级排序
select ename,sal,comm,grade,dname
from emp e
join dept d
on e.deptno=d.deptno
join salgrade s
on sal between s.losal and s.hisal 
where grade > 2  
order by grade

#自连接
select e.ename,m.ename
from emp e
join emp m
on  e.mgr=m.empno


作业:查询入职时间比其直接上级入职时间早的员工信息

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容