Package org.nutz.dao.sql

Examples of org.nutz.dao.sql.PojoCallback


    final Object value = lnk.getValue(obj);
    if (Lang.length(value) == 0)
      return;

    // 从宿主对象更新关联对象
    opt.add(Pojos.createRun(new PojoCallback() {
      public Object invoke(Connection conn, ResultSet rs, Pojo pojo) throws SQLException {
        lnk.updateLinkedField(obj, value);
        return pojo.getOperatingObject();
      }
    }).setOperatingObject(obj));

    // 为其循环生成插入语句 : holder.getEntityBy 会考虑到集合和数组的情况的
    final Entity<?> en = lnk.getLinkedEntity();
    Lang.each(value, new Each<Object>() {
      public void invoke(int i, Object ele, int length) throws ExitLoop, LoopException {
        // 执行插入
        opt.addInsert(en, ele);
        // 更新字段
        opt.add(Pojos.createRun(new PojoCallback() {
          public Object invoke(Connection conn, ResultSet rs, Pojo pojo)
              throws SQLException {
            lnk.saveLinkedField(obj, pojo.getOperatingObject());
            return pojo.getOperatingObject();
          }
View Full Code Here


  public void visit(final Object obj, final LinkField lnk) {
    Pojo pojo = opt.maker().makeQuery(lnk.getLinkedEntity());
    pojo.setOperatingObject(obj);
    pojo.append(Pojos.Items.cnd(lnk.createCondition(obj)));
    pojo.setAfter(new PojoCallback() {
      public Object invoke(Connection conn, ResultSet rs, Pojo pojo) throws SQLException {
        Object value = lnk.getCallback().invoke(conn, rs, pojo);
        lnk.setValue(obj, value);
        return value;
      }
View Full Code Here

                    // 普通条件
                    else {
                        pojo.append(new ConditionPItem(cnd));
                    }
                }
                pojo.setAfter(new PojoCallback() {
                    public Object invoke(Connection conn, ResultSet rs, Pojo pojo) throws SQLException {
                        Object value = lnk.getCallback().invoke(conn, rs, pojo);
                        lnk.setValue(obj, value);
                        return value;
                    }
View Full Code Here

        final Object value = lnk.getValue(obj);
        if (Lang.length(value) == 0)
            return;

        // 从宿主对象更新关联对象
        opt.add(Pojos.createRun(new PojoCallback() {
            public Object invoke(Connection conn, ResultSet rs, Pojo pojo) throws SQLException {
                lnk.updateLinkedField(obj, value);
                return pojo.getOperatingObject();
            }
        }).setOperatingObject(obj));

        // 为其循环生成插入语句 : holder.getEntityBy 会考虑到集合和数组的情况的
        final Entity<?> en = lnk.getLinkedEntity();
        Lang.each(value, new Each<Object>() {
            public void invoke(int i, Object ele, int length) throws ExitLoop, LoopException {
                // 执行插入
                opt.addInsert(en, ele);
                // 更新字段
                opt.add(Pojos.createRun(new PojoCallback() {
                    public Object invoke(Connection conn, ResultSet rs, Pojo pojo)
                            throws SQLException {
                        lnk.saveLinkedField(obj, pojo.getOperatingObject());
                        return pojo.getOperatingObject();
                    }
View Full Code Here

    public void visit(final Object obj, final LinkField lnk) {
        Pojo pojo = opt.maker().makeQuery(lnk.getLinkedEntity());
        pojo.setOperatingObject(obj);
        pojo.append(Pojos.Items.cnd(lnk.createCondition(obj)));
        pojo.setAfter(new PojoCallback() {
            public Object invoke(Connection conn, ResultSet rs, Pojo pojo) throws SQLException {
                Object value = lnk.getCallback().invoke(conn, rs, pojo);
                lnk.setValue(obj, value);
                return value;
            }
View Full Code Here

                    // 普通条件
                    else {
                        pojo.append(new ConditionPItem(cnd));
                    }
                }
                pojo.setAfter(new PojoCallback() {
                    public Object invoke(Connection conn,
                                         ResultSet rs,
                                         Pojo pojo) throws SQLException {
                        Object value = lnk.getCallback().invoke(conn, rs, pojo);
                        lnk.setValue(obj, value);
View Full Code Here

        final Object value = lnk.getValue(obj);
        if (Lang.length(value) == 0)
            return;

        // 从宿主对象更新关联对象
        opt.add(Pojos.createRun(new PojoCallback() {
            public Object invoke(Connection conn, ResultSet rs, Pojo pojo) throws SQLException {
                lnk.updateLinkedField(obj, value);
                return pojo.getOperatingObject();
            }
        }).setOperatingObject(obj));

        // 为其循环生成插入语句 : holder.getEntityBy 会考虑到集合和数组的情况的
        final Entity<?> en = lnk.getLinkedEntity();
        Lang.each(value, new Each<Object>() {
            public void invoke(int i, Object ele, int length) throws ExitLoop, LoopException {
              if (ele == null)
                throw new NullPointerException("null ele in linked field!!");
                // 执行插入
                opt.addInsert(en, ele);
                // 更新字段
                opt.add(Pojos.createRun(new PojoCallback() {
                    public Object invoke(Connection conn, ResultSet rs, Pojo pojo)
                            throws SQLException {
                        lnk.saveLinkedField(obj, pojo.getOperatingObject());
                        return pojo.getOperatingObject();
                    }
View Full Code Here

TOP

Related Classes of org.nutz.dao.sql.PojoCallback

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.