Package cn.org.rapid_framework.generator.provider.db.sql.model

Examples of cn.org.rapid_framework.generator.provider.db.sql.model.Sql


  }
 
  public void test_delete_myisam_user_sql() throws Exception {
//    DataSourceProvider.getConnection().close();
//    GeneratorProperties.reload();
    Sql selectSql  = new SqlFactory().parseSql("delete from user_info ");
    GeneratorModel gm = newFromQuery(selectSql);
    g.generateBy(gm.templateModel, gm.filePathModel);
  }
View Full Code Here


    GeneratorModel gm = newFromQuery(selectSql);
    g.generateBy(gm.templateModel, gm.filePathModel);
  }

  public void test_update_sql() throws Exception {
    Sql selectSql  = new SqlFactory().parseSql("update user_info set username = :username where password = :password and age=:age and sex=:sex");
    GeneratorModel gm = newFromQuery(selectSql);
    g.generateBy(gm.templateModel, gm.filePathModel);
  }
View Full Code Here

    g.generateBy(gm.templateModel, gm.filePathModel);
  }

  public void test_insert_sql() throws Exception {
      try {
    Sql selectSql  = new SqlFactory().parseSql("insert into user_info values(:username,:password,:age,:sex,:userid,:blog)");
    GeneratorModel gm = newFromQuery(selectSql);
    g.generateBy(gm.templateModel, gm.filePathModel);
    fail("数据类型应该匹配不正确");
      }catch(Exception e) {
          e.printStackTrace();
View Full Code Here

          e.printStackTrace();
      }
  }

    public void test_insert_sql_with_right_name() throws Exception {
        Sql selectSql  = new SqlFactory().parseSql("insert into user_info values(:user_id,:username,:password,:birth_date,:sex,:age)");
        GeneratorModel gm = newFromQuery(selectSql);
        g.generateBy(gm.templateModel, gm.filePathModel);
    }
View Full Code Here

        g.generateBy(gm.templateModel, gm.filePathModel);
    }
    
  public void test_insert_into() {
    try {
    Sql selectSql  = new SqlFactory().parseSql("insert into user_info (username,password,age) values(?,?,?)");
    fail("非空的userId不能为空,应该不能执行至这里");
    }catch(Exception e) {
    }
  }
View Full Code Here

    }
  }
 
  public void test_sql_error() throws Exception {
    try {
      Sql selectSql  = new SqlFactory().parseSql("update user_info1 set username = :username where password = :password and age=:age and sex=:sex");
      fail();
    }catch(Exception e){
      assertTrue(true);
    }
   
    try {
      Sql selectSql  = new SqlFactory().parseSql("insert into user_info (username,password) values(?,?,?)");
      fail();
    }catch(Exception e){
      assertTrue(true);
    }
   
    try {
      Sql selectSql  = new SqlFactory().parseSql("delete from user_info where 123username1javaeye = :username and password123 = :password and age=:age and sex=:sex");
      fail("列错误");
    }catch(Exception e){
      e.printStackTrace();
      assertTrue(true);
    }
   
    try {
      Sql selectSql  = new SqlFactory().parseSql("select * from user_info where username = :username and password =:password and age=1:age ");
      fail();
    }catch(Exception e){
      assertTrue(true);
    }
   
    try {
      Sql selectSql  = new SqlFactory().parseSql("insert into userinfo2 values(:username,:password,:age,:sex)");
      fail();
    }catch(Exception e){
      assertTrue(true);
    }
  }
View Full Code Here

    generatorFacade.setGenerator(g);
  }
 
  public void test_generate_by_sql() throws Exception {
    generatorFacade.getGenerator().addTemplateRootDir(new File("for_test_select_sql"));
    Sql sql = new SqlFactory().parseSql("select * from user_info where username=#username# and password=#password#");
    sql.setMultiplicity("many")//many or one
    sql.setOperation("findByUsernameAndPassword");
    sql.setRemarks("根据用户名及密码进行查询");
    generatorFacade.generateBySql(sql);
   
  }
View Full Code Here

//      String unscapedSourceSql = StringHelper.unescapeXml(beforeProcessedSql);
      String namedSql = SqlParseHelper.convert2NamedParametersSql(beforeProcessedSql,":","");
        ParsedSql parsedSql = NamedParameterUtils.parseSqlStatement(namedSql);
        String executeSql = new BasicSqlFormatter().format(NamedParameterUtils.substituteNamedParameters(parsedSql));
       
        Sql sql = new Sql();
        sql.setSourceSql(sourceSql);
        sql.setExecuteSql(executeSql);
        GLogger.debug("\n*******************************");
        GLogger.debug("sourceSql  :"+sql.getSourceSql());
        GLogger.debug("namedSql  :"+namedSql);
        GLogger.debug("executeSql :"+sql.getExecuteSql());
        GLogger.debug("*********************************");
       
        Connection conn = null;
        PreparedStatement ps = null;
        try {
          conn = DataSourceProvider.getNewConnection();
          conn.setAutoCommit(false);
//          if(DatabaseMetaDataUtils.isMysqlDataBase(conn.getMetaData())){
//            conn.setReadOnly(true);
//          }
          ps = conn.prepareStatement(SqlParseHelper.removeOrders(executeSql));
         
          SqlParametersParser sqlParametersParser = new SqlParametersParser();
            sqlParametersParser.execute(parsedSql,sql);
           
          ResultSetMetaData resultSetMetaData = executeSqlForResultSetMetaData(executeSql,ps,sqlParametersParser.allParams);
            sql.setColumns(new SelectColumnsParser().convert2Columns(sql,resultSetMetaData));
            sql.setParams(sqlParametersParser.params);
         
          return afterProcessedSql(sql);
        }catch(SQLException e) {
          throw new RuntimeException("execute sql occer error,\nexecutedSql:"+SqlParseHelper.removeOrders(executeSql),e);
        }catch(Exception e) {
View Full Code Here

          try {
                IbatisSqlMapConfigParser ibatisSqlMapConfigParser = new IbatisSqlMapConfigParser();
        String sqlString = ibatisSqlMapConfigParser.parse(op.getSql(),toMap(table.includeSqls));
                String namedSql = SqlParseHelper.convert2NamedParametersSql(sqlString,":",""); // TODO 确认要删除本行?,因为与SqlFactory里面的代码重复
               
                Sql sql = new SqlFactory().parseSql(namedSql);
                sql.setSqlSegments(ibatisSqlMapConfigParser.getSqlSegments());
               
                LinkedHashSet<SqlParameter> finalParameters = addExtraParams2SqlParams(op.getExtraparams(), sql);
                sql.setParams(finalParameters);
                sql.setColumns(processWithCustomColumns(getCustomColumns(table),sql.getColumns()));
               
                String ibatisSql = getIbatisSql(op, sql);
                sql.setIbatisSql(ibatisSql);
                sql.setMybatisSql(sql.replaceWildcardWithColumnsSqlName(SqlParseHelper.convert2NamedParametersSql(op.getSql(),"#{","}"))  + " "+op.getAppend()); // FIXME 修正ibatis3的问题
               
                sql.setOperation(op.getName());
                sql.setParameterClass(op.getParameterClass());
                sql.setResultClass(op.getResultClass());
                sql.setRemarks(op.getRemarks());
                sql.setPaging(op.isPaging());
                sql.setSqlmap(op.getSqlmap());
                sql.setResultMap(op.getResultMap());
               
                //FIXME 增加insert append="nowait"至 CDATA ]]>结尾的前面
               
                if(StringHelper.isNotBlank(op.getMultiplicity())) {
                    sql.setMultiplicity(op.getMultiplicity());
                }
               
                //FIXME 与dalgen的规则是否一致
                if(StringHelper.isNotBlank(op.getParamtype())) {
                    sql.setParamType(op.getParamtype());
                }else if(StringHelper.isBlank(op.getParamtype()) && (sql.isSelectSql() || sql.isDeleteSql())) {
                    sql.setParamType(Sql.PARAMTYPE_PRIMITIVE);
                }
               
                sql.afterPropertiesSet();
                return afterProcessed(sql,op,table);
          }catch(Exception e) {
                throw new RuntimeException("parse sql error on table:"+table.getSqlName()+" operation:"+op.getName()+"() sql:"+op.getSql(),e);
            }
        }
View Full Code Here

//      String unscapedSourceSql = StringHelper.unescapeXml(beforeProcessedSql);
      String namedSql = SqlParseHelper.convert2NamedParametersSql(beforeProcessedSql,":","");
        ParsedSql parsedSql = NamedParameterUtils.parseSqlStatement(namedSql);
        String executeSql = new BasicSqlFormatter().format(NamedParameterUtils.substituteNamedParameters(parsedSql));
       
        Sql sql = new Sql();
        sql.setSourceSql(sourceSql);
        sql.setExecuteSql(executeSql);
        GLogger.debug("\n*******************************");
        GLogger.debug("sourceSql  :"+sql.getSourceSql());
        GLogger.debug("namedSql  :"+namedSql);
        GLogger.debug("executeSql :"+sql.getExecuteSql());
        GLogger.debug("*********************************");
       
        Connection conn = DataSourceProvider.getConnection();
        try {
          if(!DatabaseMetaDataUtils.isHsqlDataBase(conn.getMetaData())){
            conn.setReadOnly(true);
          }
          conn.setAutoCommit(false);
          PreparedStatement ps = conn.prepareStatement(SqlParseHelper.removeOrders(executeSql));
          ResultSetMetaData resultSetMetaData = executeForResultSetMetaData(executeSql,ps);
            sql.setColumns(new SelectColumnsParser().convert2Columns(sql,resultSetMetaData));
          sql.setParams(new SqlParametersParser().parseForSqlParameters(parsedSql,sql));
         
          return afterProcessedSql(sql);
        }catch(SQLException e) {
          throw new RuntimeException("execute sql occer error,\nexecutedSql:"+SqlParseHelper.removeOrders(executeSql),e);
        }catch(Exception e) {
View Full Code Here

TOP

Related Classes of cn.org.rapid_framework.generator.provider.db.sql.model.Sql

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.