{"id":20017410,"url":"https://github.com/richinhim/springmybatis","last_synced_at":"2026-05-19T10:07:26.095Z","repository":{"id":73097572,"uuid":"41996162","full_name":"richinhim/SpringMybatis","owner":"richinhim","description":"spring/Mybatis multi datasource","archived":false,"fork":false,"pushed_at":"2015-09-08T02:12:00.000Z","size":152,"stargazers_count":4,"open_issues_count":0,"forks_count":1,"subscribers_count":4,"default_branch":"master","last_synced_at":"2025-01-12T15:46:00.753Z","etag":null,"topics":["mybatis","spring"],"latest_commit_sha":null,"homepage":"","language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/richinhim.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2015-09-06T09:09:45.000Z","updated_at":"2025-01-08T07:43:18.000Z","dependencies_parsed_at":"2023-03-11T14:25:43.373Z","dependency_job_id":null,"html_url":"https://github.com/richinhim/SpringMybatis","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/richinhim%2FSpringMybatis","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/richinhim%2FSpringMybatis/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/richinhim%2FSpringMybatis/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/richinhim%2FSpringMybatis/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/richinhim","download_url":"https://codeload.github.com/richinhim/SpringMybatis/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":241451677,"owners_count":19964901,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["mybatis","spring"],"created_at":"2024-11-13T08:15:49.036Z","updated_at":"2026-05-19T10:07:26.033Z","avatar_url":"https://github.com/richinhim.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"# SpringMybatis\nspring/Mybatis multi datasource\n\n스프링에서 Mybatis multi-datasource 연동법입니다.\n\n\n\n안녕하십니까? 지난주 spring4 + mybatis3.3 + dbcp를 이용하여 \n\n다중 데이터 소스 연결하는 부분을 해결한 내용을 올려드립니다.\n\nspring version : 4.2.0\n\nmybatis version : 3.3.0\n\nmybatis-spring version : 1.2.3\n\nWAS : wildfly9.0.1.Final\n\ndatabase : mariaDB10.0 \n\n을 이용하였습니다.\n\n그리고 소스는 DAO를 사용하지 않고 mapper 와 service를 사용하였습니다.\n\n\n\n\n에러 내용의 핵심은 2가지로 요약됩니다.\n\n1.\n\norg.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.proto.net.aron.aronMapper] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true) , @org.springframework.beans.factory.annotation.Qualifier(value=Mapper)}  \n\n\n\n\n2.\n\nMyBatis 의 MapperScannerConfigurer 가 어떤  SqlSessionFactory 를 참조해야 할지 몰라서 발생한다.\n\n\norg.springframework.beans.factory.NoUniqueBeanDefinitionException: No qualifying bean of type [org.apache.ibatis.session.SqlSessionFactory] is defined: expected single matching bean but found 2: sqlSessionFactory,sqlSessionFactory_mose  \n\n\n\n\n\n\n\n\n아래 부분은 application-config.xml 부분입니다.\n\n   \u003cbean id=\"dataSource\" class=\"org.apache.commons.dbcp.BasicDataSource\"\u003e\n\n    \t\u003cproperty name=\"driverClassName\" value=\"${database.aron.driverClassName}\"/\u003e\n\n    \t\u003cproperty name=\"url\" value=\"${database.aron.url}\"/\u003e\n\n    \t\u003cproperty name=\"username\" value=\"${database.aron.username}\"/\u003e\n\n    \t\u003cproperty name=\"password\" value=\"${database.aron.password}\"/\u003e\n\n    \t\u003cproperty name=\"testOnBorrow\" value=\"true\"/\u003e\n\n        \u003cproperty name=\"testOnReturn\" value=\"true\"/\u003e\n\n        \u003cproperty name=\"testWhileIdle\" value=\"true\"/\u003e\n\n        \u003cproperty name=\"timeBetweenEvictionRunsMillis\" value=\"1800000\"/\u003e\n\n        \u003cproperty name=\"numTestsPerEvictionRun\" value=\"3\"/\u003e\n\n        \u003cproperty name=\"minEvictableIdleTimeMillis\" value=\"1800000\"/\u003e\n\n        \u003cproperty name=\"validationQuery\" value=\"SELECT 1\"/\u003e\n\n    \u003c/bean\u003e\n\n    \n\n\t\u003ccontext:annotation-config/\u003e\n\n\t\n\n    \u003cbean id=\"sqlSessionFactory\" class=\"org.mybatis.spring.SqlSessionFactoryBean\"\u003e\n\n  \t\t\u003cproperty name=\"dataSource\" \t\tref=\"dataSource\" /\u003e\n\n  \t\t\u003cproperty name=\"configLocation\" \tvalue=\"classpath:mybatis/mybatis-config.xml\"/\u003e\n\n  \t\t\u003cproperty name=\"mapperLocations\"\u003e\n\n  \t\t\t\u003clist\u003e\n\n  \t\t\t\t\u003cvalue\u003eclasspath:mybatis/mappers/aron/aron.xml\u003c/value\u003e\n\n  \t\t\t\t\n\n  \t\t\t\u003c/list\u003e\n\n  \t\t\u003c/property\u003e\n\n  \t\t\n\n  \t\u003c/bean\u003e\n\n\t\n\n\t\u003cbean id=\"sqlSessionTemplate\" class=\"org.mybatis.spring.SqlSessionTemplate\" destroy-method=\"clearCache\"\u003e\n\n\t\t\u003cconstructor-arg name=\"sqlSessionFactory\" ref=\"sqlSessionFactory\" /\u003e\n\n\t\u003c/bean\u003e\n\n\t\n\n\t\u003c!-- mybatis mapper auto scanning --\u003e\n\n\t\u003cbean id=\"dsAronScanner\" class=\"org.mybatis.spring.mapper.MapperScannerConfigurer\"\u003e\n\n\t\t\u003cproperty name=\"basePackage\" value=\"com.proto.net.aron.mapper\" /\u003e\n\n\t\t\u003cproperty name=\"sqlSessionFactoryBeanName\" value=\"sqlSessionFactory\"/\u003e\n\n\t\t\n\n\t\u003c/bean\u003e\n\n\t\n\n\t\n\n\t\u003ctx:annotation-driven transaction-manager=\"transactionManager\" proxy-target-class=\"true\" /\u003e\n\n\t\n\n\t\u003cbean id=\"transactionManager\" class=\"org.springframework.jdbc.datasource.DataSourceTransactionManager\"\u003e\n\n  \t\t\u003cproperty name=\"dataSource\" ref=\"dataSource\" /\u003e\n\n\t\u003c/bean\u003e\n\n    \n\n    \n\n    \n\n     \u003cbean id=\"dataSource_mose\" class=\"org.apache.commons.dbcp.BasicDataSource\"\u003e\n\n    \t\u003cproperty name=\"driverClassName\" value=\"${database.mose.driverClassName}\"/\u003e\n\n    \t\u003cproperty name=\"url\" value=\"${database.mose.url}\"/\u003e\n\n    \t\u003cproperty name=\"username\" value=\"${database.mose.username}\"/\u003e\n\n    \t\u003cproperty name=\"password\" value=\"${database.mose.password}\"/\u003e\n\n\t    \u003cproperty name=\"testOnBorrow\" value=\"true\"/\u003e\n\n        \u003cproperty name=\"testOnReturn\" value=\"true\"/\u003e\n\n        \u003cproperty name=\"testWhileIdle\" value=\"true\"/\u003e\n\n        \u003cproperty name=\"timeBetweenEvictionRunsMillis\" value=\"1800000\"/\u003e\n\n        \u003cproperty name=\"numTestsPerEvictionRun\" value=\"3\"/\u003e\n\n        \u003cproperty name=\"minEvictableIdleTimeMillis\" value=\"1800000\"/\u003e\n\n        \u003cproperty name=\"validationQuery\" value=\"SELECT 1\"/\u003e\n\n    \u003c/bean\u003e\n\n    \n\n    \u003cbean id=\"sqlSessionFactory_mose\" class=\"org.mybatis.spring.SqlSessionFactoryBean\"\u003e\n\n  \t\t\u003cproperty name=\"dataSource\" \t\tref=\"dataSource_mose\" /\u003e\n\n  \t\t\u003cproperty name=\"configLocation\" \tvalue=\"classpath:mybatis/mybatis-config.xml\"/\u003e\n\n  \t\t\u003cproperty name=\"mapperLocations\"\u003e\n\n  \t\t\t\u003clist\u003e\n\n  \t\t\t\t\u003cvalue\u003eclasspath:mybatis/mappers/mose/mose.xml\u003c/value\u003e\n\n  \t\t\t\u003c/list\u003e\n\n  \t\t\u003c/property\u003e\n\n  \t\t\n\n  \t\u003c/bean\u003e\n\n\t\n\n\t\u003cbean id=\"sqlSessionTemplate_mose\" class=\"org.mybatis.spring.SqlSessionTemplate\" destroy-method=\"clearCache\"\u003e\n\n\t\t\u003cconstructor-arg name=\"sqlSessionFactory\" ref=\"sqlSessionFactory_mose\" /\u003e\n\n\t\u003c/bean\u003e\n\n\t\n\n\t\u003c!-- mybatis mapper auto scanning --\u003e\n\n\t\u003cbean id=\"dsMoseScanner\" class=\"org.mybatis.spring.mapper.MapperScannerConfigurer\"\u003e\n\n\t\t\u003cproperty name=\"basePackage\" value=\"com.proto.net.mose.mapper\" /\u003e\n\n\t\t\u003cproperty name=\"sqlSessionFactoryBeanName\" value=\"sqlSessionFactory_mose\"/\u003e\n\n\t\u003c/bean\u003e\n\n\t\n\n\t\n\n\t\u003cbean id=\"transactionManager_mose\" class=\"org.springframework.jdbc.datasource.DataSourceTransactionManager\"\u003e\n\n  \t\t\u003cproperty name=\"dataSource\" ref=\"dataSource_mose\" /\u003e\n\n\t\u003c/bean\u003e\n\n\t\u003ctx:annotation-driven transaction-manager=\"transactionManager_mose\" proxy-target-class=\"true\" /\u003e\n\n\t\n\n\t\u003ccontext:component-scan base-package=\"com.proto.net.aron.service,com.proto.net.mose.service\" /\u003e\n\n\n\n\n1번 오류에 대한 해결책은 mapper inteface 상단에 \n\n@Resource(name = \"dsMoseScanner\") 를 추가해 주는 것입니다.\n\n\n\n\n2번 오류의 해결책은 아래와 같이 매퍼가 사용할 sqlSessionFactory를 지정해 주는 것입니다.\n\n\u003cbean id=\"dsMoseScanner\" class=\"org.mybatis.spring.mapper.MapperScannerConfigurer\"\u003e\n\n\t\t\u003cproperty name=\"basePackage\" value=\"com.proto.net.mose.mapper\" /\u003e\n\n\t\t\u003cproperty name=\"sqlSessionFactoryBeanName\" value=\"sqlSessionFactory_mose\"/\u003e\n\n\u003c/bean\u003e \n\n\n\n\n감사합니다.\n\n\n\n1번과 2번의 설정을 제거하고 한방에 처리 하는 방법을 찾았습니다.\n\napplication-config.xml 파일에 \n\n\u003cmybatis:scan base-package=\"\"com.proto.net.mose.mapper\" factory-ref=\"SqlSessionFactory_mose\"  /\u003e\n\n\u003cmybatis:scan base-package=\"\"com.proto.net.aron.mapper\" factory-ref=\"SqlSessionFactory_aron\"  /\u003e\n\n으로 정의하게 되면 \n\n\u003ccontext:component-scan base-package=\"com.proto.net.aron.service,com.proto.net.mose.service\" /\u003e 이부분과 \n\n\n\n\n\u003c!-- mybatis mapper auto scanning --\u003e\n\n\t\u003cbean id=\"dsMoseScanner\" class=\"org.mybatis.spring.mapper.MapperScannerConfigurer\"\u003e\n\n\t\t\u003cproperty name=\"basePackage\" value=\"com.proto.net.mose.mapper\" /\u003e\n\n\t\t\u003cproperty name=\"sqlSessionFactoryBeanName\" value=\"sqlSessionFactory_mose\"/\u003e\n\n\t\u003c/bean\u003e\n\n\n\n\n\u003c!-- mybatis mapper auto scanning --\u003e\n\n\t\u003cbean id=\"dsAronScanner\" class=\"org.mybatis.spring.mapper.MapperScannerConfigurer\"\u003e\n\n\t\t\u003cproperty name=\"basePackage\" value=\"com.proto.net.aron.mapper\" /\u003e\n\n\t\t\u003cproperty name=\"sqlSessionFactoryBeanName\" value=\"sqlSessionFactory_aron\"/\u003e\n\n\t\u003c/bean\u003e\n\n도 제거할수 있습니다.\n\n그리고\n\nmapper inteface 상단에 \n\n@Resource(name = \"dsMoseScanner\") 를 추가해 주지 않아도 됩니다.\n\n감사합니다.\n\n\n        \n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Frichinhim%2Fspringmybatis","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Frichinhim%2Fspringmybatis","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Frichinhim%2Fspringmybatis/lists"}