Statement与PrepareStatement问题

  1. Statement执行 ,其实是拼接sql语句的。 先拼接sql语句,然后在一起执行。

     String sql = "select * from t_user where username='"+ username  +"' and password='"+ password +"'";
    
     UserDao dao = new UserDaoImpl();
     dao.login("admin", "100234khsdf88' or '1=1");
    
     SELECT * FROM t_user WHERE username='admin' AND PASSWORD='100234khsdf88' or '1=1' 
    
     前面先拼接sql语句, 如果变量里面带有了 数据库的关键字,那么一并认为是关键字。 不认为是普通的字符串。 
     rs = st.executeQuery(sql);
    

PrepareStatement

该对象就是替换前面的statement对象。

  1. 相比较以前的statement, 预先处理给定的sql语句,对其执行语法检查。 在sql语句里面使用 ? 占位符来替代后续要传递进来的变量。 后面进来的变量值,将会被看成是字符串,不会产生任何的关键字。

     	String sql = "insert into t_user values(null , ? , ?)";
     	 ps = conn.prepareStatement(sql);
     	 
     	 //给占位符赋值 从左到右数过来,1 代表第一个问号, 永远你是1开始。
     	 ps.setString(1, userName);
     	 ps.setString(2, password);
    
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值