java中的占位符

【前言】
       最近自己负责设计和开发一套公司的通知系统,比如:短信提醒,推送通知等等;在设计的时候采用了消息模版和变量的方式来组装内容从而提高系统的扩展性。

【经典案例】
       一、场景简介

               1、通知系统一般有模版,比如一个通知模版为  %s 先生/女士,您好!您的尾号(%s)的银行卡,余额是(%s)元

               2、为了拼出完整的内容,需要相应的变量,比如:张三;567;10000

               3、程序实现:

   

public static void main(String[] args) {
        String mod = "%s 先生/女士,您好!您的尾号(%s)的银行卡,余额是(%s)元";
        String variable = "张三;567;10000";
        String context = String.format(mod, variable.split(";"));
        System.out.println(context);
        
    }


       二、巧用占位符

               1、产品两个需求:

                 (1)某天产品来了个需求需要将短信变更不需要带xxx 先生/女士,内容变更为您好!您的尾号(567)的银行卡,余额是(10000)元

                 (2)某某天产品又来了个需求将短信内容变更为您好!您的余额是(10000)元的且尾号(567)的银行卡正在被消费

               2、纵使当时心里有千万只草泥马在奔腾;奔腾过后还是得老老实实的改N个系统的N处代码,测试,发布上线;

                  (1)针对1中需求(1)需要将短信模版需要变更为  您好!您的尾号(%s)的银行卡,余额是(%s)元 而且短信变量变更为 567;10000 

                  (2)针对1中需求(2)需要将短信模版需要变更为  您好!您的余额是(%s)元的且尾号(%s)的银行卡正在被消费 而且短信变量变更为 10000;567 

               3、有没有更好的解决方案那?在针对需求变更总结后发现,无非是在模版中改变变量的位置以及将变量的个数在减少;突然联想到占位符{n}

               4、模版调整为{0} 先生/女士,您好!您的尾号({1})的银行卡,余额是({2})元

               5、程序实现

   

 public static void main(String[] args) {
        String mod = "{0} 先生/女士,您好!您的尾号({1})的银行卡,余额是({2})元";
        String variable = "张三;567;10000";
        String context = MessageFormat.format(mod, variable.split(";"));
        System.out.println(context);
 
    }


               6、如何应对产品的需求

                    1中产品提到的需求(1),只需将模版调整为 您好!您的尾号({1})的银行卡,余额是({2})元

                    1中产品提到的需求(2),只需将模版调整为 您好!您的余额是({2})元的且尾号({1})的银行卡正在被消费

               注:一般模版都会在数据库和缓存中存放,只需要更换一下数据库和缓存中的模版就OK了。

【总结】
         将知识运用到具体的业务场景中,不断思考去把系统做的更加灵活扩展性更加的强。
 

### Java SQL PreparedStatement 占位符使用方法 在Java中,`PreparedStatement` 接口用于执行预编译的SQL语句。这种类型的语句可以包含一个或多个参数占位符(即 `?`),这些占位符可以在运行时被具体的值替换。 #### 创建PreparedStatement对象并设置参数 当创建了一个带有问号作为占位符的SQL查询字符串之后,可以通过调用连接对象上的适当方法来获取对应的 `PreparedStatement` 实例: ```java Connection conn = DriverManager.getConnection(url, user, password); String sql = "SELECT * FROM users WHERE sname=? AND spassword=?"; PreparedStatement pstmt = conn.prepareStatement(sql); ``` 接着,通过调用 `pstmt.setXXX()` 方法为每个占位符提供实际的数据值,在这里 `XXX` 表示数据类型名称,比如 `setString`, `setInt` 等等。对于上述例子中的两个占位符来说,则应如下操作[^2]: ```java pstmt.setString(1, username); // 设置第一个占位符(?) pstmt.setString(2, password); // 设置第二个占位符(?) ``` #### 执行查询与处理结果集 一旦所有的参数都被正确设置了,就可以像下面这样去执行这个准备好的陈述,并获得返回的结果集合: ```java ResultSet rs = pstmt.executeQuery(); while(rs.next()){ System.out.println("User Name: "+rs.getString("sname")); } ``` 需要注意的是,如果尝试直接传入整个含有未转义字符或其他特殊符号的字符串给 `executeQuery(String)` 函数而没有事先准备好相应的 `PreparedStatement` 对象的话,那么很可能会遇到异常情况[^1]。 另外值得注意的一点是在某些特定情况下,例如涉及到函数调用的时候,可能需要手动调整SQL模板以适应不同的数据库驱动程序的行为差异。例如,在向 ClickHouse 数据库插入带精度控制的小数时,应该按照以下方式构建SQL语句[^4]: ```sql insert into table (name, core) values (?, toDecimal64(?,4)) ``` 最后提醒一点关于性能优化方面的问题:相比于普通的 `Statement` 而言,`PreparedStatement` 不仅能够防止SQL注入攻击,而且由于其内部实现了SQL语句缓存机制的缘故,在多次重复执行相同的SQL命令时效率更高一些[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值