zoukankan      html  css  js  c++  java
  • mysql procedure返回多数据集

    返回多数据集写法:
    第一种
     

    DROP PROCEDURE IF EXISTS `p_query_user` ; 
    DELIMITER //  
        CREATE PROCEDURE p_query_user(  p_inout_user_id  INT   )  
        begin
        declare c varchar(100) default '0';
             SELECT * FROM T_SD_USER WHERE USER_ID = p_inout_user_id ;
             SET p_inout_user_id =2222;
    end //
     DELIMITER ; 
    set @uId = 3000 ;
    CALL p_query_user(@uId );
    SELECT @uId ;

    第二种

    mysql>delimiter //
    mysql>drop procedure if exists proc;
    mysql>create procedure proc()
    begin
    create temporary table tmp1 like t;
    insert into tmp1 select * from t;
    create temporary table tmp2 like t;
    insert into tmp2 select * from t;
    end;
    //
    mysql>delimiter ;
    mysql>select * from tmp1;
    mysql>select * from tmp2; 

    注:使用临时表在session级一直可用,再次调用存储过程需要先DROP临时表。

    hibernate call 

    @Test
        public void test0() {
            try {
    
                String procedureSql = "CALL p_query_user( :userId)";
                SQLQuery sqlQuery = t.getSession().createSQLQuery(procedureSql)
                        .addEntity(TSdUser.class);
                Object userId = 3000;
                sqlQuery.setParameter("userId", userId);
                List<TSdUser> result = sqlQuery.list();
                for (TSdUser tSdUser : result) {
                    System.out.println(tSdUser);
                }
                System.out.println(userId);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }

    结果如下:

    Hibernate: CALL p_query_user( ?)
    TSdUser [userSysMlb=100.0, userUseredMlb=633137.0, userDoDiscoverCount=0, userDoCommonsSayCount=0, createTime=2014-05-08 12:20:35.0, lastActivateSystemMsgTime=2014-07-17 12:10:00.0, lastActivateSusCommentMsgTime=2014-05-08 12:20:35.0, lastActivateNegativeMsgTime=2014-06-17 10:27:37.0, lastActivatePraiseMsgTime=2014-05-08 12:20:35.0, lastActiveTime=2014-08-11 18:45:52.0, priMsgTime=2014-08-09 14:30:27.0, lockTime=null, userMark=null, userSubMark=null, userRemark=null, userInfo=null, userLoginIp=127.0.0.1, userLogginPhoneCode=13724770797, userRegisterInfo=null, userRealName=null, userRegisterPhoneCode=13724770797, userRegistrationCity=null, userPhoneCity=湛江, userDeviceType=Android, userLoginQqId=1, userLoginWeiXinId=null, userLoginSinaBlogId=null, userWeiXinOpenId=111, cteateType=1, restaurantWeiXinOpenId=222, weiXinSubscribeTime=2014-05-17 13:29:28.0, weiXinSubscribeStatus=SUBSCRIBE, weiXinUnSubscribeTime=null, userId=3000, userName=MJorcen, userTotalMlb=1.1111111E7, userDoAttentionCount=0, userReAttentionCount=0, userDoPraiseCount=0, userRePraiseCount=11, userDoNegativeCount=0, userReNegativeCount=6, userDoShowDetailCount=38, userDoGetVoucherCount=5, userDoUsedVoucherCount=2, userPhone=13724770797, userGender=G, userGrade=0, userHeader=null]

    或者:

        @Test
        public void test1() {
            try {
    
                String procedureSql = "CALL p_query_user(?)";
                Connection connection = t.getSession().connection();
                Object userId = 3000;
                java.sql.CallableStatement cs = connection
                        .prepareCall(procedureSql);
                cs.setInt(1, 3000);
                
                cs.registerOutParameter("p_inout_user_id", Types.INTEGER);
                cs.execute();
                int patams1 = cs.getInt(1);
                ResultSet resultSet = cs.getResultSet();
                while (resultSet.next()) {
                    System.out.println(resultSet.getInt("USER_ID"));
                }
                System.out.println(patams1);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }

     一个网上的例子;

    public String callFirstProcedures(final long qyid, final int pdys) {
        String procedureSql = "{call get_qyaqdcpdjb(?,?,?)}";
        Object pj = jdbcTemplate.execute(procedureSql,
                new CallableStatementCallback() {
                    public Object doInCallableStatement(CallableStatement cs)
                            throws SQLException, DataAccessException {
                        cs.setLong(1, qyid);
                        cs.setInt(2, pdys);
                        //你需要注册一个输出参数
                        cs.registerOutParameter(3, Types.VARCHAR);
                        cs.execute();
                        return cs.getString(3);
                    }
                });
        return HtmsUtils.formatObject(pj);
    }
  • 相关阅读:
    《代码整洁之道》之四 注释
    《代码整洁之道》之三 函数
    《代码整洁之道》之二 有意义的命名
    《代码整洁之道》
    Hibernate学习笔记
    Struts2复习笔记
    学习Spring必学的Java基础知识
    Eclipse下搭建Maven框架
    onvif实现
    rtmp服务端实现
  • 原文地址:https://www.cnblogs.com/mjorcen/p/3915125.html
Copyright © 2011-2022 走看看