【JavaEE】Spring事务-@Transactional参数介绍-事务的隔离级别以及传播机制

【JavaEE】Spring事务(2)

在这里插入图片描述

文章目录

  • 【JavaEE】Spring事务(2)
    • 1. @Transactional 参数介绍
      • 1.1 value 和 transactionManager
      • 1.2 timeout
      • 1.3 readOnly
      • 1.4 后面四个
      • 1.5 isolation 与 propagation
    • 2. Spring 事务隔离级别 - isolation
      • 2.1 MySQL事务隔离级别
      • 2.2 MySQL默认有没有解决幻读
      • 2.3 Spring的五种事务隔离级别
    • 3. Spring 事务传播机制 - propagation
      • 3.1 事务传播机制是什么?
      • 3.2 为什么需要事务传播机制?
        • 3.2.1 事务隔离级别
        • 3.2.2 事务传播机制
      • 3.3 Spring 事务的七种事务传播机制
        • 3.3.1 propagation的七个取值
        • 3.3.2 propagation的七个取值各自的作用
      • 3.4 支持当前事务的三种传播机制
        • 3.4.1 REQUIRED
        • 3.4.2 REQUIRED例子
        • 3.4.3 SUPPORTS
        • 3.4.4 SUPPORTS例子
        • 3.4.5 MANDATORY
        • 3.4.6 MANDATORY例子
      • 3.5 不支持当前事务的三种传播机制
        • 3.5.1 REQUIRES_NEW
        • 3.5.2 NOT_SUPPORTED 与 NEVER
      • 3.6 嵌套事务
        • 3.6.1 NESTED
        • 3.6.2 NESTED例子
        • 3.6.3 加入事务和嵌套事务的区别
        • 3.6.4 嵌套事务的逻辑(加入事务和嵌套事务的区别:有无保存点)

【JavaEE】Spring事务(2)

1. @Transactional 参数介绍

参数作用
value当配置了多个事务管理器时,可以使用该属性指定选择哪个事务管理器
transactionManager当配置了多个事务管理器时,可以使用该属性指定选择哪个事务管理器
isolation事务的隔离级别.默认值为solation.DEFAULT
propagation事务的传播机制,默认值为 Propagation.REQUIRED
timeout事务的超时时间,默认值为-1.如果超过该时间限制但事务还没有完成,则自动回滚事务
readOnly指定事务是否为只读事务,默认值为 false;为了忽略那些不需要事务的方法,比如读取数据,可以设置read-only为 true.
rollbackFor用于指定能够触发事务回滚的异常类型,可以指定多个异常类型
rollbackForClassName用于指定能够触发事务回滚的异常类型,可以指定多个异常类型
noRollbackFor抛出指定的异常类型,不回滚事务,也可以指定多个异常类型
noRollbackForClassName抛出指定的异常类型,不回滚事务,也可以指定多个异常类型

1.1 value 和 transactionManager

其实默认就是一个Spring事务管理器,但是如果你是多个数据源等情况下,是可能用到多个事务管理器的,所以要使用哪个事务管理器,用这两个属性来区分(两个的作用一致,同时存在就是为了保证兼容性呗)

目前只看作只有一个事务管理器,之后遇到再说~

1.2 timeout

指定超时时间:

  1. 默认为-1,即没有时间限制
  2. 指定时间(/s)后,超过时间限制事务就会强制回滚

1.3 readOnly

  1. false => 不是只读事务
  2. true => 是只读事务
    • 此时若要进行写的操作,会出现错误
    • 只读事务内,同一个查询方法的多次调用查询结果一致,不会读取到其他事务修改的数据

只是读操作的话,其实不需要回滚,但是又需要配合一些事务的传播行为以及保证一些查询结果一致性,就可以设置为true去优化性能,了解即可

1.4 后面四个

无非就是:

  1. 指定捕获的异常的类对象,只有捕获对应的异常才能回滚
  2. 指定捕获的异常的类名称,只有捕获对应的异常才能回滚
  3. 指定捕获的异常的类对象,捕获对应的异常不能回滚
  4. 指定捕获的异常的类名称,捕获对应的异常不能回滚

并且可以传数组…

1.5 isolation 与 propagation

  1. isolation 事务的隔离级别
  2. propagation 事务的传播机制

随后重点讲解

2. Spring 事务隔离级别 - isolation

在这里插入图片描述

Spring设置事务隔离解绑是通过@Transactional的isolation属性,并且用Isolation枚举类去访问设置常量

在这里插入图片描述

2.1 MySQL事务隔离级别

  1. READ UNCOMMITTED:读未提交
  2. READ COMMITTED:读已提交
  3. REPEATABLE READ:可重复读,是 MySQL 的默认事务隔离级别
  4. SERIALIZABLE:序列化

补充说明:本文一些具体细节就不讲了,比如MySQL的知识

  • 脏读:一个事务读取到了另⼀个事务修改的数据之后,后⼀个事务又进行了回滚操作,从而导致第⼀个事务读取的数据是错误的。
  • 不可重复读:⼀个事务两次查询得到的结果不同,因为在两次查询中间,有另⼀个事务把数据修改了。
  • 幻读:⼀个事务两次查询中得到的结果集不同,因为在两次查询中另⼀个事务有新增了⼀部分数据。

四种隔离级别对着三种情况的应对情况是这样的:

事务隔离级别(isolation)脏读问题不可重复读问题幻读
READ UNCOMMITTED:读未提交没有解决没有解决没有解决
READ COMMITTED:读已提交解决没有解决没有解决
REPEATABLE READ:可重复读解决解决有解决,但没完全解决
SERIALIZABLE:序列化解决解决解决

MySQL默认:select @@global.tx_isolation,@@tx_isolation;

在这里插入图片描述

2.2 MySQL默认有没有解决幻读

有,但是没有彻底解决

对于MySQL默认是RR(REPEATABLE READ:可重复读)+ MVCC(Multi-VersionConcurrency Control:多版本并发控制) 去解决幻读的,对于

  • 快照读:MVCC解决得了幻读
  • 当前读:MVCC解决不了,得加锁

所以要想彻底解决幻读:

  1. 串行化
  2. MVCC + 锁

2.3 Spring的五种事务隔离级别

其实其中四种跟MySQL一致:

在这里插入图片描述

而多了的一种就是DEFAULT:含义就是,以配置的数据库的全局事务隔离级别为准~

@Transactional(isolation = Isolation.DEFAULT)
//默认设置
  • 如果是MySQL的话,就是RR
  • 如果设置了隔离级别(isolation = …),且数据库支持的话,这个"局部"事务临时以这个隔离级别为准

网络资料:

如果使用@Transactional注解**设置了一个在当前数据库中不支持的隔离级别**,会发生下列情况之一:

  1. 编译错误:编译过程中可能会出现错误,指示该隔离级别不可用。
  2. 运行时异常:编译器无法在编译时捕获到错误,那么在运行时可能会抛出异常。具体的异常类型和处理方式取决于使用的事务管理框架和数据库驱动程序。

通常情况下,当设置了一个不支持的隔离级别时,事务管理框架会尝试使用一个与之最接近的可用隔离级别。例如,假设设置的隔离级别是"SERIALIZABLE"

  • 但数据库只支持"READ_COMMITTED"和"REPEATABLE_READ"两个隔离级别。在这种情况下,事务管理框架可能会自动选择使用"REPEATABLE_READ"作为隔离级别。

  • 但是需要注意的是,不同的事务管理框架和数据库驱动程序的行为可能会有所不同。因此,建议在设置隔离级别之前,先了解所使用的数据库是否支持所需的隔离级别,并确保事务管理框架和数据库驱动程序的兼容性。

3. Spring 事务传播机制 - propagation

3.1 事务传播机制是什么?

Spring 事务传播机制定义了多个事务的方法,相互调用时,事务是如何在这些方法之间进行传递的

传播行为定义了事务方法之间的事务边界,控制着事务方法在调用过程中对事务的影响

不必纠结传播这个资源,它就只是个词语罢了,其含义就是 事务方法被调用时进行的“行为逻辑”

  • propagation传播就是事务扩展嘛,就是因为调用了方法,事务就要扩展(你可以理解为调用者事务和被调用者事务是extends的关系)了,要怎么扩展(事务之间的继承规则是咋样的)就是行为逻辑的机制咯

3.2 为什么需要事务传播机制?

3.2.1 事务隔离级别

事务隔离级别解决的问题是多个事务同时调用数据库的问题,即并发事务执行的可控性和稳定性:

在这里插入图片描述

3.2.2 事务传播机制

事务传播机制解决的则是保证了一个事务在多个调用方法的可控性和稳定性

举一个例子,事务A调用事务B,那么整体看成一个事务呢,还是分开来看,还是要咋样咋样,这些都是要规定的,而我们就是通过设置一个事务的传播机制,去控制,达到我们想要的效果~

在这里插入图片描述

3.3 Spring 事务的七种事务传播机制

3.3.1 propagation的七个取值

在这里插入图片描述

一样的,Propagation也是个枚举类型,通过访问其内部常量来给propagation赋值:

在这里插入图片描述

Spring事务的默认值为:Propagation.REQUIRED

@Transactional(propagation = Propagation.REQUIRED)
// 默认设置

3.3.2 propagation的七个取值各自的作用

propagation作用
REQUIRED默认的事务传播级别,它表示如果当前存在事务,则加入该事务;如果当前没有事务,则创建⼀个新的事务。
SUPPORTS如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务的⽅式继续运行。
MANDATORY(mandatory:强制性)如果当前存在事务,则加入该事务;如果当前没有事务,则抛出异常。
REQUIRES_NEW表示创建⼀个新的事务,如果当前存在事务,则把当前事务挂起。也就是说不管外部方法是否开启事务,Propagation.REQUIRES_NEW 修饰的内部方法会新开启自己的事务,且开启的事务相互独立,互不干扰。
NOT_SUPPORTED以非事务方式运行,如果当前存在事务,则把当前事务挂起。
NEVER以非事务方式运行,如果当前存在事务,则抛出异常。
NESTED如果当前存在事务,则创建⼀个事务作为当前事务的嵌套事务来运行;如果当前没有事务,则该取值等价于 PROPAGATION_REQUIRED。

对于七种传播机制,可以分为三类:

  1. 支持当前事务
    • REQUIRED(没事务我就造,有事务我就入)
    • SUPPORTS(没事务我就摆)
    • MANDATORY(没事务我就闹)
  2. 不支持当前事务(不常使用)
    • REQUIRES_NEW
    • NOT_SUPPORTED
    • NEVER
  3. 嵌套事务
    • NESTED

非事务方式运行代表的含义就是,这个方法不是个事务,但是参与了事务传播机制的逻辑规范

3.4 支持当前事务的三种传播机制

3.4.1 REQUIRED

@Transactional(propagation = Propagation.REQUIRED)
public void methodA() {// 代码逻辑
}

methodA()方法使用REQUIRED传播机制

  1. 当该方法被调用时,如果当前已存在一个事务,则methodA()将会使用该事务,或者说是加入该事务(融合成一个大事务)
  2. 如果没有事务,则会为methodA()创建一个新的事务

3.4.2 REQUIRED例子

在这里插入图片描述

在这里插入图片描述

调用链就是这样的:

在这里插入图片描述

没有报异常的现象:

在这里插入图片描述

在这里插入图片描述

在insert方法返回前加异常:

在这里插入图片描述

控制台:

在这里插入图片描述

在这里插入图片描述

无新增,代表已回滚

验证,不存在事务也可以创建:

在这里插入图片描述

效果:

在这里插入图片描述

控制台:

在这里插入图片描述

在这里插入图片描述

无新增

3.4.3 SUPPORTS

@Transactional(propagation = Propagation.SUPPORTS)
public void methodB() {// 代码逻辑
}

methodB()方法使用SUPPORTS传播机制

  1. 当该方法被调用时,如果当前已存在一个事务,则methodB()将会使用该事务
  2. 如果没有事务,则以非事务的方式执行。

3.4.4 SUPPORTS例子

在这里插入图片描述

存在事务的情况效果:

在这里插入图片描述

在这里插入图片描述

无新增

不存在事务的情况:

在这里插入图片描述

效果:

在这里插入图片描述

在这里插入图片描述

新增数据,代表回滚失败

补充一点,你会发现一些id不连续,其实就是因为空着的id加过了,只不过被回滚了

分析:

  • add在执行的时候,当前没有事务,摆烂~
  • testService.add在执行的时候,当前没有事务,摆烂~
  • insert在执行的时候,当前没有事务,摆烂~

一开始没有事务,最终导致,这些“妈宝”一个都不创建事务,没有事务自然就没有回滚

3.4.5 MANDATORY

@Transactional(propagation = Propagation.MANDATORY)
public void methodC() {// 代码逻辑
}

methodC()方法使用MANDATORY传播机制

  1. 当该方法被调用时,如果当前已存在一个事务,则methodC()将会使用该事务
  2. 如果没有事务,则会抛出异常
    • 不要纠结这个异常抛出没有回滚的问题,因为事务压根没开始,有啥好回滚的,所以抛出异常没啥坏影响,就是规范作用

3.4.6 MANDATORY例子

在这里插入图片描述

在这里插入图片描述

效果:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

无新增

报异常情况的演示:

在这里插入图片描述

效果:

在这里插入图片描述

  • 这里的异常就不是算术异常了

在这里插入图片描述

压根没添加进入那两个方法,自然没有添加数据

在这里插入图片描述

3.5 不支持当前事务的三种传播机制

3.5.1 REQUIRES_NEW

@Transactional(propagation = Propagation.REQUIRES_NEW)
public void methodD() {// 代码逻辑
}

methodD()方法使用REQUIRES_NEW传播机制

  • 当该方法被调用时,将会为methodD()创建一个新的事务,并挂起当前事务(如果存在)
  • 事务被挂起:事务停止,等待新事物执行完此事务才能继续执行

不存在的话,就是简单的创建一个事务~

3.5.2 NOT_SUPPORTED 与 NEVER

@Transactional(propagation = Propagation.NOT_SUPPORTED)
public void methodE() {// 代码逻辑
}
@Transactional(propagation = Propagation.NEVER)
public void methodF() {// 代码逻辑
}

methodE()方法使用NOT_SUPPORTED传播机制

  • 当该方法被调用时,会以**非事务的方式执行操作**,并在执行期间挂起当前事务(如果存在)。

methodF()方法使用NEVER传播机制

  • 当该方法被调用时,会以**非事务的方式执行操作**,并在执行期间如果存在事务,则抛出异常。

非事务方式运行代表的含义就是,这个方法不是个事务,但是参与了事务传播机制的逻辑规范


不支持当前事务的这三种传播机制,存在即合理,只是那种情景我们还没遇到呢~

  • 这里不做代码演示,感兴趣的同学可以去了解!

3.6 嵌套事务

3.6.1 NESTED

@Transactional(propagation = Propagation.NESTED)
public void methodG() {// 代码逻辑
}

methodG()方法使用NESTED传播机制

  1. 当该方法被调用时,如果当前存在事务,则在嵌套事务内执行
  2. 如果没有事务,则创建一个新的事务,跟默认的REQUIRED一样~

3.6.2 NESTED例子

在这里插入图片描述

调用链是这样的:

在这里插入图片描述

在这里插入图片描述

  • 异常注意处理哦,否则add方法也会感应到异常,导致外部事务回滚~

效果:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

只增加了一条~

  • 代表insert方法是回滚了的,而testService方法事务提交成功
  • 而insert也是有返回值的,因为try后的代码还是会继续运行

3.6.3 加入事务和嵌套事务的区别

在前面加入事务的例子可以看出,加入事务就相当于融合成大事务,看成一个整体,在任何一个地方回滚,影响的都是全部(不再做演示)

而嵌套事务NEXTED,则允许整个事务,部分事务回滚(允许部分代码失败)

  1. 如果你希望内部方法能够独立于外部事务进行回滚
    • 可以选择 Propagation.NESTED
  2. 如果你希望内部方法与外部事务一同回滚或提交
    • 可以选择 Propagation.REQUIRED
  3. 整个事务如果全部执行成功,⼆者的结果是⼀样的。

嵌套这个词就体现在这特性:

  1. 内部事务回滚,不会导致外部事务也回滚
  2. 外部事务回滚,内部事务会收到牵连

内部事务就是个部件吧,相对于整个事务

加入事务:

在这里插入图片描述

嵌套事务:

在这里插入图片描述

3.6.4 嵌套事务的逻辑(加入事务和嵌套事务的区别:有无保存点)

可以将嵌套事务理解为“尝试”的动作,这个方法失败了就失败了,没关系,咱还是一条好汉~

嵌套事务之所以能够实现部分事务的回滚,是因为事务中有⼀个保存点(savepoint)的概念:

  • 嵌套事务进入当前事务之后相当于新建了⼀个保存点
  • 而滚回时只回滚到当前保存点,因此之前的事务是不受影响的

在这里插入图片描述

实心黑点就相当于保存点~

REQUIRED 是加⼊到当前事务中,并没有创建事务的保存点,因此出现了回滚就是整个事务回滚, 这也是嵌套事务和加入事务的区别

官方文档:MySQL :: MySQL 5.7 Reference Manual :: 13.3.4 SAVEPOINT, ROLLBACK TO SAVEPOINT, and RELEASE SAVEPOINT Statements


文章到此结束!谢谢观看
可以叫我 小马,我可能写的不好或者有错误,但是一起加油鸭🦆

代码:事务/src/main · 游离态/马拉圈2023年8月 - 码云 - 开源中国 (gitee.com)

实际情况可能简单,也可能复杂,希望你能通过已学知识去“排列组合”,去实现和分析!


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/1619656.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

房屋中介费怎么收取才合理?快看看别再花冤枉钱了

[摘要]本文讲述了什么是房屋中介,房屋中介费是如何收取的,房屋中介费的收取标准是什么。希望可以对即将用到房屋中介的网友们有所帮助。 买房的朋友都应该知道有房产中介这回事,甚至有的是通过房产中介的服务来买的房,当然&#x…

基于C#的房屋租赁管理系统设计与实现

目录 第一章 引言 3 第二章 系统分析与设计 4 2.1 需求分析 4 设计流程图: 4 2.2数据库概念结构设计 5 E-R图 5 2.3数据库的创建 6 管理员表: 6 房屋表: 7 用户信息表: 7 房屋租贷表: 7 财务报表: 7 收费标…

设计模式.中介者模式Mediator

定义 中介者模式(Mediator pattern) : 使用中介者模式来集中相关对象之间复杂的沟通和控制方式,使得这些对象不必相互明显引用。从而使它们可以较松散地耦合。当这些对象中的某些对象之间的相互作用发生改变时,不会立即影响到其他的一些对象之间的相互作…

C++课程设计 房产中介管理系统(代码全)

目录表 1 需求分析**主函数:调用创建的各种类和方法**交易类:交易的实现房屋类:主要管理房屋信息房主信息:管理房屋主人的信息房主的实现:看房信息:存储有人想去实地看房的信息,预约等看房信息的…

房屋中介费收取标准有?详细的房屋中介费收取标准。

[摘要]如果购房者在买房的一定过程中,你选择找了中介,对购房会有便利的一方面,但是房屋中介费收取标准是什么呢?你了解房屋中介费收取标准吗?来了解房屋中介费收取标准吧。如果你选择了中介公司,可以参考条…

基于Linux操作系统的keepalived双机热备和keepalived+lvs(DR)基本配置操作

目录 keepalived双机热备 一、概述 (一)具体工作原理如下: (二)实验拓补 二、安装NFS、配置 1、第一台机器配置:NFS :192.168.11.101 2、更改配置文件 3、安装NFS进行目录共享 4、编辑…

应不应该收取房屋中介费用?房屋中介费用收取合理吗

[摘要]近年来不少人选择通过中介机构完成房屋买卖,那房屋中介费用是怎么收取的?房屋中介费用收取的标准是什么?交了房屋中介费用就可以安枕无忧了吗?但实际中,有一些中介机构的服务质量和效果良莠不齐,购房的情况也是千变万化,导致纠纷不断。 近年来不少人选择通过中介机构完…

基于NodeJS+VUE房屋中介管理系统的设计与实现

当今社会房屋租赁买卖是必不可少的,人们不管走到哪里都需要有一个温馨的家,有一个落脚之地,所以房屋租赁市场也是非常火爆!不管是房屋中介公司或者是个人都需要一套完整的管理系统来掌握整个市场信息。针对这一需求,本…

【全源码及文档】基于Java面向对象开发的房屋中介管理系统

摘 要 现代的房产市场愈加复杂化,用软件来管理房产中介管理系统的开发与设计及自动匹配等功能,在实际运用中起到极大的帮助作用。 随着房地产业的飞速发展,待交易房屋的数量大幅度提高,传统手工处理为主的房屋管理方式存在着工作…

[附源码]计算机毕业设计JAVA房屋中介管理系统

[附源码]计算机毕业设计JAVA房屋中介管理系统 项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybati…

[附源码]java毕业设计房屋中介管理系统

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

【河北建筑工程学院毕业论文】房屋中介公司网站的设计与实现

摘 要 随着计算机行业的不断发展,计算机的应用也随着行业发展的速度而不断更新。如今,在网络应用非常广泛的社会中,房屋中介公司的网站功能要求更加严格,所以一个好的系统对于房屋中介公司的网站来说非常重要。 本文详细介绍了房…

帝国CMS仿管理资源吧资料下载网站模板源码/下载会员+积分付费下载功能自动采集资源网站源码

帝国CMS仿管理资源吧资料下载网站模板源码,带下载会员积分付费下载功能自动采集资源网站源码,管理资源吧——为中小企业管理者提供全方位的管理资料下载服务;是一个所有资料免费下载,免注册、免登陆、免积分的公益性的管理知识共享…

pycharm 右键运行代码时总是测试模式运行(run pytest)

*# 问题 使用pycharm时,右键运行代码,结果是这样的: 运行_‘pytesr(xxx.py 内)’ 英语界面可能是这样:run_‘pytesr(xxx.py)’我并不想使用测试模式。如何改回正常模式? 解决办法 本着遇到什么问题就搜什么问题的态…

Nanoprobes艾美捷氟纳米金 结合物

Nanoprobes艾美捷荧光标签纳米金-共价键合,让你的目标在几乎任何显微镜下都可见! 像以前一样查看目标的荧光标签再加上光学显微镜上的纳米金标签,甚至是EM共焦、光学显微镜和EM之间的相关性: 1.可方便地与二级抗体(或…

MAL-Gold Nanoparticle/Au nanoparticles纳米金颗粒/金纳米粒子|50nm浓度:0.5mg/ml

MAL-Gold Nanoparticle/Au nanoparticles纳米金颗粒/金纳米粒子|50nm浓度:0.5mg/ml 别称:MAL-Gold Nanoparticle/Au nanoparticles纳米金颗粒/金纳米粒子 【成分】金纳米颗粒、超纯水 【性状】金纳米颗粒的水溶液随粒径不同呈现橙红、红、紫红等颜色 …

介孔二氧化硅包裹超顺磁性Fe3O4纳米颗粒表面氨基修饰|齐岳生物

介孔二氧化硅包裹超顺磁性Fe3O4纳米颗粒表面氨基修饰|齐岳生物 由于纳米四氧化三铁(VK-EF01, VK-EF02) 特殊的理化学性质, 使其在实际应用中越来越广泛, 其制备方法和性质的研究也得到了深入的进展。 磁性纳米微粒的制备方法主要有物理方法和化学方法。…

金纳米颗粒修饰二氧化硅纳米片AuNPs-SiO2,金纳米棒表面包覆薄纳米二氧化硅

产品名称:金纳米颗粒修饰二氧化硅纳米片AuNPs-SiO2,金纳米棒表面包覆薄纳米二氧化硅 产地:西安 规格:1mg 5mg 10mg 纯度:99% 金纳米棒表面包覆薄纳米二氧化硅是一种在纳米技术领域中常见的复合材料。让我为您解释一…

异形双柱体阵列纳米粒:针状/花状纳米粒子/纳米金星/金笼/金壳/三角形纳米金

今天瑞禧生物小编给大家分享的内容是异形双柱体阵列纳米粒:针状/花状纳米粒子/纳米金星/金笼/金壳/三角形纳米金的相关内容,和小编一起来看! 在磁性材料方面有许多应用,例如:可以用纳米粒子作为永久磁体材料&#xff0…

共聚物/化合物/聚合物纳米胶束/官能团修饰二氧化硅纳米颗粒

小编这里给大家整理了共聚物/化合物/聚合物纳米胶束/官能团修饰二氧化硅纳米颗粒的应用,来看! 共聚物修饰二氧化硅纳米粒子的应用: 介孔二氧化硅纳米粒子(MSNs)作为药物载体在生物医学方面的潜在应用价值吸引了越来越多的关注.MSNs具有均一的…