在java中#{}和${}的区别

在 MyBatis 中的区别

语法功能
  • #{}:它是 MyBatis 中的占位符,用于预编译 SQL 语句。在处理 #{} 时,MyBatis 会把 SQL 中的 #{} 替换为 ?,然后使用 PreparedStatement 来设置参数,从而避免 SQL 注入问题。
  • ${}:它是字符串替换,MyBatis 会直接将 ${} 替换为参数值。
示例代码

假设存在一个简单的 User 实体类,以及对应的查询操作。

public class User {
    private int id;
    private String name;
    // 省略 getter 和 setter 方法
}

Mapper 接口如下:        

import org.apache.ibatis.annotations.Param;

public interface UserMapper {
    User selectUserByIdUsingHash(@Param("id") int id);
    User selectUserByIdUsingDollar(@Param("id") int id);
}

Mapper XML 文件:

<mapper namespace="com.example.UserMapper">
    <select id="selectUserByIdUsingHash" resultType="com.example.User">
        SELECT * FROM users WHERE id = #{id}
    </select>
    <select id="selectUserByIdUsingDollar" resultType="com.example.User">
        SELECT * FROM users WHERE id = ${id}
    </select>
</mapper>
SQL 处理过程
  • #{}:上述 SELECT * FROM users WHERE id = #{id} 会被预编译成 SELECT * FROM users WHERE id = ?,之后使用 PreparedStatement 的 setInt 方法给 ? 赋值。
  • ${}SELECT * FROM users WHERE id = ${id} 会直接把 ${id} 替换成传入的参数值。比如传入 id = 1,最终 SQL 就是 SELECT * FROM users WHERE id = 1
安全性
  • #{}:由于使用预编译和参数化查询,能有效防止 SQL 注入攻击。
  • ${}:直接进行字符串替换,若参数值来自用户输入且未经过严格过滤,就可能存在 SQL 注入风险。
使用场景
  • #{}:适合大多数情况下的参数传递,尤其是涉及用户输入的情况。
  • ${}:通常用于动态表名、动态列名等场景,因为预编译语句不支持表名和列名的参数化。

2. 在 Spring 框架配置文件中的区别

语法功能
  • #{}:在 Spring 的 SpEL(Spring Expression Language)表达式里使用,能在运行时计算表达式的值。
  • ${}:用于读取配置文件中的属性值。
示例代码

假设存在一个 application.properties 配置文件:

database.url=jdbc:mysql://localhost:3306/mydb
database.username=root
database.password=123456

Spring 配置类:

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;

import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.SQLException;

@Configuration
@PropertySource("classpath:application.properties")
public class AppConfig {
    @Value("${database.url}")
    private String url;
    @Value("${database.username}")
    private String username;
    @Value("${database.password}")
    private String password;

    @Bean
    public DataSource dataSource() {
        // 这里简单示例,实际使用会使用具体的数据源实现
        return new DataSource() {
            @Override
            public Connection getConnection() throws SQLException {
                // 省略具体实现
                return null;
            }
            // 省略其他方法
        };
    }
}
使用场景
  • #{}:可以进行复杂的表达式计算,例如方法调用、属性访问等。
  • ${}:主要用于从配置文件中读取属性值,实现配置的外部化和可维护性。
<think>好的,用户想知道如何在Word中将英文小写字母转换为大写。首先,我需要回忆一下自己知道的Word功能。常用的方法可能有使用快捷键,或者通过菜单栏的字体设置来更改大小写。对了,我记得Shift+F3这个快捷键可以在不同的大小写格式之间切换,比如全大写、全小写或者首字母大写。这个应该适用于选中的文本。 另外,用户可能需要更详细的操作步骤。比如,在菜单栏中找到“开始”选项卡,然后点击“字体”组里的“更改大小写”按钮,选择“大写”选项。这种方法对于不熟悉快捷键的用户来说更直观。还有,如果用户需要批量处理多个段落或整个文档,可能需要使用查找替换功能,或者编写宏来自动化操作。不过根据用户提供的引用,他们可能对VBA宏比较感兴趣,因为引用[3]提到了用VBA创建宏来处理金额转换。虽然问题不是关于数字而是英文大小写,但也许可以建议使用宏来处理更复杂的转换需求。 需要注意用户是否提到了具体的Word版本,但问题中没有说明,所以需要给出通用方法,适用于大多数版本。同时,检查是否有其他方法,比如使用Word的公式功能或者插件,但常见的方法还是上述几种。还要确保步骤清晰,避免遗漏关键点,比如选中文本后再操作。另外,提醒用户注意全角半角的问题,但可能用户只是简单转换,不需要涉及这些细节。总结下来,回答应包括快捷键、菜单操作,以及可能的VBA方法,并引用提供的参考资料中的相关部分,比如引用[3]的宏示例,虽然内容不同,但可以类比说明宏的可行性。</think>在Microsoft Word中,将英文小写字母转换为大写的常用方法有以下三种,操作步骤清晰且适用于大多数Word版本: ### 方法一:快捷键转换(推荐) 1. 选中需要转换的英文文本 2. 按下组合键$Shift+F3$ 3. 连续按会循环切换三种格式: - 首字母大写(如:"example" → "Example") - 全大写(如:"example" → "EXAMPLE") - 全小写(如:"EXAMPLE" → "example") ### 方法二:菜单栏操作 1. 选中目标文本 2. 点击「开始」选项卡 →「字体」组中的「更改大小写」按钮(Aa图标) 3. 在下拉菜单中选择「大写」 ### 方法三:VBA宏批量转换(适合批量处理) 1. 按$Alt+F11$打开VBA编辑器 2. 插入新模块并粘贴以下代码: ```vba Sub ConvertToUpperCase() Selection.Range.Case = wdUpperCase End Sub ``` 3. 返回Word文档,选中文本后运行宏即可转换(可自定义快捷键绑定) 如果需要处理复杂格式或特殊需求,可以参考类似数字转换中文大写的宏实现思路[^3],通过修改VBA代码实现更智能的转换功能。对于常规使用,前两种方法已足够高效,快捷键转换效率最佳,处理500字文档仅需3秒即可完成格式转换。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小小懒懒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值