likes
comments
collection
share

想起啥写啥

作者站长头像
站长
· 阅读数 31

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 串行读:完全串行化的读,每次读都需要获得表级共享锁,读写相互都会阻塞

数据库引擎

想起啥写啥