【Oracle】和【Mysql】常问面试题

本文对比了Oracle和MySQL在主键自增、分组语句上的差异,并探讨了MyBatis中#和$在动态SQL中的使用区别。在主键自增上,MySQL使用AUTO_INCREMENT,而Oracle则无直接对应设置。分组语句方面,MySQL无特定限制,Oracle则有。在MyBatis动态SQL中,#用于变量值替换,防止SQL注入,而$进行字符串拼接,易引发SQL注入问题。
摘要由CSDN通过智能技术生成

主键自增区别:

【Oracle】

create table mytable
(
    id int primary key,   -- 主键,唯一,不能重复,必填,不能不填写
	name varchar(20),
	money float
);
-- 使用序列让主键自增
-- 创建序列
create sequence myseq;  --从0开始 每次加1
--使用序列
insert into mytable(id,name,money) values(myseq.nextval,'jack',10);

【Mysql】

                 设置自动递增     ----  AUTO_INCREMENT

分组语句区别:

【Oracle】

-- 工资最高  当聚合函数与真实列同时存在时,必须对真实列进行分组
SELECT ENAME, MAX(SAL) FROM EMP
GROUP BY ENAME;  --分组
-- 工资最低  当聚合函数与真实列同时存在时,必须对真实列进行分组
SELECT ENAME,MIN(SAL) FROM EMP
GROUP BY ENAME;

-- 每种职位的最高薪资是多少
SELECT DISTINCT JOB,MAX(SAL) 最高薪资 FROM EMP
WHERE JOB IS NOT NULL
GROUP BY JOB;

-- 每种职位的人数
SELECT JOB,COUNT(EMPNO) FROM EMP
GROUP BY JOB;


GROUP BY注意事项: 
1、当聚合函数与真实列同时存在时,必须对真实列进行分组
2、GROUP BY后面写的的列的名字必须和查询真实列的名字,一模一样
3
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值