登录
首页 >  数据库 >  MySQL

想起啥写啥

来源:SegmentFault

时间:2023-01-22 16:50:41 287浏览 收藏

亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《想起啥写啥》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下MySQL、Java、spring、springboot,希望所有认真读完的童鞋们,都有实质性的提高。

java中线程创建方式
1、继承Thread类:重写run方法并调用start方法
2、实现Runnable接口:重写run方法,创建实现Runnable接口的子类对象,并创建Thread类,调用start方法
3、实现callable接口:重写call方法,创建Excutors线程池,提交程序,接受返回值并抛出异常,关闭服务完成线程使用;
线程的五种状态
1、新生状态:new出来新的线程
2、就绪状态:调用start方法进入就绪状态,此时的线程并没有被执行,而是等待cpu调度
3、运行状态:cpu调度线程进入运行状态,开始执行代码
4、阻塞状态:当线程调用sleep方法或者wait方法的时候会进入阻塞状态,此时的线程停止运行,进入就绪状态等待cpu调度;
5、死亡状态:当线程运行结束就进入死亡状态,或者调用stop方法使线程进入死亡状态,此时的状态不能被cpu再次调度
数据库事务的ACID特性
原子性:要么全部执行成功要么全部执行失败
一致性:指数据得规则,执行前/后保持一致
隔离性:某个事务的操作对其他事务是不可见的
持久性:事务一旦提交后,其影响应该保存下来,不能撤销
事务的隔离性
数据库系统必须具有隔离并发运行各个事务的能力, 使它们不会相互影响, 避免各种并发问题。一个事务与其他事务隔离的程度称为隔离级别. 数据库规定了多种事务隔离级别, 不同隔离级别对应不同的干扰程度, 隔离级别越高, 数据一致性就越好, 但并发性越弱。

Oracle 支持的 2 种事务隔离级别:READ COMMITED, SERIALIZABLE. Oracle 默认的事务隔离级别为: READ COMMITED

Mysql 支持 4 中事务隔离级别. Mysql 默认的事务隔离级别为: REPEATABLE-READ

每启动一个 mysql 程序, 就会获得一个单独的数据库连接. 每个数据库连接都有一个变量 @@tx_isolation, 表示当前的事务隔离级别.

查看当前的隔离级别: SELECT @@tx_isolation;

查看全局的隔离级别:select @@global.tx_isolation;

设置当前 mySQL 连接的隔离级别: set tx_isolation ='repeatable-read';

设置数据库系统的全局的隔离级别: set global tx_isolation ='read-committed';

数据库隔离级别

Read uncommitted 读未提交:READ UNCOMMITTED级别忽略其它事务放置的锁。使用READ UNCOMMITTED级别运行的事务,能够读取尚未由其它事务提交的改动后的数据值,这些行为称为“脏”读。我们所说的脏读,两个并发的事务,事务A可以读取到事务B未提交的数据。假设事务A回滚,事务B就读取了一行没有提交的数据。这种数据我们觉得是不存在的。

Read committed 读提交:一个事务只能读取另一个事务已经提交的修改。其避免了脏读,但仍然存在不可重复读和幻读问题。大多数数据库的默认级别就是Read committed。比方Sql Server , Oracle。

Repeatable read 反复读:该级别指定了在当前事务提交之前,其它不论什么事务均不能够改动或删除当前事务已读取的数据。并发性低于 READ COMMITTED。由于已读数据的共享锁在整个事务期间持有,而不是在每一个语句结束时释放。这个隔离级别仅仅是说,不可以改动和删除,可是并没有强制不能插入新的满足条件查询的数据行。所以会产生“幻读”;Mysql的默认隔离级别就是Repeatable read

Serializable 串行读:完全串行化的读,每次读都需要获得表级共享锁,读写相互都会阻塞

数据库引擎

image.png

今天带大家了解了MySQL、Java、spring、springboot的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表