마이바티스 시리즈 심층 설명(3) - 속성 및 환경 상세 구성(마이바티스 소스코드)
이전 글 "마이바티스 시리즈 심층 소개(2)---구성 소개(마이바티스 소스코드)"에서 마이바티스 소스코드에 대한 간단한 분석을 통해 에서 mybatis 구성 파일은 아래 구성 루트 노드에서 속성, typeAliases, 플러그인, objectFactory, objectWrapperFactory, 설정, 환경, DatabaseIdProvider, typeHandlers 및 매퍼 노드를 구성할 수 있습니다. 그래서 이번에는 속성 노드와 환경 노드를 먼저 소개하겠습니다.
모든 사람이 mybatis 소스 코드를 더 잘 읽을 수 있도록 속성 사용 방법에 대한 간단한 예를 제공하겠습니다.
1 <configuration> 2 <!-- 方法一: 从外部指定properties配置文件, 除了使用resource属性指定外,还可通过url属性指定url 3 <properties resource="dbConfig.properties"></properties> 4 --> 5 <!-- 方法二: 直接配置为xml --> 6 <properties> 7 <property name="driver" value="com.mysql.jdbc.Driver"/> 8 <property name="url" value="jdbc:mysql://localhost:3306/test1"/> 9 <property name="username" value="root"/> 10 <property name="password" value="root"/> 11 </properties>
그럼 두 가지 방법을 동시에 사용한다면 어떤 방법이 우선 적용되나요?
위의 두 가지 방법에 xml 구성이 있는 경우 우선 순위가 주어지며 외부 지정 속성 구성이 두 번째입니다. 이유는 다음 소스코드 분석에서 언급할 예정이니 주목해주세요.
환경 요소 노드를 사용하는 방법을 살펴보겠습니다.
<environments default="development"> <environment id="development"> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <!-- 如果上面没有指定数据库配置的properties文件,那么此处可以这样直接配置 <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/test1"/> <property name="username" value="root"/> <property name="password" value="root"/> --> <!-- 上面指定了数据库配置文件, 配置文件里面也是对应的这四个属性 --> <property name="driver" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> </dataSource> </environment> <!-- 我再指定一个environment --> <environment id="test"> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"/> <!-- 与上面的url不一样 --> <property name="url" value="jdbc:mysql://localhost:3306/demo"/> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource> </environment> </environments>
환경 요소 노드는 여러 환경 하위 노드로 구성될 수 있습니다. .어떻게 이해하나요?
우리 시스템의 개발 환경이 공식 환경에서 사용하는 데이터베이스와 다르다면(확실히 그렇습니다) 두 가지 환경을 설정할 수 있으며 두 ID는 개발 환경(dev)과 정식 환경(최종)의 경우 환경의 기본 속성을 구성하여 해당 환경을 선택할 수 있습니다. 예를 들어 환경의 기본 속성 값을 dev로 구성하면 해당 환경이 선택됩니다. 개발자가 선택됩니다. 이것이 어떻게 구현되는지에 대해서는 소스 코드가 아래에서 설명됩니다.
자, 위에서 속성과 환경의 구성에 대해 간략히 소개한 후 본격적으로 소스 코드를 살펴보기 시작했습니다.
지난번에 mybatis는 XMLConfigBuilder를 통해서라고 말씀드렸습니다. 클래스는 mybatis 구성 파일을 파싱하고 있으므로 이번에는 XMLConfigBuilder의 속성 및 환경 분석을 살펴보겠습니다.
XMLConfigBuilder:
1 public class XMLConfigBuilder extends BaseBuilder { 2 3 private boolean parsed; 4 //xml解析器 5 private XPathParser parser; 6 private String environment; 7 8 //上次说到这个方法是在解析mybatis配置文件中能配置的元素节点 9 //今天首先要看的就是properties节点和environments节点 10 private void parseConfiguration(XNode root) { 11 try { 12 //解析properties元素 13 propertiesElement(root.evalNode("properties")); //issue #117 read properties first 14 typeAliasesElement(root.evalNode("typeAliases")); 15 pluginElement(root.evalNode("plugins")); 16 objectFactoryElement(root.evalNode("objectFactory")); 17 objectWrapperFactoryElement(root.evalNode("objectWrapperFactory")); 18 settingsElement(root.evalNode("settings")); 19 //解析environments元素 20 environmentsElement(root.evalNode("environments")); // read it after objectFactory and objectWrapperFactory issue #631 21 databaseIdProviderElement(root.evalNode("databaseIdProvider")); 22 typeHandlerElement(root.evalNode("typeHandlers")); 23 mapperElement(root.evalNode("mappers")); 24 } catch (Exception e) { 25 throw new BuilderException("Error parsing SQL Mapper Configuration. Cause: " + e, e); 26 } 27 } 28 29 30 //下面就看看解析properties的具体方法 31 private void propertiesElement(XNode context) throws Exception { 32 if (context != null) { 33 //将子节点的 name 以及value属性set进properties对象 34 //这儿可以注意一下顺序,xml配置优先, 外部指定properties配置其次 35 Properties defaults = context.getChildrenAsProperties(); 36 //获取properties节点上 resource属性的值 37 String resource = context.getStringAttribute("resource"); 38 //获取properties节点上 url属性的值, resource和url不能同时配置 39 String url = context.getStringAttribute("url"); 40 if (resource != null && url != null) { 41 throw new BuilderException("The properties element cannot specify both a URL and a resource based property file reference. Please specify one or the other."); 42 } 43 //把解析出的properties文件set进Properties对象 44 if (resource != null) { 45 defaults.putAll(Resources.getResourceAsProperties(resource)); 46 } else if (url != null) { 47 defaults.putAll(Resources.getUrlAsProperties(url)); 48 } 49 //将configuration对象中已配置的Properties属性与刚刚解析的融合 50 //configuration这个对象会装载所解析mybatis配置文件的所有节点元素,以后也会频频提到这个对象 51 //既然configuration对象用有一系列的get/set方法, 那是否就标志着我们可以使用java代码直接配置? 52 //答案是肯定的, 不过使用配置文件进行配置,优势不言而喻 53 Properties vars = configuration.getVariables(); 54 if (vars != null) { 55 defaults.putAll(vars); 56 } 57 //把装有解析配置propertis对象set进解析器, 因为后面可能会用到 58 parser.setVariables(defaults); 59 //set进configuration对象 60 configuration.setVariables(defaults); 61 } 62 } 63 64 //下面再看看解析enviroments元素节点的方法 65 private void environmentsElement(XNode context) throws Exception { 66 if (context != null) { 67 if (environment == null) { 68 //解析environments节点的default属性的值 69 //例如: <environments default="development"> 70 environment = context.getStringAttribute("default"); 71 } 72 //递归解析environments子节点 73 for (XNode child : context.getChildren()) { 74 //<environment id="development">, 只有enviroment节点有id属性,那么这个属性有何作用? 75 //environments 节点下可以拥有多个 environment子节点 76 //类似于这样: <environments default="development"><environment id="development">...</environment><environment id="test">...</environments> 77 //意思就是我们可以对应多个环境,比如开发环境,测试环境等, 由environments的default属性去选择对应的enviroment 78 String id = child.getStringAttribute("id"); 79 //isSpecial就是根据由environments的default属性去选择对应的enviroment 80 if (isSpecifiedEnvironment(id)) { 81 //事务, mybatis有两种:JDBC 和 MANAGED, 配置为JDBC则直接使用JDBC的事务,配置为MANAGED则是将事务托管给容器, 82 TransactionFactory txFactory = transactionManagerElement(child.evalNode("transactionManager")); 83 //enviroment节点下面就是dataSource节点了,解析dataSource节点(下面会贴出解析dataSource的具体方法) 84 DataSourceFactory dsFactory = dataSourceElement(child.evalNode("dataSource")); 85 DataSource dataSource = dsFactory.getDataSource(); 86 Environment.Builder environmentBuilder = new Environment.Builder(id) 87 .transactionFactory(txFactory) 88 .dataSource(dataSource); 89 //老规矩,会将dataSource设置进configuration对象 90 configuration.setEnvironment(environmentBuilder.build()); 91 } 92 } 93 } 94 } 95 96 //下面看看dataSource的解析方法 97 private DataSourceFactory dataSourceElement(XNode context) throws Exception { 98 if (context != null) { 99 //dataSource的连接池 100 String type = context.getStringAttribute("type"); 101 //子节点 name, value属性set进一个properties对象 102 Properties props = context.getChildrenAsProperties(); 103 //创建dataSourceFactory 104 DataSourceFactory factory = (DataSourceFactory) resolveClass(type).newInstance(); 105 factory.setProperties(props); 106 return factory; 107 } 108 throw new BuilderException("Environment declaration requires a DataSourceFactory."); 109 } 110 }
를 통해 위의 쌍 mybatis 소스 코드 해석을 통해 모든 사람이 mybatis 구성에 대해 깊이 이해하고 있다고 믿습니다.
또 다른 질문이 있습니다. 위에서 본 것처럼 dataSource를 구성할 때 ${driver}라는 표현식이 사용되었습니다. 실제로 PropertyParser 클래스를 통해 구문 분석됩니다.
PropertyParser:
/** * 这个类解析${}这种形式的表达式 */public class PropertyParser { public static String parse(String string, Properties variables) { VariableTokenHandler handler = new VariableTokenHandler(variables); GenericTokenParser parser = new GenericTokenParser("${", "}", handler); return parser.parse(string); } private static class VariableTokenHandler implements TokenHandler { private Properties variables; public VariableTokenHandler(Properties variables) { this.variables = variables; } public String handleToken(String content) { if (variables != null && variables.containsKey(content)) { return variables.getProperty(content); } return "${" + content + "}"; } } }
자, 위는 속성 및 환경 요소 노드를 분석한 것입니다. 이것이 더 중요합니다. 소스 코드의 주석에 모두 표시되어 있습니다. 이번 글은 여기서 마치고, 다음 글에서는 계속해서 다른 노드의 구성을 분석해보겠습니다.
위는 마이바티스 시리즈(3)의 내용입니다. - 속성 및 환경의 상세 구성(마이바티스 소스코드)에 대한 자세한 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고하시기 바랍니다. )!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











iBatis vs. MyBatis: 무엇을 선택해야 할까요? 소개: Java 언어의 급속한 발전으로 인해 많은 지속성 프레임워크가 등장했습니다. iBatis와 MyBatis는 두 가지 인기 있는 지속성 프레임워크로, 둘 다 간단하고 효율적인 데이터 액세스 솔루션을 제공합니다. 이 기사에서는 iBatis와 MyBatis의 기능과 장점을 소개하고 적절한 프레임워크를 선택하는 데 도움이 되는 몇 가지 특정 코드 예제를 제공합니다. iBatis 소개: iBatis는 오픈 소스 지속성 프레임워크입니다.

MyBatis 동적 SQL 태그 해석: Set 태그 사용법에 대한 자세한 설명 MyBatis는 풍부한 동적 SQL 태그를 제공하고 데이터베이스 작업 명령문을 유연하게 구성할 수 있는 탁월한 지속성 계층 프레임워크입니다. 그 중 Set 태그는 업데이트 작업에서 매우 일반적으로 사용되는 UPDATE 문에서 SET 절을 생성하는 데 사용됩니다. 이 기사에서는 MyBatis에서 Set 태그의 사용법을 자세히 설명하고 특정 코드 예제를 통해 해당 기능을 보여줍니다. Set 태그란 무엇입니까? Set 태그는 MyBati에서 사용됩니다.

MyBatis에서 일괄 삭제 문을 구현하는 여러 가지 방법에는 특정 코드 예제가 필요합니다. 최근 몇 년 동안 데이터 양이 증가함에 따라 일괄 작업이 데이터베이스 작업의 중요한 부분이 되었습니다. 실제 개발에서는 데이터베이스의 레코드를 일괄적으로 삭제해야 하는 경우가 많습니다. 이 기사에서는 MyBatis에서 일괄 삭제 문을 구현하는 여러 가지 방법에 중점을 두고 해당 코드 예제를 제공합니다. 일괄 삭제를 구현하려면 foreach 태그를 사용하세요. MyBatis는 세트를 쉽게 탐색할 수 있는 foreach 태그를 제공합니다.

JPA와 MyBatis: 기능과 성능의 비교 분석 소개: Java 개발에서 지속성 프레임워크는 매우 중요한 역할을 합니다. 일반적인 지속성 프레임워크에는 JPA(JavaPersistenceAPI) 및 MyBatis가 포함됩니다. 이 기사에서는 두 프레임워크의 기능과 성능을 비교 분석하고 구체적인 코드 예제를 제공합니다. 1. 기능 비교: JPA: JPA는 JavaEE의 일부이며 객체 지향 데이터 지속성 솔루션을 제공합니다. 주석 또는 X가 전달되었습니다.

MyBatis 일괄 삭제 문을 사용하는 방법에 대한 자세한 설명에는 특정 코드 예제가 필요합니다. 소개: MyBatis는 풍부한 SQL 작업 기능을 제공하는 뛰어난 지속성 계층 프레임워크입니다. 실제 프로젝트 개발을 하다 보면, 데이터를 일괄적으로 삭제해야 하는 상황이 자주 발생합니다. 이 기사에서는 MyBatis 일괄 삭제 문을 사용하는 방법을 자세히 소개하고 특정 코드 예제를 첨부합니다. 사용 시나리오: 데이터베이스의 많은 양의 데이터를 삭제할 때 삭제 문을 하나씩 실행하는 것은 비효율적입니다. 이때 MyBatis의 일괄삭제 기능을 사용할 수 있습니다.

MyBatis 1차 캐시에 대한 자세한 설명: 데이터 액세스 효율성을 향상시키는 방법은 무엇입니까? 개발 과정에서 효율적인 데이터 액세스는 항상 프로그래머의 초점 중 하나였습니다. MyBatis와 같은 지속성 계층 프레임워크의 경우 캐싱은 데이터 액세스 효율성을 향상시키는 주요 방법 중 하나입니다. MyBatis는 두 가지 캐싱 메커니즘을 제공합니다: 첫 번째 수준 캐시와 두 번째 수준 캐시는 기본적으로 활성화됩니다. 이 기사에서는 MyBatis 1단계 캐시의 메커니즘을 자세히 소개하고 독자의 이해를 돕기 위해 구체적인 코드 예제를 제공합니다.

MyBatis 캐싱 메커니즘 분석: 1단계 캐시와 2단계 캐시의 차이점 및 적용 MyBatis 프레임워크에서 캐싱은 데이터베이스 작업 성능을 효과적으로 향상시킬 수 있는 매우 중요한 기능입니다. 그중 1단계 캐시와 2단계 캐시는 MyBatis에서 일반적으로 사용되는 두 가지 캐싱 메커니즘입니다. 이 기사에서는 1차 수준 캐시와 2차 수준 캐시의 차이점과 적용을 자세히 분석하고 설명할 구체적인 코드 예제를 제공합니다. 1. 레벨 1 캐시 레벨 1 캐시는 로컬 캐시라고도 하며 기본적으로 활성화되어 있으며 끌 수 없습니다. 첫 번째 수준 캐시는 SqlSes입니다.

MyBatisGenerator는 MyBatis에서 공식적으로 제공하는 코드 생성 도구로, 개발자가 데이터베이스 테이블 구조에 맞는 JavaBeans, Mapper 인터페이스 및 XML 매핑 파일을 빠르게 생성할 수 있도록 도와줍니다. 코드 생성을 위해 MyBatisGenerator를 사용하는 과정에서 구성 매개변수 설정이 중요합니다. 이 글은 구성 매개변수의 관점에서 시작하여 MyBatisGenerator의 기능을 깊이 탐구할 것입니다.
