MySQL的简单操作方法:PreparedStatement

preparedStatement 的两种使用方式:

方式1:使用preparedStatement选择数据,读取数据:

使用preparedStatement插入数据的数据库:

public boolean saveComment(Comment comment) {

        Connection connection = DBUtil.getConn();
        String sql = "insert into comment values (null,?,?,?,?)";
        PreparedStatement preparedStatement = null;
        boolean flag = false;
        try {
            preparedStatement = connection.prepareStatement(sql);
            preparedStatement.setString(1, comment.getCommenttext() + "");
            preparedStatement.setString(2, comment.getCommenttime() + "");
            preparedStatement.setString(3, comment.getUserid() + "");
            preparedStatement.setString(4, comment.getArticleid() + "");
            int isOk = preparedStatement.executeUpdate();
            if (isOk > 0) {
                return !flag;
            } else {
                return flag;
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        DBUtil.close(connection, null, preparedStatement, null);
        return flag;
    }

 

 

方式2:

 

public int insert(Orders orders){
		
		
//		try {
//			testSessionDowork();
//		} catch (Exception e) {
//			// TODO Auto-generated catch block
//			e.printStackTrace();
//		}
	    
		Session session = getSession();
//		session.beginTransaction().begin();;
		try {
			session.doWork(new Work() {
				
				@Override
				public void execute(Connection arg0) throws SQLException {
					//通过JDBC 原生API 进行操作,效率最高,速度最快
//					String sql = "";
					//preparedStatement = arg0.prepareStatement(sql);//准备执行语句  
					
					//int Res = statement.executeUpdate(sql);
					if(orders == null){
						return ;
					}
					DateFormat simpleDateFormat= new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");   //创建一个格式化日期对象
			        String currentTime = simpleDateFormat.format(orders.getCreateTime());   //格式化后的时间
					String sql = "INSERT INTO orders "
							+ ""
							+ "				( total, create_time, STATUS, pay_status, member_id, ship_area, ship_address, ship_mobile ) "
							+ "   VALUES "
							+ " "
							+ "  			( "+orders.getTotal()+", '"+currentTime+"', '"+orders.getStatus()+"', '"+orders.getPayStatus()+"', '"+orders.getMemberId()+"', '"+orders.getShipArea()+"', '"+orders.getShipAddress()+"', '"+orders.getShipMobile()+"' )";
			        
					System.out.println("orders insert sql :" + sql);
				
					number = preparedStatement.executeUpdate(sql);

					
					System.out.println(number > 0 ? "插入数据成功" : "插入数据失败");
					
				}
			});
			
//			session.getTransaction().commit();
		} catch (Exception e) {
			// TODO: handle exception
			e.printStackTrace();
		}finally{
			doClose(null, preparedStatement, rs);
		}
		
		return number;
	}

 

 

注意:

方式1:

 int isOk = preparedStatement.executeUpdate(); 没有参数sql

方式2:

 number = preparedStatement.executeUpdate(sql);有参数sql

 

 

参考链接:http://blog.csdn.net/xlgen157387/article/details/44891653

 

转载于:https://my.oschina.net/qimhkaiyuan/blog/1584385

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值