全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货

oracle为什么不提供CREATE TABLE IF NOT EXIST方式创建表?

发布时间:2023-10-13 12:26:42
发布人:xqq

一、oracle为什么不提供CREATE TABLE IF NOT EXIST方式创建表

因为系统设定语法就这样,后面只能先跟文件名,然后再跟条件。但写脚本时可以每次先drop ,再create。 写个块判断也行。使用了oracle的保留字size和rows,不能用来作为列名,把他改成别的吧,比如items_size,items_rows,不然以后调用也很麻烦。

mysql的CREATE TABLE IF NOT EXISTS 方法

DROP TABLE IF EXISTS ci_sessions;
CREATE TABLE IF NOT EXISTS ci_sessions (
   session_id VARCHAR(40) NOT NULL DEFAULT ‘0’,
   peopleid INT(11) NOT NULL,
   ip_address VARCHAR(16) NOT NULL DEFAULT ‘0’,
   user_agent VARCHAR(50) NOT NULL,
   last_activity INT(10) UNSIGNED NOT NULL DEFAULT ‘0’,
   LEFT INT(11) NOT NULL,
   name VARCHAR(25) NOT NULL,
   status TINYINT(4) NOT NULL DEFAULT ‘0’
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

延伸阅读:

二、MVCC多版本并发控制机制的实现

undo日志版本链是指一行数据被多个事务依次修改过后,在每个事务修改完后,Mysql会保留修改前的数据undo回滚日志,并且用两个隐藏字段trx_id和roll_pointer把这些undo日志串联起来形成一个历史记录版本链。

在可重复读隔离级别,当事务开启,执行任何查询sql时会生成当前事务的一致性视图read-view该视图在事务结束之前都不会变化(如果是读已提交隔离级别在每次执行查询sql时都会重新生成)该视图由执行查询时所有未提交事务id数组(数组里最小的id为min_id)和已创建的最大事务id(max_id)组成事务里任何sql的查询结果需要从对应版本链里的最新数据开始逐条跟read-view做比对从而得到最终的快照结果

1.如果 row 的 trx_id 落在绿色部分( trx_id

2. 如果 row 的 trx_id 落在红色部分( trx_id>max_id ),表示这个版本是由将来启动的事务生成的,是不可见的(若 row 的 trx_id 就是当前自己的事务是可见的);

3. 如果 row 的 trx_id 落在黄色部分(min_id <=trx_id<= max_id),那就包括两种情况:

若 row 的 trx_id 在视图数组中,表示这个版本是由还没提交的事务生成的,不可见(若 row 的 trx_id 就是当前自己的事务,是可见的);

若 row 的 trx_id 不在视图数组中,表示这个版本是已经提交了的事务生成的,可见。

#it技术干货

相关文章

Mysql中sum和group by联用求和为什么会计算不准确?

Mysql中sum和group by联用求和为什么会计算不准确?

2023-10-13
如果同一条记录同时多个进程可能对不同的字段进行修改,怎么保证列锁?

如果同一条记录同时多个进程可能对不同的字段进行修改,怎么保证列锁?

2023-10-13
memcached、Redis缓存的数据都是key-value的形式,那缓存时,具体是key、value分别是怎样的数据呢?

memcached、Redis缓存的数据都是key-value的形式,那缓存时,具体是key、value分别是怎样的数据呢?

2023-10-13
mysql如果一张表里面两个字段的值相同,则添加到第二张表里,怎么做?

mysql如果一张表里面两个字段的值相同,则添加到第二张表里,怎么做?

2023-10-13

最新文章

常见网络安全面试题:Windows常用的命令有哪些?

常见网络安全面试题:Windows常用的命令有哪些?

2023-10-09
常见网络安全面试题:根据设备告警如何展开排查?

常见网络安全面试题:根据设备告警如何展开排查?

2023-10-09
常见网络安全面试题:mysql加固呢?(数据库加固)

常见网络安全面试题:mysql加固呢?(数据库加固)

2023-10-09
常见网络安全面试题:windows和linux加固?(操作系统加固)

常见网络安全面试题:windows和linux加固?(操作系统加固)

2023-10-09
在线咨询 免费试学 教程领取