Persekitaran pembangunan: IDEA 2022.1.4+ Mybatis
Semasa BiliBili sedang belajar SprintBoot, saya menaip kod mengikut. pada video, SpringBoot menyepadukan MyBatis dan menulis fail mybatis-config.xml yang berasingan. Konfigurasikan sambungan data, pemeta dan maklumat lain. Kemudian, saya bertanya kepada rakan sekerja saya yang terlibat dalam Java dan memberitahu saya bahawa fail mybatis-config.xml sebenarnya boleh ditulis ke application.yml. Saya tidak memahaminya pada masa itu. Kemudian, semasa saya menerokanya, saya secara beransur-ansur memahaminya.
Pada masa itu, saya mengkaji video dan juga menulis ringkasan pembelajaran.
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <!--configuration核心配置文件--> <!--顺序 properties->settings->typeAliases->typeHandlers->objectFactory->objectWrapperFactory->reflectorFactory->plugins->environments->databaseIdProvider->mappers--> <configuration> <!--jdbc.properties配置文件--> <properties resource="jdbc.properties"></properties> <!--设置mybatis输出日志 Mybatis默认就是STDOUT_LOGGING--> <settings> <setting name="logImpl" value="STDOUT_LOGGING"/> </settings> <!-- 类型别名 默认为类名 指定这个后 mapper的xml文件指定返回值时候 可直接写类名(不区分大小写) 建议直接拷贝类名 --> <typeAliases> <package name="com.ceaning.crudp.entity"/> </typeAliases> <!-- 环境配置 --> <!-- development IDEA默认 开发环境 --> <!-- 可以自定义 比如定义test formal 看心情 每个SqlSessionFactory实例只能选择一种环境 这个可随时配置 --> <!-- test 测试环境 --> <!-- formal 正式环境 --> <environments default="development"> <environment id="development"> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <property name="driver" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> </dataSource> </environment> </environments> <!-- 映射器 每一个mapper.xml都需要在Mybatis的核心文件中注册! --> <!-- 注册方式1 使用xml文件 <mapper resource="com/ceaning/efmis/mapper/UserMapper.xml"/> --> <!-- 注册方式2 使用class文件 <mapper class="com.ceaning.efmis.mapper.UserMapper"/> --> <!-- 注册方式3 mapper代理方式 <package name="com.ceaning.efmis.mapper"/> --> <!-- 注册方式2(使用class文件)和注册方式3(使用包扫描注册) 1.接口和他的Mapper配置文件必须同名 2.接口和他的Mapper配置文件必须在同一个包下 --> <mappers> <package name="com.ceaning.crudp.mapper"/> </mappers> </configuration>
Kandungan jdbc.properties adalah seperti berikut:
Saya menulis konfigurasi jdbc secara berasingan kerana saya bimbang jika ia digunakan dalam format WAR pada masa hadapan dan kandungan mybatis- config.xml diubah suai, akan ada terlalu banyak kandungan dan sukar untuk mengubah suainya Salah, cuma buat konfigurasi jdbc yang berasingan. (Sebenarnya, saya terlalu banyak berfikir)
driver=com.microsoft.sqlserver.jdbc.SQLServerDriver url=jdbc:sqlserver://127.0.0.1:1433;databaseName=EFMIS username=sa password=123qwe,.
Peranan kelas tambahan adalah untuk memuatkan konfigurasi dan mencipta SqlSessionFactory apabila kelas pada mulanya dipanggil untuk memudahkan pertanyaan SQL berikutnya .
public class MybatisUtils { //SqlSessionFactory 静态单例模式 private static SqlSessionFactory sqlSessionFactory; //使用Mybatis第一步 获取SqlSessionFactory对象 static { try{ String resource="mybatis-config.xml"; InputStream inputStream= Resources.getResourceAsStream(resource); sqlSessionFactory= new SqlSessionFactoryBuilder().build(inputStream); } catch (Exception e){ e.printStackTrace(); } } //获取SqlSession实例 //该实例包含了面向数据库执行sql命令所需要的所有方法 public static SqlSession getSqlSession(){ return sqlSessionFactory.openSession(); } }
Di sini saya mengambil operasi log masuk sebagai contoh. Dengan cara ini anda boleh menyambung ke pangkalan data untuk operasi.
@PostMapping("/user/login") public Result<?> login(@RequestBody User user){ SqlSession sqlSession= null; Map<String, Object> map= new HashMap<>(); try{ sqlSession= MybatisUtils.getSqlSession(); UserMapper mapper= sqlSession.getMapper(UserMapper.class); user= mapper.login(user); if (user!= null){ //生成token Map<String, String> tokenmap= new HashMap<>(); tokenmap.put("loginname", user.getLoginname()); tokenmap.put("password", user.getPassword()); String token= JwtUtils.getToken(tokenmap); //返回数据 map.put("user", user); map.put("token", token); return Result.ok(map); } else { return Result.error(CommonConstant.SYS_ERR_CODE, "用户不存在!"); } } catch (Exception e){ e.printStackTrace(); return Result.error("异常!"+ e.getMessage()); } finally { if (sqlSession!= null){ sqlSession.close(); } } }
Abaikan kandungan tambahan. Perkara utama ialah mengkonfigurasi sumber data spring.datasource. Konfigurasikan maklumat sambungan pangkalan data.
Server: port: 8090 spring: # quartz定时任务配置 quartz: # 数据库存储方式 job-store-type: jdbc org: quartz: jobStore: class: org.springframework.scheduling.quartz.LocalDataSourceJobStore #配置数据源 datasource: url: jdbc:sqlserver://127.0.0.1:1433;SelectMethod=cursor;databaseName=EFMIS username: sa password: 123qwe,. driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver #json jackson: date-format: yyyy-MM-dd HH:mm:ss time-zone: GMT+8 #热部署 devtools: restart: enabled: true additional-paths: src/main/java exclude: static/** jta: atomikos: properties: recovery: forget-orphaned-log-entries-delay: mybatis: configuration: #开启驼峰映射 map-underscore-to-camel-case: true #开启缓存 cache-enabled: true #加载mapper.xml文件 mapper-locations: classpath:com/ceaning/crudp/mapper/*.xml #别名扫描 type-aliases-package: com.ceaning.crudp.entity logging: config: classpath:logback-spring.xml
@Component public class SpringUtils implements BeanFactoryPostProcessor { /** * Spring应用上下文环境 */ private static ConfigurableListableBeanFactory beanFactory; @Override public void postProcessBeanFactory(ConfigurableListableBeanFactory configurableListableBeanFactory) throws BeansException { SpringUtils.beanFactory= configurableListableBeanFactory; } public static <T> T getBean(String name) throws BeansException{ name= lowerCaseInit(name); if(containsBean(name)){ return (T) beanFactory.getBean(name); } else{ return null; } } /** * 获取 * @param cls * @return * @param <T> * @throws BeansException */ public static <T> T getBean(Class<T> cls) throws BeansException{ T result= (T) beanFactory.getBean(cls); return result; } /** * 判断 BeanFactory是否包含bean对象 * @param name * @return */ public static boolean containsBean(String name){ return beanFactory.containsBean(name); } /** * 判断以给定名字注册的bean定义是一个singleton还是一个prototype。 * 如果与给定名字相应的bean定义没有被找到,将会抛出一个异常(NoSuchBeanDefinitionException) * @param name * @return * @throws NoSuchBeanDefinitionException */ public static boolean isSingleton(String name) throws NoSuchBeanDefinitionException{ return beanFactory.isSingleton(name); } public static Class<?> getType(String name) throws NoSuchBeanDefinitionException{ return beanFactory.getType(name); } public static String[] getAliases(String name) throws NoSuchBeanDefinitionException{ return beanFactory.getAliases(name); } /** * 首字母小写 * @param name * @return */ private static String lowerCaseInit(String name){ if(name.length()>0){ char c= name.charAt(0); if(c>=65 && c<=90){ int i= c+ 32; return ((char)i)+ name.substring(1); } else{ return name; } } else{ return null; } } }
Di sini kita mengambil operasi log masuk sebagai contoh. Operasi sambungan pangkalan data juga boleh dilakukan.
rreeeeAtas ialah kandungan terperinci Bagaimana untuk mengkonfigurasi fail SpringBoot Mybatis. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!