Mybatis-核心配置文件 / Mybatis增删改查

1. 核心配置文件

1.1. 概述

核心配置文件是MyBatis框架中用于集中定义全局配置信息的XML文件,其内部包含了一系列预设标签,用于设置数据库连接、对象映射、类型处理等关键参数。这些标签遵循特定的排列顺序,尽管并非所有标签都是强制性的,但按照推荐顺序编写有助于保持配置文件的清晰性和一致性。

  1. properties(可选):
    用于导入外部属性文件,便于在核心配置文件中引用其中的变量。通常用于存储数据库连接信息、环境切换标志等敏感或可变数据。
  2. settings(可选):
    设置MyBatis全局行为的配置项集合。如开启驼峰命名自动映射、设置默认的执行器、指定是否延迟加载等。每个设置项以<setting>标签进行定义。
  3. typeAliases(可选):
    定义类型别名,为Java类提供简短易记的名字,以便在Mapper XML文件中更简洁地引用。可以为单个类定义别名,也可以批量定义包下的所有类。
  4. typeHandlers(可选):
    注册自定义类型处理器,用于处理JDBC无法直接识别的数据类型(如枚举、日期等)。可以为单个类型处理器定义,也可以批量定义包下的所有处理器。
  5. objectFactory(可选):
    指定自定义对象工厂,用于创建结果对象(如查询结果映射到的实体类)。当需要对对象创建过程进行特殊控制时使用。
  6. objectWrapperFactory(可选):
    指定自定义对象包装器工厂,用于创建对象包装器,控制对象属性的读写操作。在处理深层次嵌套属性或复杂对象结构时可能用到。
  7. reflectorFactory(可选):
    指定反射器工厂,用于创建反射器,影响对象属性的读取和设置。通常情况下无需定制,但在某些特定优化场景下可能需要。
  8. plugins(可选):
    配置MyBatis插件,用于拦截核心接口方法执行,实现诸如性能监控、日志记录、动态SQL修改等功能。每个插件需指定对应的拦截器类。
  9. environments
    定义多个环境配置,如开发环境、生产环境等。每个环境包含一个默认的transactionManager(事务管理器)和至少一个dataSource(数据源)。根据实际运行时的环境标识符选择对应的环境配置。
  10. databaseIdProvider(可选):
    提供数据库供应商ID识别功能,用于在XML映射文件中根据不同的数据库执行特定的SQL语句。通常与<if><choose>等动态SQL元素配合使用。
  11. mappers
    引入Mapper XML文件或接口类,定义SQL映射语句和结果映射。可以通过相对于配置文件的路径、类路径下的绝对路径、包扫描等方式进行引入。

比如下面这个代码示例:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<!-- MyBatis 配置文件 -->
<configuration><!-- 引入外部属性文件 --><!-- 将database.properties文件中的属性值注入到MyBatis配置中 --><properties resource="database.properties"/><!-- 全局配置 --><settings><!-- 设置日志实现方式为LOG4J --><setting name="logImpl" value="LOG4J"/><!-- 开启驼峰命名与下划线命名之间的自动转换 --><setting name="mapUnderscoreToCamelCase" value="true"/></settings><!-- 类型别名 --><!-- 定义类型别名,简化SQL语句中的全限定类名书写 --><typeAliases><!-- 为User类定义别名为User --><typeAlias alias="User" type="com.example.model.User"/><!-- 扫描com.example.model包下的所有类,自动生成类型别名 --><package name="com.example.model"/></typeAliases><!-- 类型处理器 --><!-- 定义自定义类型处理器,处理特殊数据类型的SQL映射 --><typeHandlers><!-- 注册自定义类型处理器 --><typeHandler handler="com.example.handler.MyCustomTypeHandler"/><!-- 扫描com.example.handler包下的所有类,自动注册类型处理器 --><package name="com.example.handler"/></typeHandlers><!-- 对象工厂、对象包装器工厂、反射器工厂(此处省略,通常使用默认即可) --><!-- 插件配置 --><!-- 注册MyBatis插件,用于增强或拦截MyBatis行为 --><plugins><!-- 注册LoggingInterceptor插件 --><plugin interceptor="com.example.plugin.LoggingInterceptor"/></plugins><!-- 环境配置 --><!-- 配置多个数据库连接环境,可按需切换 --><environments default="development"><!-- 配置开发环境 --><environment id="development"><!-- 事务管理器配置,此处使用JDBC原生事务管理 --><transactionManager type="JDBC"/><!-- 数据源配置,使用连接池(POOLED) --><dataSource type="POOLED"><!-- 使用${}引用外部属性文件中的属性 --><property name="driver" value="${jdbc.driver}"/><property name="url" value="${jdbc.url}"/><property name="username" value="${jdbc.username}"/><property name="password" value="${jdbc.password}"/></dataSource></environment><!-- 可以添加更多环境,如 production 环境 --></environments><!-- 数据库厂商识别 --><!-- 根据数据库类型自动选择对应的SQL方言 --><databaseIdProvider type="DB_VENDOR"><!-- 定义MySQL和Oracle的标识符 --><property name="MySQL" value="mysql"/><property name="Oracle" value="oracle"/></databaseIdProvider><!-- SQL 映射文件 --><!-- 配置SQL映射文件或接口,用于编写SQL语句和结果映射 --><mappers><!-- 引入XML形式的SQL映射文件 --><mapper resource="com/example/mapper/UserMapper.xml"/><!-- 引入注解形式的SQL映射接口 --><mapper class="com.example.mapper.UserMapper"/><!-- 可以通过包扫描方式引入 --><!-- <package name="com.example.mapper"/> --></mappers>
</configuration>

1.2. 分离数据库连接属性

使用外部 .properties文件简化MyBatis配置


在实际项目开发中,数据库连接信息(如驱动、URL、用户名、密码等)通常需要根据不同的环境(如开发、测试、生产)灵活调整。直接在MyBatis的核心配置文件中硬编码这些数据源信息,虽然简单直接,但不利于配置的管理和维护,特别是在需要频繁切换数据库连接时,每次手动修改配置文件会显得繁琐且易出错。

为解决这一问题,我们可以将数据库连接相关的属性提取到一个单独的db.properties文件中,并通过MyBatis的<properties>标签将其引入到核心配置文件中。这样,当需要切换数据库连接时,只需修改db.properties文件,而无需改动核心配置文件,大大提高了配置的灵活性和可维护性。

以下是具体的操作步骤和代码示例:

步骤1:创建db.properties文件

创建一个名为db.properties的文件,名字可根据实际情况来

其中包含数据库连接所需的各项属性:

db.driver = com.mysql.cj.jdbc.Driver
db.url = jdbc:mysql://localhost:3306/mybatis3?characterEncoding=utf-8
db.username = root
db.password = 2076805863

步骤2:在MyBatis核心配置文件中引入db.properties

在MyBatis的mybatis-config.xml核心配置文件中添加<properties>标签,指定resource属性为db.properties文件的路径,以便MyBatis加载该文件:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><!-- 引入外部文件 --><properties resource="db.properties"/><!-- ... 其他配置 ... -->
</configuration>

步骤3:使用属性占位符替换数据源配置

接下来,在配置数据源时,使用${}语法引用db.properties文件中定义的属性,替换原本硬编码的值:

<dataSource type="POOLED"><property name="driver" value="${db.driver}"/><property name="url" value="${db.url}"/><property name="username" value="${db.username}"/><property name="password" value="${db.password}"/>
</dataSource>

2. Mybatis增删改查

2.1. 准备操作

创建表并添加数据

创建相关Javabean类

package com.sakurapaid.mybatis3.demo01.bean;public class User {private int id;private String name;private int age;private String sex;public User() {}public User(int id, String name, int age, String sex) {this.id = id;this.name = name;this.age = age;this.sex = sex;}/*** 获取* @return id*/public int getId() {return id;}/*** 设置* @param id*/public void setId(int id) {this.id = id;}/*** 获取* @return name*/public String getName() {return name;}/*** 设置* @param name*/public void setName(String name) {this.name = name;}/*** 获取* @return age*/public int getAge() {return age;}/*** 设置* @param age*/public void setAge(int age) {this.age = age;}/*** 获取* @return sex*/public String getSex() {return sex;}/*** 设置* @param sex*/public void setSex(String sex) {this.sex = sex;}public String toString() {return "User{id = " + id + ", name = " + name + ", age = " + age + ", sex = " + sex + "}";}
}

配置 mybatis-config.xml 文件

记得在最下面写映射配置

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><!-- 配置MyBatis的运行环境,默认使用development环境 --><environments default="development"><!-- 定义development环境 --><environment id="development"><!-- 使用JDBC事务管理器 --><transactionManager type="JDBC"/><!-- 配置数据源,使用连接池类型 --><dataSource type="POOLED"><!-- 配置数据库连接池的属性 --><property name="driver" value="com.mysql.cj.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/mybatis3?characterEncoding=utf-8"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><!-- 映射器配置,指定Mapper XML文件的位置 --><mappers><mapper resource="mappers/UserMapper.xml"/></mappers></configuration>

创建 UserMapper.xml 映射接口

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- 定义mapper接口的命名空间 -->
<mapper namespace="com.sakurapaid.mybatis3.demo01.mapper.UserMapper"></mapper>

namespace对应下面创建的Dao层接口的全类名位置

namespace="com.sakurapaid.mybatis3.demo01.mapper.UserMapper"

创建UserMapper的dao层接口

package com.sakurapaid.mybatis3.demo01.mapper;import com.sakurapaid.mybatis3.demo01.bean.User;import java.util.List;public interface UserMapper {}

项目结构


2.2. 添加数据

UserMapper.java

package com.sakurapaid.mybatis3.demo01.mapper;import com.sakurapaid.mybatis3.demo01.bean.User;public interface UserMapper {// 1.添加用户public int addUser(User user);
}

UserMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- 定义mapper接口的命名空间 -->
<mapper namespace="com.sakurapaid.mybatis3.demo01.mapper.UserMapper"><!--1.添加用户--><insert id="addUser" parameterType="User">insert into user(name,age,sex) values(#{name},#{age},#{sex})</insert>
</mapper>

可能到这里就需要一步步解释每个标签是什么意思了:

<mapper> 标签:

<mapper namespace="com.sakurapaid.mybatis3.demo01.mapper.UserMapper">

<mapper> 标签代表一个独立的 SQL 映射文件,用于定义与数据库交互的各种操作(如增删改查)。每个 <mapper> 必须有一个唯一的 namespace 属性,它类似于 Java 中的包名,用于唯一标识该映射文件。这里的 namespace 值为 "com.sakurapaid.mybatis3.demo01.mapper.UserMapper",表示这个映射文件对应于名为 UserMapper 的 Java 接口(通常位于 com.sakurapaid.mybatis3.demo01.mapper 包下),该接口中定义了与 <mapper> 文件中 SQL 语句相对应的方法。

<insert> 标签:

<!--1.添加用户-->
<insert id="addUser" parameterType="User">insert into user(name,age,sex) values(#{name},#{age},#{sex})
</insert>

<insert> 标签用于定义插入数据到数据库表的操作。具体说明如下:

id 属性id="addUser" 表示这个 <insert> 标签对应于 UserMapper 接口中一个名为 addUser 的方法。当调用该接口方法时,MyBatis 将执行此 <insert> 标签内的 SQL 语句。

parameterType 属性parameterType="User" 指定执行 SQL 语句时使用的输入参数类型。这里为 User 类,通常是一个与数据库表结构对应的 Java 实体类。这意味着调用 addUser 方法时,需要传入一个 User 对象作为参数。

parameterType 的值一般要写全类名才可以,这里只写User是因为我核心配置文件做了取别名操作,

一般上要写右边com开头的一大堆东西

SQL 语句insert into user(name,age,sex) values(#{name},#{age},#{sex}) 是具体的 SQL 插入语句,用于向名为 user 的数据库表中插入一条新记录。name, age, sex 分别对应表中的字段名,而 #{name}, #{age}, #{sex} 是占位符,它们会被传入的 User 对象的相应属性值替换。例如,如果传入的 User 对象有属性 name="John", age=25, sex="Male",那么实际执行的 SQL 语句将会是:

insert into user(name,age,sex) values('John',25,'Male')

总结来说,这段 <mapper> 标签定义了一个与 com.sakurapaid.mybatis3.demo01.mapper.UserMapper 接口对应的 SQL 映射文件,其中的 <insert> 标签定义了向 user 表中插入用户数据的操作。当在代码中通过 UserMapper 接口调用 addUser 方法并传入一个 User 对象时,MyBatis 会自动执行相应的 SQL 插入语句,将用户数据写入数据库。


测试输出

package com.sakurapaid.mybatis3.demo01.test;import com.sakurapaid.mybatis3.demo01.bean.User;
import com.sakurapaid.mybatis3.demo01.mapper.UserMapper;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.jupiter.api.Test;import java.io.IOException;
import java.io.InputStream;
import java.util.List;/*** 用户测试类*/
public class UserTest {@Testpublic void test() throws IOException {// 加载MyBatis的核心配置文件InputStream is = Resources.getResourceAsStream("mybatis-config.xml");// 使用配置文件构建SqlSessionFactoryBuilder对象SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();// 通过SqlSessionFactoryBuilder构建SqlSessionFactory对象SqlSessionFactory sqlSessionFactory = builder.build(is);// 打开一个SqlSession会话// true的作用:自动提交事务,默认为falseSqlSession sqlSession = sqlSessionFactory.openSession(true);// 获取UserMapper接口的代理对象UserMapper userMapper = sqlSession.getMapper(UserMapper.class);// 1.添加用户User user = new User(0, "小明", 18, "男");int i = userMapper.addUser(user);if (i > 0) {System.out.println("添加成功");} else {System.out.println("添加失败");}}
}


2.3. 修改数据

UserMapper.java

package com.sakurapaid.mybatis3.demo01.mapper;import com.sakurapaid.mybatis3.demo01.bean.User;public interface UserMapper {// 1.添加用户public int addUser(User user);// 2.修改用户public int updateUser(User user);   
}

UserMapper.xml

这里的 <update>标签就不用我多说了吧(ノ ̄▽ ̄)

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- 定义mapper接口的命名空间 -->
<mapper namespace="com.sakurapaid.mybatis3.demo01.mapper.UserMapper"><!--1.添加用户--><insert id="addUser" parameterType="User">insert into user(name,age,sex) values(#{name},#{age},#{sex})</insert><!--2.修改用户--><update id="updateUser" parameterType="User">update user set name=#{name},age=#{age},sex=#{sex} where id=#{id}</update>
</mapper>

测试输出

package com.sakurapaid.mybatis3.demo01.test;import com.sakurapaid.mybatis3.demo01.bean.User;
import com.sakurapaid.mybatis3.demo01.mapper.UserMapper;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.jupiter.api.Test;import java.io.IOException;
import java.io.InputStream;
import java.util.List;/*** 用户测试类*/
public class UserTest {@Testpublic void test() throws IOException {// 加载MyBatis的核心配置文件InputStream is = Resources.getResourceAsStream("mybatis-config.xml");// 使用配置文件构建SqlSessionFactoryBuilder对象SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();// 通过SqlSessionFactoryBuilder构建SqlSessionFactory对象SqlSessionFactory sqlSessionFactory = builder.build(is);// 打开一个SqlSession会话// true的作用:自动提交事务,默认为falseSqlSession sqlSession = sqlSessionFactory.openSession(true);// 获取UserMapper接口的代理对象UserMapper userMapper = sqlSession.getMapper(UserMapper.class);// 1.添加用户/*User user = new User(0, "小明", 18, "男");int i = userMapper.addUser(user);if (i > 0) {System.out.println("添加成功");} else {System.out.println("添加失败");}*/// 2.修改用户User user = new User(1, "萨达姆", 26, "男");int i = userMapper.updateUser(user);if (i > 0) {System.out.println("修改成功");} else {System.out.println("修改失败");}}}


2.4. 查询数据

UserMapper.java

package com.sakurapaid.mybatis3.demo01.mapper;import com.sakurapaid.mybatis3.demo01.bean.User;import java.util.List;public interface UserMapper {// 1.添加用户public int addUser(User user);// 2.修改用户public int updateUser(User user);// 3.查询所有用户public List<User> findAllUser();
}

UserMapper.xml

这里的 <select>标签就不用我多说了吧ヽ( ̄▽ ̄)ノ

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- 定义mapper接口的命名空间 -->
<mapper namespace="com.sakurapaid.mybatis3.demo01.mapper.UserMapper"><!--1.添加用户--><insert id="addUser" parameterType="User">insert into user(name,age,sex) values(#{name},#{age},#{sex})</insert><!--2.修改用户--><update id="updateUser" parameterType="User">update user set name=#{name},age=#{age},sex=#{sex} where id=#{id}</update><!--3.查询所有用户--><select id="findAllUser" resultType="User">select * from user</select>
</mapper>

测试输出

package com.sakurapaid.mybatis3.demo01.test;import com.sakurapaid.mybatis3.demo01.bean.User;
import com.sakurapaid.mybatis3.demo01.mapper.UserMapper;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.jupiter.api.Test;import java.io.IOException;
import java.io.InputStream;
import java.util.List;/*** 用户测试类*/
public class UserTest {@Testpublic void test() throws IOException {// 加载MyBatis的核心配置文件InputStream is = Resources.getResourceAsStream("mybatis-config.xml");// 使用配置文件构建SqlSessionFactoryBuilder对象SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();// 通过SqlSessionFactoryBuilder构建SqlSessionFactory对象SqlSessionFactory sqlSessionFactory = builder.build(is);// 打开一个SqlSession会话// true的作用:自动提交事务,默认为falseSqlSession sqlSession = sqlSessionFactory.openSession(true);// 获取UserMapper接口的代理对象UserMapper userMapper = sqlSession.getMapper(UserMapper.class);// 1.添加用户/*User user1 = new User(0, "小明", 18, "男");int i = userMapper.addUser(user1);if (i > 0) {System.out.println("添加成功");} else {System.out.println("添加失败");}*/// 2.修改用户/*User user2 = new User(1, "萨达姆", 26, "男");int i = userMapper.updateUser(user2);if (i > 0) {System.out.println("修改成功");} else {System.out.println("修改失败");}*/// 3.查询所有用户List<User> users = userMapper.findAllUser();if (!users.isEmpty()) {for (User user : users) {System.out.println(user);}} else {System.out.println("没有数据");}}}


2.5. 删除数据

UserMapper.java

package com.sakurapaid.mybatis3.demo01.mapper;import com.sakurapaid.mybatis3.demo01.bean.User;import java.util.List;public interface UserMapper {// 1.添加用户public int addUser(User user);// 2.修改用户public int updateUser(User user);// 3.查询所有用户public List<User> findAllUser();// 4.根据id删除指定用户public int deleteUserById(int id);
}

UserMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- 定义mapper接口的命名空间 -->
<mapper namespace="com.sakurapaid.mybatis3.demo01.mapper.UserMapper"><!--1.添加用户--><insert id="addUser" parameterType="User">insert into user(name,age,sex) values(#{name},#{age},#{sex})</insert><!--2.修改用户--><update id="updateUser" parameterType="User">update user set name=#{name},age=#{age},sex=#{sex} where id=#{id}</update><!--3.查询所有用户--><select id="findAllUser" resultType="User">select * from user</select><!--4.根据id删除指定用户--><delete id="deleteUserById" parameterType="int">delete from user where id=#{id}</delete>
</mapper>

测试输出

package com.sakurapaid.mybatis3.demo01.test;import com.sakurapaid.mybatis3.demo01.bean.User;
import com.sakurapaid.mybatis3.demo01.mapper.UserMapper;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.jupiter.api.Test;import java.io.IOException;
import java.io.InputStream;
import java.util.List;/*** 用户测试类*/
public class UserTest {@Testpublic void test() throws IOException {// 加载MyBatis的核心配置文件InputStream is = Resources.getResourceAsStream("mybatis-config.xml");// 使用配置文件构建SqlSessionFactoryBuilder对象SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();// 通过SqlSessionFactoryBuilder构建SqlSessionFactory对象SqlSessionFactory sqlSessionFactory = builder.build(is);// 打开一个SqlSession会话// true的作用:自动提交事务,默认为falseSqlSession sqlSession = sqlSessionFactory.openSession(true);// 获取UserMapper接口的代理对象UserMapper userMapper = sqlSession.getMapper(UserMapper.class);// 1.添加用户/*User user1 = new User(0, "小明", 18, "男");int i = userMapper.addUser(user1);if (i > 0) {System.out.println("添加成功");} else {System.out.println("添加失败");}*/// 2.修改用户/*User user2 = new User(1, "萨达姆", 26, "男");int i = userMapper.updateUser(user2);if (i > 0) {System.out.println("修改成功");} else {System.out.println("修改失败");}*/// 3.查询所有用户/*List<User> users = userMapper.findAllUser();if (!users.isEmpty()) {for (User user : users) {System.out.println(user);}} else {System.out.println("没有数据");}*/// 4.根据id删除指定用户int i = userMapper.deleteUserById(4);if (i > 0) {System.out.println("删除成功");} else {System.out.println("删除失败");}}}


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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Div2 D. Effects of Anti Pimples

解题思路 将由小到大排序若不考虑绿色的情况则为最大值的情况为&#xff0c;即选择在它之前的点对于同时选,会被统计贡献时考虑考虑绿色&#xff0c;对于每个&#xff0c;若选则均选对于每个预处理出&#xff0c;记作对由小到大排序为答案的情况为 …

基于springboot实现网上订餐系统项目【项目源码+论文说明】

基于springboot实现网上订餐系统演示 摘要 随着我国经济的飞速发展&#xff0c;人们的生活速度明显加快&#xff0c;在餐厅吃饭排队的情况到处可见&#xff0c;近年来由于新兴IT行业的空前发展&#xff0c;它与传统餐饮行业也进行了新旧的结合&#xff0c;很多餐饮商户开始通过…

关于SpringBoot你需要了解这些

文章目录 写在前面官网上是这么去描述springboot以及总结springboot特点的springBoot特点 spring核心流程简图Springboot常用注解springBoot自动装配原理手写如何自定义starterSpringBoot是如何启动tomcat的 写在前面 springBoot官网 官网上是这么去描述springboot以及总结spri…

数组的概述

数组的概述 为什么需要数组 需求分析1&#xff1a; 需要统计某公司50个员工的工资情况&#xff0c;例如计算平均工资、找到最高工资等。用之前知识&#xff0c;首先需要声明50个变量来分别记录每位员工的工资&#xff0c;这样会很麻烦。因此我们可以将所有的数据全部存储到一…

网际协议 - IP

文章目录 目录 文章目录 前言 1 . 网际协议IP 1.1 网络层和数据链路层的关系 2. IP基础知识 2.1 什么是IP地址? 2.2 路由控制 3. IP地址基础知识 3.1 IP地址定义 3.2 IP地址组成 3.3 IP地址分类 3.4 子网掩码 IP地址分类导致浪费? 子网与子网掩码 3.5 CIDR与…

一口气搞懂分库分表 12 种分片算法,大厂都在用

大家好&#xff0c;我是小富&#xff5e; 前言 本文是《ShardingSphere5.x分库分表原理与实战》系列的第五篇文章&#xff0c;我们一起梳理下ShardingSphere框架中的核心部分分片策略和分片算法&#xff0c;其内部针为我们提供了多种分片策略和分片算法&#xff0c;来应对不同…

开发组合:PHP+MySQL 同城社区小程序源码 同城便民信息发布系统源码 源码开源可二开含搭建教程

同城便民信息发布系统源码在提升信息发布效率、促进商家宣传、增强用户互动、实现信息聚合与分类管理、个性化定制与扩展以及数据统计与分析等方面发挥着重要作用。 今天小编给大家分享一个同城社区小程序源码、同城便民信息发布系统源码&#xff0c;开发组合PHPMySQL&#xf…

中间商赚差价?炒金该不该选伦敦金投资代理商?

近期&#xff0c;伦敦金价格受鲍威尔鸽派言论的影响&#xff0c;一度强势冲高突破2200大关&#xff0c;这不光是金价再度刷新历史的新高&#xff0c;而且也是金价首次突破2200。有这么好的涨势&#xff0c;自然很多投资者都想入场去炒伦敦金&#xff0c;但是他们入场的时候会面…

软件推荐 篇三十七:安卓软件推荐IP Tools「IP工具」:全面解析网络状态与管理的必备神器

引言&#xff1a; 随着互联网的普及&#xff0c;网络已经成为我们日常生活中不可或缺的一部分。无论是工作、学习还是娱乐&#xff0c;我们都需要通过网络来进行各种操作。然而&#xff0c;网络问题的出现往往会给我们带来诸多困扰。为了更好地管理和优化网络&#xff0c;我们…

SerpAPI - Search API

文章目录 关于 SerpAPIserpapi & google-search-resultshttp 请求示例&#xff1a; Python 调用示例Basic Examples in PythonSearch BingSearch BaiduSearch YahooSearch YouTubeSearch WalmartSearch eBaySearch NaverSearch Home DepotSearch Apple App StoreSearch Duc…

【中文视觉语言模型+本地部署 】23.08 阿里Qwen-VL:能对图片理解、定位物体、读取文字的视觉语言模型 (推理最低12G显存+)

项目主页&#xff1a;https://github.com/QwenLM/Qwen-VL 通义前问网页在线使用——&#xff08;文本问答&#xff0c;图片理解&#xff0c;文档解析&#xff09;&#xff1a;https://tongyi.aliyun.com/qianwen/ 论文v3. : 一个全能的视觉语言模型 23.10 Qwen-VL: A Versatile…

[Java基础揉碎]抽象类

目录 通过问题引出 介绍 关键点 细节 ​编辑 抽象类的最佳设计模式--模版设计模式 1.先用最容易想到的方法 2.分析问题&#xff0c;提出使用模板设计模式 通过问题引出 假如我们有个动物类, 动物都有eat吃的方法, 但是具体吃什么, 我们不知道, 因为是什么动物我们不知道…