- SpringBoot + MyBatis 事务管理全解析:从 @Transactional 到 JDBC Connection 的旅程
coderzpw
MybatisSpring系列springbootmybatisjava
SpringBoot+MyBatis事务管理全解析:从@Transactional到JDBCConnection的旅程一、JDBCConnection:事务操作的真正执行者1.1数据库事务的本质1.2Spring与Connection的协作流程二、从@Transactional到JDBCConnection的完整链路2.1Spring中TransactionInterceptor的核心逻辑2.2T
- springboot中@Transactional注解的使用
风也温柔1
springbootspringboot后端java
1、引入依赖首先,确保你的SpringBoot项目中包含了对事务支持的依赖。对于大多数应用场景,SpringBoot会自动引入事务管理相关的依赖。但如果你需要手动添加,可以检查spring-boot-starter-data-jpa(针对JPA)或spring-boot-starter-jdbc(针对JDBC)等起步依赖是否已经存在于你的pom.xml或build.gradle文件中。2、使用@T
- 实战|StarRocks 通过 JDBC Catalog 访问 MongoDB 的数据
方案介绍本文档介绍如何通过StarRocks的JDBCCatalog功能,结合MongoDBBIConnector,将MongoDB数据便捷接入StarRocks,实现数据打通和SQL查询分析,以下是整体流程图。前提条件StarRocks环境:版本≥3.0,支持JDBCCatalog功能。MongoDBBIConnector:已安装并运行,版本需与MongoDB兼容(参考MongoDB官方文档)。
- OceanBase批量插入数据报错java.lang.ArrayIndexOutOfBoundsException:0
二宝哥
oceanbasejava开发语言
OceanBase数据库MySQL模式,插入数据报错,直接首先换了连接池,插入数据成功。参考文章:com.mysql.cj.jdbc.result.ResultSetMetaData.getCloumnType(ResultSetMetaData.java:188)空指针-CSDN博客批量插入数据时,报错如下:OceanBase社区中搜索批量插入报错,出现“ArrayIndexOutOfBound
- SpringBoot-jdbcTemplate访问数据库
xiatianit
springbootspringboot数据库java
在实际的企业级应用开发中,却很少有人直接使用原生的JDBCAPI进行开发,这是因为使用JDBCAPI对数据库进行操作十分繁琐,需要我们对每一步都做到“步步把控,处处关心”,例如我们需要手动控制数据库连接的开启,异常处理、事务处理、最后还要手动关闭连接释放资源等等。Spring提供了一个SpringJDBC模块,它对JDBCAPI进行了封装,其的主要目的降低JDBCAPI的使用难度,以一种更直接、更
- spring —— 使用 JDBCTemplate 对数据库操作
张民遇
spring数据库springoracle
在传统方法中,我们一般建立Connection链接,然后通过Statementstm=conn.createStatement()来获取Statement对象,最后用Statement对象操作数据库。在spring中,则是通过com.alibaba的druid配置数据源工具,来配置要连接的数据库,然后将配置好的数据源作为属性传入JDBCTemplate对象当中,最后用JDBCTemplate对象操
- 一个非常好用的快速生成数据库表映射工具-Screw
qq_21526409
数据库java
将数据库的表结构生成文档需要引入的依赖org.springframework.bootspring-boot-starter-jdbcorg.springframework.bootspring-boot-starter-testtestcn.smallbun.screwscrew-core1.0.5com.zaxxerHikariCP5.1.0测试代码importcn.smallbun.scre
- Java web%10
好学且牛逼的马
java前端AI编程
%10新路线Javawebai笔记阶段时长内容Web前端基础2天HTML、CSS、JS、Vue3、AjaxWeb后端基础4天Maven、HTTP协议、SpringIOC、DI、MySQL、JDBC、MybatisWeb后端实战6天Tlias案例(基于案例讲解web开发的核心知识)Web后端进阶2天SpringAOP、SpringBoot原理、自定义Starter、Maven高级前端web实战4天V
- 2.jdbc之工具类,SQL注入攻击和JDBC事务
hutc_Alan
sqljava数据库
4.JDBC工具类抽取工具类1)编写配置文件在src目录下创建config.properties配置文件driverClass=com.mysql.cj.jdbc.Driverurl=jdbc:mysql://192.168.1.224:3306/db14username=rootpassword=1234562)编写jdbc工具类utils文件下(JDBCUtils.java)packagejd
- mysql之jdbc连接数据库和sql注入的问题
一,概述可能是自己的记忆力太差了,经常忘记一些很重要的知识点,记得个大概,等要用的时候就去找,结果还找不到。干脆,记博客里,怎么都找的到。这篇博客主要就是关于Jdbc(javadatabaseconnectivity)和MySql的,记录如何连接数据库及插入数据等等。二,工具及准备工作MyEclipse10,mysql驱动jar包(我用的是这个版本mysql-connector-java-5.0.
- JDBC工具类
小布不吃竹
数据库java
目录引言一、JDBC连接数据库步骤1.加载驱动2.获取连接(URL用户名密码)3.编写sql4.获取执行sql的stmt的对象5.执行sql拿到结果集6.遍历结果集7.关闭资源(先开的后关后开的先关)二、JDBC工具类版本一:基础JDBC工具类(JdbcUtils)版本二:配置化JDBC工具类(JdbcUtils2)版本三:连接池JDBC工具类(JdbcUtils3)测试总结引言JDBC(Java
- Mysql中是text,jdbcType对应类型及jdbcType与javaType对应关系
天宇_任
mybatisjava
如果Mysql中是text,则jdbcType对应LONGVARCHAR,javatype对应String
- Spring Boot 中@Value注解:看似便捷,实则暗藏玄机?
爆炸糖果
springboot后端java
一、引言在SpringBoot的开发旅程中,我们常常会与各种配置文件打交道,而@Value注解就像是一位贴心的小助手,为我们从配置文件中获取值提供了极大的便利。假设我们正在开发一个简单的用户管理系统,在application.yml文件中配置了数据库连接信息:spring:datasource:url:jdbc:mysql://localhost:3306/user_dbusername:root
- 分库分表之-ShardingJDBC技术详解
ShardingJDBC技术详解一、ShardingJDBC简介ShardingJDBC是一款轻量级的分布式数据库中间件,定位为在Java的JDBC层提供额外服务。它以客户端直连数据库的方式,以jar包形式提供服务,无需额外部署和依赖,可理解为增强版的JDBC驱动,完全兼容JDBC和各种ORM框架。适用于任何基于JDBC的ORM框架,如JPA、Hibernate、Mybatis、SpringJDB
- javaweb项目,mavenweb项目,springboot项目的区别
xrkhy
JavaWebSpringBootSSMspringboot后端java
文章目录一、项目定义与定位二、核心架构差异三、依赖管理机制四、项目结构与配置五、构建与部署流程六、适用场景推荐核心差异总结一、项目定义与定位JavaWeb项目基于原生JavaEE技术栈(Servlet/JSP/JDBC),依赖外部Web容器(如Tomcat)运行。需手动配置web.xml管理Servlet和过滤器,依赖库需下载后放入WEB-INF/lib目录。典型场景:传统企业级应用(如ERP系统
- Java:Spi 小实战
weixin_34248118
java数据库
背景Java中区分Api和Spi,通俗的讲:Api和Spi都是相对的概念,他们的差别只在语义上,Api直接被应用开发人员使用,Spi被框架扩张人员使用,详细内容可以看:http://www.cnblogs.com/happyframework/p/3325560.html。Java类库中的实例代码1Class.forName("com.mysql.jdbc.Driver");2Connection
- Java EDW三剑客:如何让数据从“沼泽”变身“报告神器”?手把手教你玩转企业数据仓库!
墨瑾轩
Java乐园java数据仓库开发语言
关注墨瑾轩,带你探索编程的奥秘!超萌技术攻略,轻松晋级编程高手技术宝库已备好,就等你来挖掘订阅墨瑾轩,智趣学习不孤单即刻启航,编程之旅更有趣一、你的EDW在“数据沼泽”里?是时候请个“数据炼金术士”了!“数据散落在10个系统里,生成月报要熬3个通宵?”——别慌!今天我们就用JDBC+ApacheSpark+Thymeleaf三剑客,教你如何让Java在EDW中将“数据沼泽”炼成“报告神器”!从“数
- Sharding-Sphere,Sharding-JDBC_介绍_Sharding-Sphere,Sharding-JDBC分布式_分库分表工作笔记001
添柴程序猿
技术交流QQ群【JAVA,C++,Python,.NET,BigData,AI】:170933152因为公司最近在做多租户的智慧城市相关的产品,这里,偶然看到这个框架,应该是可以用到,所以就看了一些,记录下来.先看一下我们要看的内容.去网站看看shardingsphere,是一套开源的分布式数据库中间件,解决方案包括3个产品点击了解更多去看一下
- 【NACOS更改源码支持达梦数据库 单机 集群】
张小白的 java笔记
java开发语言阿里云
1、下载源码我的是2.1.1版本的下载署说明上面的地址可以得到最新稳定版本的压缩包或者从github上下载2、添加达梦驱动的依赖最根部的pom文件修改nacos-2.1.1\pom.xml8.1.2.84com.damengDmJdbcDriver18${dm8-jdbc.version}3、修改nacos-2.0.3\config\pom.xmlcom.damengDmJdbcDriver184
- Spring Boot多数据源配置实战指南
代码的余温
springboot后端java
在SpringBoot中实现多数据源拆分,需根据业务需求(如读写分离、模块隔离、多租户等)选择合适的方案。以下是核心思路及实现方式:一、配置多个数据源在application.yml中为每个数据源定义独立配置:spring:datasource:primary:url:jdbc:mysql://localhost:3306/db1username:rootpassword:123456driver
- 【回顾原生JDBC手动管理事务以及两种方式实现Spring编程式事务】
无岸之舟
spring数据库java
文章目录一.关于事务1.事务概念2.事务四个基本特性3.事务的生命周期4.事务的隔离级别5.事务的应用场景二.回顾原生JDBC手动管理事务三.Spring编程式事务1.使用TransactionTemplate进行编程式事务管理2.使用PlatformTransactionManager进行编程式事务管理四.编程式事务的应用场景五.总结一.关于事务1.事务概念事务(Transaction)是数据库
- Spring JDBC和事务管理
小矮多
Spring框架springjava
SpringJDBC是Spring框架用来处理关系型数据库的模块,对JDBC的API进行了封装。SpringJDBC的核心类为JdbcTemplate,提供数据CRUD方法SpringJDBC使用步骤Maven工程引入依赖spring-jdbcorg.springframeworkspring-jdbc5.2.6.RELEASEmysqlmysql-connector-java8.0.27xml中
- Spring JDBC配置与使用
越来越无动于衷
springoracle数据库
SpringJDBCSpringJDBC框架负责所有的低层细节,从开始打开连接,准备和执行SQL语句,处理异常,处理事务,到最后关闭连接。大大简化了开发人员对数据库的操作,使得开发人员可以从繁琐的数据库操作中解脱出来,从而将更多的精力投入到编写业务逻辑中。Spring框架提供了JdbcTemplate类,该类是Spring框架数据抽象层的基础这是管理所有数据库通信和异常处理的中央框架类。JdbcT
- Spring JDBC 和事务控制
徐长卿@
笔记springjava后端
1.Spring整合JDBC环境Spring框架除了提供IOC与AOP核心功能外,同样提供了基于JDBC的数据访问功能,使得访问持久层数据更加方便。使用SpringJDBC环境,首先需要一套整合的Spring整合JDBC的环境。1.1添加依赖坐标4.0.0com.xxxSpringJDBC1.0-SNAPSHOTSpringJDBChttp://www.example.comUTF-81.71.7
- 第21~22周Java主流框架入门-Spring 3.SpringJDBC事务管理
SpringJDBC模块与事务管理课程总结1.课程介绍本课程主要讲解Spring框架中的JDBC模块及其事务管理的相关内容,重点包括以下三个方面:SpringJDBC模块及核心对象JDBCTemplate的使用通过学习如何使用SpringJDBC模块,了解JDBCTemplate的CRUD操作,并探索如何简化数据库操作。声明式事务的配置方式学习如何在Spring中进行声明式事务的配置,以实现对事务
- jdbc插入时获取自增id号
大海无量波涛凶
javaweb
//2.进行插入方法publicbooleancharu(ImageImage){booleanflag=false;//1.先连接数据库Connectionconnection=getCon();PreparedStatementpst=null;Stringsql="INSERTINTOtb_banqiimgs(img_name,img_path)values(?,?)";Integerent
- Mybatis获取新增记录(insert)的主键值
博风
#MySQL#OracleMybatisMySQLOracle数据库主键
Mysql、SQLServer:insertintobs_test(uuid,create_time,update_time,status,dm_desc,dm_desc2)values(#{uuid,jdbcType=VARCHAR},now(),now(),#{status,jdbcType=INTEGER},#{dmDesc,jdbcType=VARCHAR},#{dmDesc2,jdbcT
- SpringJDBC快速入门指南
Cyanto
Springoracle数据库spring
目录概要使用方法创建数据库和表添加依赖创建实体类在application当中配置数据库连接和jdbcTemplate创建类实现增删改查操作概要SpringJDBC是Spring所提供的持久层技术,负责数据库资源和错误处理,降低JDBCAPI的使用难度,以一种更简洁,更直接的方式使用JDBCAPI,大大简化了开发人员对数据库的操作。JdbcTemplate是spring框架中提供的一个对象,是对原始
- 各种数据库产品的细节比较
demon7552003
数据库数据库细节对比
JdbcUrlmysqlspring:datasource:type:com.zaxxer.hikari.HikariDataSourcedriver-class-name:com.mysql.cj.jdbc.Driverusername:xxxpassword:xxxurl:jdbc:mysql://192.168.1.54:3306/tmp?characterEncoding=utf8&zer
- 医院预约挂号系统源码_基于Java web的医院预约挂号系统
weixin_39668496
医院预约挂号系统源码
源码编号:B-E00011点击查看分类规则项目类型:JavaEE项目(javaweb项目)项目名称:基于javaweb的医院预约挂号系统(appointment-web)当前版本:V2.0.0版本难度等级:✩✩复杂程度:✩✩点击查看难度等级用户类型:单角色(只有管理员)设计模式:MVC(jsp+servlet+javabean)项目架构:B/S架构开发语言:Java语言主要技术:mvc、jdbc、
- java线程Thread和Runnable区别和联系
zx_code
javajvmthread多线程Runnable
我们都晓得java实现线程2种方式,一个是继承Thread,另一个是实现Runnable。
模拟窗口买票,第一例子继承thread,代码如下
package thread;
public class ThreadTest {
public static void main(String[] args) {
Thread1 t1 = new Thread1(
- 【转】JSON与XML的区别比较
丁_新
jsonxml
1.定义介绍
(1).XML定义
扩展标记语言 (Extensible Markup Language, XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。 XML使用DTD(document type definition)文档类型定义来组织数据;格式统一,跨平台和语言,早已成为业界公认的标准。
XML是标
- c++ 实现五种基础的排序算法
CrazyMizzz
C++c算法
#include<iostream>
using namespace std;
//辅助函数,交换两数之值
template<class T>
void mySwap(T &x, T &y){
T temp = x;
x = y;
y = temp;
}
const int size = 10;
//一、用直接插入排
- 我的软件
麦田的设计者
我的软件音乐类娱乐放松
这是我写的一款app软件,耗时三个月,是一个根据央视节目开门大吉改变的,提供音调,猜歌曲名。1、手机拥有者在android手机市场下载本APP,同意权限,安装到手机上。2、游客初次进入时会有引导页面提醒用户注册。(同时软件自动播放背景音乐)。3、用户登录到主页后,会有五个模块。a、点击不胫而走,用户得到开门大吉首页部分新闻,点击进入有新闻详情。b、
- linux awk命令详解
被触发
linux awk
awk是行处理器: 相比较屏幕处理的优点,在处理庞大文件时不会出现内存溢出或是处理缓慢的问题,通常用来格式化文本信息
awk处理过程: 依次对每一行进行处理,然后输出
awk命令形式:
awk [-F|-f|-v] ‘BEGIN{} //{command1; command2} END{}’ file
[-F|-f|-v]大参数,-F指定分隔符,-f调用脚本,-v定义变量 var=val
- 各种语言比较
_wy_
编程语言
Java Ruby PHP 擅长领域
- oracle 中数据类型为clob的编辑
知了ing
oracle clob
public void updateKpiStatus(String kpiStatus,String taskId){
Connection dbc=null;
Statement stmt=null;
PreparedStatement ps=null;
try {
dbc = new DBConn().getNewConnection();
//stmt = db
- 分布式服务框架 Zookeeper -- 管理分布式环境中的数据
矮蛋蛋
zookeeper
原文地址:
http://www.ibm.com/developerworks/cn/opensource/os-cn-zookeeper/
安装和配置详解
本文介绍的 Zookeeper 是以 3.2.2 这个稳定版本为基础,最新的版本可以通过官网 http://hadoop.apache.org/zookeeper/来获取,Zookeeper 的安装非常简单,下面将从单机模式和集群模式两
- tomcat数据源
alafqq
tomcat
数据库
JNDI(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API。
没有使用JNDI时我用要这样连接数据库:
03. Class.forName("com.mysql.jdbc.Driver");
04. conn
- 遍历的方法
百合不是茶
遍历
遍历
在java的泛
- linux查看硬件信息的命令
bijian1013
linux
linux查看硬件信息的命令
一.查看CPU:
cat /proc/cpuinfo
二.查看内存:
free
三.查看硬盘:
df
linux下查看硬件信息
1、lspci 列出所有PCI 设备;
lspci - list all PCI devices:列出机器中的PCI设备(声卡、显卡、Modem、网卡、USB、主板集成设备也能
- java常见的ClassNotFoundException
bijian1013
java
1.java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory 添加包common-logging.jar2.java.lang.ClassNotFoundException: javax.transaction.Synchronization
- 【Gson五】日期对象的序列化和反序列化
bit1129
反序列化
对日期类型的数据进行序列化和反序列化时,需要考虑如下问题:
1. 序列化时,Date对象序列化的字符串日期格式如何
2. 反序列化时,把日期字符串序列化为Date对象,也需要考虑日期格式问题
3. Date A -> str -> Date B,A和B对象是否equals
默认序列化和反序列化
import com
- 【Spark八十六】Spark Streaming之DStream vs. InputDStream
bit1129
Stream
1. DStream的类说明文档:
/**
* A Discretized Stream (DStream), the basic abstraction in Spark Streaming, is a continuous
* sequence of RDDs (of the same type) representing a continuous st
- 通过nginx获取header信息
ronin47
nginx header
1. 提取整个的Cookies内容到一个变量,然后可以在需要时引用,比如记录到日志里面,
if ( $http_cookie ~* "(.*)$") {
set $all_cookie $1;
}
变量$all_cookie就获得了cookie的值,可以用于运算了
- java-65.输入数字n,按顺序输出从1最大的n位10进制数。比如输入3,则输出1、2、3一直到最大的3位数即999
bylijinnan
java
参考了网上的http://blog.csdn.net/peasking_dd/article/details/6342984
写了个java版的:
public class Print_1_To_NDigit {
/**
* Q65.输入数字n,按顺序输出从1最大的n位10进制数。比如输入3,则输出1、2、3一直到最大的3位数即999
* 1.使用字符串
- Netty源码学习-ReplayingDecoder
bylijinnan
javanetty
ReplayingDecoder是FrameDecoder的子类,不熟悉FrameDecoder的,可以先看看
http://bylijinnan.iteye.com/blog/1982618
API说,ReplayingDecoder简化了操作,比如:
FrameDecoder在decode时,需要判断数据是否接收完全:
public class IntegerH
- js特殊字符过滤
cngolon
js特殊字符js特殊字符过滤
1.js中用正则表达式 过滤特殊字符, 校验所有输入域是否含有特殊符号function stripscript(s) { var pattern = new RegExp("[`~!@#$^&*()=|{}':;',\\[\\].<>/?~!@#¥……&*()——|{}【】‘;:”“'。,、?]"
- hibernate使用sql查询
ctrain
Hibernate
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import org.hibernate.Hibernate;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.Transa
- linux shell脚本中切换用户执行命令方法
daizj
linuxshell命令切换用户
经常在写shell脚本时,会碰到要以另外一个用户来执行相关命令,其方法简单记下:
1、执行单个命令:su - user -c "command"
如:下面命令是以test用户在/data目录下创建test123目录
[root@slave19 /data]# su - test -c "mkdir /data/test123" 
- 好的代码里只要一个 return 语句
dcj3sjt126com
return
别再这样写了:public boolean foo() { if (true) { return true; } else { return false;
- Android动画效果学习
dcj3sjt126com
android
1、透明动画效果
方法一:代码实现
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
{
View rootView = inflater.inflate(R.layout.fragment_main, container, fals
- linux复习笔记之bash shell (4)管道命令
eksliang
linux管道命令汇总linux管道命令linux常用管道命令
转载请出自出处:
http://eksliang.iteye.com/blog/2105461
bash命令执行的完毕以后,通常这个命令都会有返回结果,怎么对这个返回的结果做一些操作呢?那就得用管道命令‘|’。
上面那段话,简单说了下管道命令的作用,那什么事管道命令呢?
答:非常的经典的一句话,记住了,何为管
- Android系统中自定义按键的短按、双击、长按事件
gqdy365
android
在项目中碰到这样的问题:
由于系统中的按键在底层做了重新定义或者新增了按键,此时需要在APP层对按键事件(keyevent)做分解处理,模拟Android系统做法,把keyevent分解成:
1、单击事件:就是普通key的单击;
2、双击事件:500ms内同一按键单击两次;
3、长按事件:同一按键长按超过1000ms(系统中长按事件为500ms);
4、组合按键:两个以上按键同时按住;
- asp.net获取站点根目录下子目录的名称
hvt
.netC#asp.nethovertreeWeb Forms
使用Visual Studio建立一个.aspx文件(Web Forms),例如hovertree.aspx,在页面上加入一个ListBox代码如下:
<asp:ListBox runat="server" ID="lbKeleyiFolder" />
那么在页面上显示根目录子文件夹的代码如下:
string[] m_sub
- Eclipse程序员要掌握的常用快捷键
justjavac
javaeclipse快捷键ide
判断一个人的编程水平,就看他用键盘多,还是鼠标多。用键盘一是为了输入代码(当然了,也包括注释),再有就是熟练使用快捷键。 曾有人在豆瓣评
《卓有成效的程序员》:“人有多大懒,才有多大闲”。之前我整理了一个
程序员图书列表,目的也就是通过读书,让程序员变懒。 写道 程序员作为特殊的群体,有的人可以这么懒,懒到事情都交给机器去做,而有的人又可
- c++编程随记
lx.asymmetric
C++笔记
为了字体更好看,改变了格式……
&&运算符:
#include<iostream>
using namespace std;
int main(){
int a=-1,b=4,k;
k=(++a<0)&&!(b--
- linux标准IO缓冲机制研究
音频数据
linux
一、什么是缓存I/O(Buffered I/O)缓存I/O又被称作标准I/O,大多数文件系统默认I/O操作都是缓存I/O。在Linux的缓存I/O机制中,操作系统会将I/O的数据缓存在文件系统的页缓存(page cache)中,也就是说,数据会先被拷贝到操作系统内核的缓冲区中,然后才会从操作系统内核的缓冲区拷贝到应用程序的地址空间。1.缓存I/O有以下优点:A.缓存I/O使用了操作系统内核缓冲区,
- 随想 生活
暗黑小菠萝
生活
其实账户之前就申请了,但是决定要自己更新一些东西看也是最近。从毕业到现在已经一年了。没有进步是假的,但是有多大的进步可能只有我自己知道。
毕业的时候班里12个女生,真正最后做到软件开发的只要两个包括我,PS:我不是说测试不好。当时因为考研完全放弃找工作,考研失败,我想这只是我的借口。那个时候才想到为什么大学的时候不能好好的学习技术,增强自己的实战能力,以至于后来找工作比较费劲。我
- 我认为POJO是一个错误的概念
windshome
javaPOJO编程J2EE设计
这篇内容其实没有经过太多的深思熟虑,只是个人一时的感觉。从个人风格上来讲,我倾向简单质朴的设计开发理念;从方法论上,我更加倾向自顶向下的设计;从做事情的目标上来看,我追求质量优先,更愿意使用较为保守和稳妥的理念和方法。
&