当前位置: 首页 > news >正文

Mysql和Oracle使用差异和主观感受

这两种常用的关系型数据库有何差异?

支持和社区

MySQL:有一个活跃的开源社区,用户可以获取大量的文档和支持。
Oracle:提供了专业的技术支持,但通常需要额外的费用。

易用性

MySQL:通常被认为是更易于学习和使用的数据库系统。
Oracle:可能需要更多的学习和培训,但提供了更强大的功能。

使用语法

自增主键

mysql中要使用自增主键非常方便,只需要在建表时增加 auto_increment 关键字即可,样例如下:

create table tb1 (id int(11) unsigned not null auto_increment);

而在oracle中则不一样了,它需要使用另一个概念:序列号;我们可以简单将其理解为只有一个列的表,这个表提供了 nextval 的方法,辅助我们生成自增id,样例如下:

-- 1. 建普通表create table tb1(id number not null);
-- 2. 创建序列,参数比较多,自行查阅资料
create sequence seq_tb1 increment by 1 start with 1 minvalue 1 maxvalue 999999999
-- 3. 插入使用
insert into tb1 (id) values (seq_tb1.nextval)

分页

分页一般用于列表数据多页显示,或取总数中的几条数据使用。mysql中的分页,使用limit,这也是大多数数据库的选择,样例如下:

select username from tb1 limit 50, 100;

而在oracle中则不太一样,它使用行号去定位记录,一般需要使用嵌套子查询;样例如下:

select * from (select t.*,rownum num from tb1 t where rownum<=100 ) where num>50

创建索引

索引的目的自然是为了提高查询效率,mysql中想要添加索引可以在建表时操作,也可以在后期更改;样例如下:

-- 1. 建表时指定
create table tb1 (username varchar(50), index username (username));
-- 2. 后期更改
alter table tb1 add index username (usrrname);

而在oracle中则不一样,它只能在建表完成之后操作;样例如下:

CREATE INDEX tb1_username ON tb1(username);

看起来差异不大,但oracle的索引是全局的,即所有表的索引名都不能重复,比如大家都有id索引,但却不能都叫id。另外,oracle建表时,无法做到一步到位。实际上需要n步:建表sql + n个注释sql + 主键sql + n个索引sql + 建序列号sql + 。。。 总之,会让你醉了!

http://www.lryc.cn/news/457075.html

相关文章:

  • 【Java】—— File类与IO流:File类的实例化与常用方法
  • C++设计模式——装饰器模式
  • C#使用ITextSharp生成PDF文件实例详解
  • 10.9QT对话框以及QT的事件机制处理
  • SiLM266x系列SiLM2661高压电池组前端充/放电高边NFET驱动器 为电池系统保护提供可靠性和设计灵活性
  • linux中sed命令详解
  • vue 模板语法
  • bladex漏洞思路总结
  • 解决SqlServer自增主键使用MybatisPlus批量插入报错问题
  • leetcode:反转字符串中的单词III
  • 深度学习常见问题
  • 神经网络的一些benchmark示例
  • 如何进行统级架构设计
  • 鼓组编写:SsdSample鼓映射 GM Map 自动保存 互换midi位置 风格模板 逻辑编辑器
  • 使用YOLOv11进行视频目标检测
  • DEEP和DeepBook V3将于10月14日推出
  • 学习之高阶编程列表推导式,字典推导式
  • QT实现QInputDialog中文按钮
  • Redis 常用指令技术解读
  • Web前端入门
  • 贝塞尔曲线详细讲解,如何用 Canvas 绘制三阶贝塞尔曲线?
  • Ubuntu20.04卸载ros2 foxy版本安装ros1 noetic版本
  • PicGo+Gitee搭建Typora图床
  • MySQL 脱敏函数使用详解:保护数据隐私的关键手段
  • nginx之virtual host
  • Windows 下纯手工打造 QT 开发环境
  • k8s的安装和部署
  • 第十八篇:一文说清楚ICMP的底层原理
  • 【优选算法】(第三十二篇)
  • 线程(四)线程的同步——条件变量