首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java面试——数据库知识点

当现有数据中存在重复的键值时,大多数数据库不允许将新创建的唯一索引与表一起保存。数据库还可能防止添加将在表中创建重复键值的新数据。 主键索引 :数据库表经常有一列或列组合,其值唯一标识表中的每一行。...如果右表的某行在左表中没有匹配行,则将为左表返回空值。...是 串行化(serializable) 否 否 否 注:mysql默认是 可重复读(repeatable-read),oracle默认是读已提交(read committed)。...常见于使用非唯一索引即唯一索引的非唯一前缀进行的查找 eq_ref:唯一性索引扫描,对于每个索引键,表中只有一条记录与之匹配。...常见于主键或唯一索引扫描 const、system:当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型访问。

57220

MySQL入门详解(二)---mysql事务、锁、以及优化

,然后B回滚操作,那么A读取到的数据是脏数据 2.不可重复读:事务A多次读取同一数据,事务B在事务A多次读取过程中,对数据作了更新并提交 ,导致事务A多次读取同一数据时结果不一致 3.幻读:系统管理员A...幻读可能性 未提交读 READ UNCOMMITED 是 是 是 不可重复读 READ COMMITED 否 是 是 可重复读 REPEATABLE READ 否 否 是 串行化 SERIALIZABLE...否 否 否 数据库锁 mysql不同存储引擎支持不同锁机制,innodb支持表行级锁默认行级锁,memory采用表级锁,bdb采用页面锁支持表级锁。...FOR UPDATE #主动添加独占锁(X) #释放锁 commit;或 rollback; 当使用行排他锁写数据时,其他人无法操作本条数据; 当给一条数据添加了排它锁,其他人对这条数据没有任何权限,...< const: 表最多有一个匹配行,它将在查询开始时被读取。

1.1K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【MySQL知识点】唯一约束、主键约束

    插入数据 如下,我们创建my_unique1和my_unique2两个表来进行测试,为两个表分别添加列级约束和表级约束,然后查看表的结构,会发现两个表的结构是相同的。...当表级约束仅建立在一个字段上时,其作用效果与列级效果相同。 由以下结果我们可以发现,添加唯一约束后,插入重复记录会失败。...创建复合唯一约束 在表级唯一性约束创建时,unique()的字段列表中,可以添加多个字段,组成复合唯一键,特点是只有多个字段的值相同时才视为重复记录。...表级约束的字段若只有一个,则为单字段主键与列级约束添加的效果相同;若有多个,则为复合主键,复合主键需要用多个字段来确定一条记录的唯一性,类似于复合唯一键。...插入数据 插入NULL时,会插入失败,提示id字段不能为NULL 插入重复值也会失败,提示”1“已经存在主键。

    3K30

    mysql面试题目及答案_docker 面试题

    3.说一说脏读、不可重复读、幻读 脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据; 不可重复读:事务 A 多次读取同一数据,事务 B 在事务A多次读取的过程中,对数据作了更新并提交...在进行表链接后会筛选掉重复的记录,Union All不会去除重复记录; 对排序的处理:Union将会按照字段的顺序进行排序;UNION ALL只是简单的将两个结果合并后就返回; 从效率上说,UNION...因为当不符合以上条件的时候,外键会影响业务的扩展和修改,当数据量庞大时,会严重影响增删改查的效率。 27.什么叫视图?...在平时InnoDB建表的时候我们最好自己确定主键,防止每次插入数据前数据库会去生成rowid。 29.mysql怎么在查询时给查出来的数据设置一个自增的序号?...,常见于使用非唯一索引即唯一索引的非唯一前缀进行查找;eq_ref:唯一性索引扫描,对于每个索引键,表中只有一条记录与之匹配,常用于主键或者唯一索引扫描;const,system:当MySQL对某查询某部分进行优化

    1.1K20

    MySQL全网最全面试题

    如果FROM子句包含两个以上表,则对上一个连接生成的结果表VT3和下一个表重复执行步骤1)~步骤3),直到处理完所有的表为止 WHERE:对虚拟表VT3应用WHERE过滤条件,只有符合的记录才被插入虚拟表...此时binlog没有对上面的更新语句进行保存,导致当使用binlog进行数据库的备份或者恢复时,就少了上述的更新语句。从而使得id=2这一行的数据没有被更新。...当我们使用唯一性的索引(包括唯一索引和聚簇索引)进行等值查询且精准匹配到一条记录时,此时就会直接将这条记录锁定。...当使用唯一性索引,等值查询匹配到一条记录的时候,临键锁(Next-Key Locks)会退化成记录锁;没有匹配到任何记录的时候,退化成间隙锁。...Read 可重复读 否 否 是 Serialzable 可串行化 否 否 否 52.事务的各个隔离级别都是如何实现的?

    51611

    mysql学习总结04 — SQL数据操作

    更新数据 更新数据时通常跟随where条件,如果没有条件,是全表更新数据,可以使用 limit 限制更新的数量 基本语法:update set 字段名> = where <判断条件...(避免) 使用匹配条件进行匹配,因为表的设计通常容易产生同名字段,尤其是ID,所以为了避免重名出现错误,通常使用 字段名> 来确保唯一性 通常,如果条件中使用到对应的表名,而表名通常比较长,所以可以通过表别名来简化...外键 12.1 概念 foreign key : 一张表(从表)中有一个字段(外键),保存的值指向另外一张表(主表)的主键 12.2 外键的操作 增加外键 方案1:创建表时增加外键(类似主键) 基本语法...外键创建时会自动增加一个普通索引,但删除时仅删除外键不删除索引,如果要删除需要手动删除 基本语法: alter table drop foreign key ; alter table...外键约束概念 外键约束主要约束主表操作,从表仅约束不能插入主表不存在的数据,外键约束约束了例如: 从表插入数据,不能插入对应主表主键不存在的数据 主表删除数据,不能删除被从表引入的数据 外键约束保证了数据的完整性

    5.2K30

    ⑦【MySQL】什么是约束?如何使用约束条件?主键、自增、外键、非空....

    约束 ⑦【MySQL】约束条件 1. 约束的基本使用 2. 外键约束 ⑦【MySQL】约束条件 1. 约束的基本使用 约束: 什么是约束? 约束是作用于表中字段上的规则,用于限制存储在表中的数据。...约束分类: ①非空约束 —— 限制该字段的数据不能为null NOT NULL ②唯一约束 —— 保证该字段的所有数据都是唯一、不重复的 UNIQUE ③主键约束—— 主键是一行数据的唯一标识,要求非空且唯一...INSERT INTO test(NAME,age,STATUS,gender) VALUES ('小二',-1,'1','女'); -- 当插入数据时,没有为默认约束字段status设置值,会自动设置默认值...外键名称 FOREIGN KEY(外键字段名) REFERENCES 主表(主表字段名); 外键的删除/更新行为: NO ACTION:在父表进行更新/删除时,首先检查记录是否存在外键,存在则不允许删除...,存在则将外键关联的字段值设置为null(前提是外键关联字段可以为null) SET DEFAULT:在父表进行更新/删除时,首先检查记录是否存在外键,存在则将外键关联的字段值设置为一个默认值(Innodb

    536100

    MySQL相关问题整理

    注意和不可重复读的区别,这里是新增,不可重复读是更改(或删除)。select某记录是否存在,不存在,准备插入此记录,但执行 insert 时发现此记录已存在,无法插入,此时就发生了幻读。...read-uncommitted) 是 是 是 不可重复读(read-committed) 否 是 是 可重复读(repeatable-read) 否 否 是 串行化(serializable) 否 否...否 在MySQL可重复读的隔离级别中并不是完全解决了幻读的问题,而是解决了读数据情况下的幻读问题。...比如当(张三,F)这样的数据来检索时,b+树可以用name来指定搜索方向,但下一个字段age的缺失,所以只能把名字等于张三的数据都找到,然后再匹配性别是F的数据了, 这个是非常重要的性质,即索引的最左匹配特性...乐观锁:大多数基于数据版本(Version)记录机制实现,具体可通过给表加一个版本号或时间戳字段实现,当读取数据时,将version字段的值一同读出,数据每更新一次,对此version值加一。

    58340

    MySQL基础知识

    此时binlog没有对上面的更新语句进行保存,导致当使用binlog进行数据库的备份或者恢复时,就少了上述的更新语句。从而使得id=2这一行的数据没有被更新。...index_subqueryindex_subquery:区别于unique_subquery,用于非唯一索引,可以返回重复值。rangerange:使用索引选择行,仅检索给定范围内的行。...当我们使用唯一性的索引(包括唯一索引和聚簇索引)进行等值查询且精准匹配到一条记录时,此时就会直接将这条记录锁定。...当使用唯一性索引,等值查询匹配到一条记录的时候,临键锁(Next-Key Locks)会退化成记录锁;没有匹配到任何记录的时候,退化成间隙锁。...不同的隔离级别,在并发事务下可能会发生的问题:隔离级别脏读不可重复读幻读Read Uncommited  读取未提交是是是Read Commited 读取已提交否是否Repeatable Read 可重复读否否是

    1.9K30

    【MySQL】015-MySQL索引

    唯一性约束:通过在索引上添加唯一性约束,可以确保某一列的值在表中是唯一的。这对于维护数据的完整性非常有用。 加速数据修改:尽管索引可以加快数据检索,但它们在数据插入、更新和删除时也有一定的好处。...降低插入、更新和删除性能:在插入、更新或删除记录时,索引需要维护,这会导致额外的I/O操作和处理时间。如果表有多个索引,这个开销会更加显著。...加速检查外键约束:外键列通常会被索引,以确保引用完整性。这有助于在执行插入或更新操作时快速验证外键引用。 加速子查询:索引可以加速子查询的执行,使其更高效。...3、维护索引:确保在插入、更新和删除操作后,二级索引保持一致。MySQL通常会自动处理索引的维护,但在大批量插入或更新数据时,可能需要手动重建索引以确保其正确性。...不适合创建索引的场景 频繁需要更新的字段:对于需要经常更新的字段不适合建立索引,因为字段频繁被修改,而B+树需要维护索引键的有序性,所以频繁更新的字段会增加维护索引的成本,很影响数据库的性能。

    8710

    Mysql基础

    三、存储引擎 InnoDB 是 MySQL 默认的事务型存储引擎,只有在需要它不支持的特性时,才考虑使用其它存储引擎。 实现了四个标准的隔离级别,默认级别是可重复读(REPEATABLE READ)。...当线程A要更新数据值时,在读取数据的同时也会读取version值,在提交更新时,若刚才读取到的version值为当前数据库中的version值相等时才更新,否则重试更新操作,直到更新成功。...当需要更新时,判断当前内存值与之前取到的值是否相等,若相等,则用新值更新,若失败则重试,一般情况下是一个自旋操作,即不断的重试。...每当与表相关联的事件发生时,即会执行或触发SQL触发器,例如插入,更新或删除。 QL触发器是一种特殊类型的存储过程。 这是特别的,因为它不像直接像存储过程那样调用。...NOT NULL不为空、UNIQUE唯一、PRIMARY KEY主键、FOREIGN KEY外键、CHECK控制字段范围) 16 Mysql数据库引擎MyISAM和InnoDB( MyISAM: 表锁

    1.8K00

    MySQL数据库:锁机制

    记录锁:当使用唯一索引,且记录存在的精准查询时,使用记录锁 具体的使用体现在哪里呢?...如下图所示: (1)范围查询,记录存在,使用临键锁: (2)当记录不存在时(不论是等值查询,还是范围查询),临建锁将退化成间隙锁: (3)当条件是精准匹配(即为等值查询时)且记录存在时,并且是唯一索引...,临键锁退化成记录锁: (4)当条件是精准匹配(即为等值查询时)且记录存在,但不是唯一索引时,使用临键锁,有精准值的数据会增加记录锁 和 精准值前后的区间的数据会增加间隙锁 3、利用锁机制解决并发问题...: 通过对InnoDB不同锁类型的特性分析,可以利用锁解决脏读、不可重复读、幻读: X锁解决脏读 S锁解决不可重复读 临键锁解决幻读 4、分析数据库中行锁情况的命令: mysql...2、并发插入: 一般情况下,当数据库表有一个读锁时,其它进程无法对此表进行更新操作,但在一定条件下,MyISAM表也支持查询和插入操作的并发进行。

    1.5K30

    Mysql基础

    三、存储引擎 InnoDB 是 MySQL 默认的事务型存储引擎,只有在需要它不支持的特性时,才考虑使用其它存储引擎。 实现了四个标准的隔离级别,默认级别是可重复读(REPEATABLE READ)。...当线程A要更新数据值时,在读取数据的同时也会读取version值,在提交更新时,若刚才读取到的version值为当前数据库中的version值相等时才更新,否则重试更新操作,直到更新成功。...当需要更新时,判断当前内存值与之前取到的值是否相等,若相等,则用新值更新,若失败则重试,一般情况下是一个自旋操作,即不断的重试。...每当与表相关联的事件发生时,即会执行或触发SQL触发器,例如插入,更新或删除。 QL触发器是一种特殊类型的存储过程。 这是特别的,因为它不像直接像存储过程那样调用。...NOT NULL不为空、UNIQUE唯一、PRIMARY KEY主键、FOREIGN KEY外键、CHECK控制字段范围) 16 Mysql数据库引擎MyISAM和InnoDB( MyISAM: 表锁

    1.5K00

    MySQL_库和表的使用(部分未完

    主键不为空、数据值不能重复,因此可以标定一条数据的唯一性。...,其主键或唯一键,与表中现存数据重合,则插入数据失败。...在test表中插入数据Sno、Sage(Sno必填,因为是主键),如果填入的内容与主键发生重复冲突,则更新update语句后面指定字段中的内容 示例中是,如果发生主键/唯一键冲突,则将该主键/唯一键对应的数据中...Sno字段数据改为21 插入否则替换(replace) 与更新update不同,更新是只更新数据中原有的部分字段,替换replace则是先删除原数据(所有字段),然后根据要填入的value再插入。...要插入的数据的主键/唯一键与现有数据冲突时,replace将现有数据所有字段删除,将要插入的数据重新插入。即replace在遇到冲突时,是先删除,后插入。

    12210

    MySQL学习之路:数据的完整性-外键约束

    decimal(20,2) -> ); Query OK, 0 rows affected (0.03 sec) 当主键由多个字段组合构成时,主键只能在字段定义完成后设置。...当向表中添加记录时,若未为字段赋值,数据库系统会自动为将字段的默认值插入。 属性名 数据类型 DEFAULT 默认值 修改购物车表cart,将购买数量的默认值设置为1。...序号 字段 数据类型 主键 外键 允许空 说明 1 cid int 是 否 类别id 2 cname varchar(30) 否 类别名称 序号 字段 数据类型 主键 外键 允许空 说明 1 gid...外键约束实现了表间的引用完整性,当主表中被引用列的值发生变化时,为了保证表间数据的一致性,从表的中与该值相关的信息也应该相应更新,这就是外键约束的级联更新和删除。...SET NULL:更新和删除操作表记录时,从表中相关记录对应的值设置为NULL。 NO ACTION:不进行任何操作 RESTRICT:拒绝主表更新或修改外键的关联列。

    31620

    一篇文章彻底搞懂Mysql事务相关原理

    对于使用唯一索引来锁定唯一行来锁定行的语句,不需要间隙锁定。(这不包括搜索条件仅包含多列唯一索引的某些列的情况;在这种情况下,会发生间隙锁定。)...在内部,InnoDB向数据库中存储的每一行添加三个字段。6个字节的DB_TRX_ID字段表示插入或更新该行的最后一个事务的事务标识符。...回滚段中的撤消日志分为插入和更新撤消日志。插入撤消日志仅在事务回滚时才需要,并且在事务提交后可以立即将其丢弃。...更新二级索引列时,将对旧的二级索引记录进行删除标记,插入新记录,并最终清除带有删除标记的记录。当二级索引记录被删除标记或二级索引页由较新的事务更新时,InnoDB在聚集索引中查找数据库记录。...undo log 的生成 假设有两个表 bank和finance,表中原始数据如图所示,当进行插入,删除以及更新操作时生成的undo log如下面图所示: ?

    85210

    SQL命令 INSERT(二)

    如果为计算字段提供值,或者如果此字段具有默认值,则INSERT将存储此显式值。否则,将计算该字段值,如下所示: COMPUTECODE:值在插入时计算并存储,值在更新时不变。...可以使用此语句插入使用UNIQUE约束定义的字段。如果字段定义了唯一约束且没有默认值,则重复调用会插入多行,并将此唯一字段设置为NULL。如果使用唯一约束和默认值定义字段,则此语句只能使用一次。...对应的字段可以具有不同的列名和列长度,只要插入的数据适合插入表字段即可。相应的字段必须通过数据类型和长度验证;否则将生成SQLCODE-104错误。...可以使用GROUP BY子句仅插入一个(或多个)字段的唯一值。由于默认情况下,GROUP BY会将值转换为大写,以便进行分组,因此可能需要使用%Exact排序规则来保留插入值的字母大小写。...可以使用包含所有字段名(不包括RowID)的列表的INSERT SELECT将数据复制到重复表中。 但是,如果Source有一个外键public RowID,则不会为目标表保留外键关系。

    3.4K20

    MySQL从删库到跑路_高级(一)——数据完整性

    2、主键 MySQL的主键名总是PRIMARY, 当创建主键约束时,如果表的存储引擎是innoDB,系统默认会在所在的列和列组合上建立对应的唯一索引。...index uc_sname; 三、域完整性 1、默认值 在表中插入一条新的记录时,如果没有为该字段赋值,那么数据库系统会自动为该字段赋一条默认值。...四、参照完整性 1、参照完整性简介 MySQL参照完整性一般是通过MySQL外键(foreign key)实现的。 外键(仅innoDB支持)所引用表的列必须是主键。...在score表创建的参照完整性,删除动作和更新动作的参照动作选择了cascade(级联操作),当学生表的sid更新时,分数表score的相应的sid也会更新,当学生被删除,分数表对应的sid的记录也会自动删除...将子表上匹配记录的列设为null ,要注意子表的外键列不能为not null。

    1.9K20

    程序员面试备战篇:18个经典MySQL面试专题解析(干货分享答案)

    有外键约束会影响插入和删除性能,如果程序能够保证数据的完整性,那在设计数据库时就去掉外键。 表中允许适当冗余,譬如,主题帖的回复数量和最后回复时间等4....主服务器将更新写入二进制日志文件,并维护文件的一个索引以跟踪日志循环。这些日志可以记录发送到从服务器的更新。当一个从服务器连接主服务器时,它通知主服务器在日志中读取的最后一次成功更新的位置。...当需要查询大字段时,此时的关联查询是不可避免的,但也是值得的。...query cache 中去匹配,如果没有匹配中,则将这个hash 值存放在一个 hash 链表中,同时将 query 的结果集存放进cache 中,存放 hash 值的链表的每一个 hash 节点存放了相应...17.MySQL 当记录不存在时 insert,当记录存在时 update,语句怎么写?

    1.7K00
    领券