Grails 2.4.4 executeQuery()用于连接数据库表中的表

时间:2017-04-05 20:34:43

标签: grails gorm executequery

这是我的域代码。

class Btr {

    Date dateBreak
    int timeBreak
    String typeBreak
    User usuario

    static constraints = {
    }

    static mapping = {

      }
}


class User {

    String name
    String user
    String password
    String confirmPassword
    String state
    String extent
    String movileNumber
    String email
    String address
    Rol rol



    static constraints = {

    }

    static mapping = {

    }
}

这是我的控制器的代码。

def df = new SimpleDateFormat("yyyy-MM-dd HH:mm")
def startDate = params.startDate
def stopDate = params.stopDate

resultado = Btr .executeQuery("select dateBreak, timeBreak, typeBreak, 
user, usuario.rol from Btr inner join User on user = usuario.rol where 
dateBreak between :startDate" and :stopDate", [startDate: 
df.parse(startDate), stopDate: df.parse(stopDate)])


render (view: "data", model: [result: resultado])

这是我的观点。

  <g:each in="${result}" var="results" status="i">
    <tr><td>{results.dateBreak}</td><td>{results.timeBreak}</td><td>
    {results.typeBreak} </td><td>${results.usuario.rol}</td></tr>
    </g:each>

然后我在提交表单时收到此错误。 在GSP中,当我打印数据时,

Exception evaluating property 'dateBreak' for java.util.Arrays$ArrayList, Reason: groovy.lang.MissingPropertyException: No such property: dateBreak for class: java.sql.Timestamp 

有人可以请告诉我如何使用executeQuery连接grails中的表格,并且很高兴学习如何使用,withCriteria

1 个答案:

答案 0 :(得分:0)

public static void main(String[] args){
        float pi=0;
        int sign=1;
        for(int i=1; i <= 33554430; i+=2){
            pi += (sign*(1.0/(float)i));
            sign*= -1;
        }
        pi *= 4;
        System.out.println(pi);
    }

应该是

resultado = Btr .executeQuery("select dateBreak, timeBreak, typeBreak, 
user, usuario.rol from Btr inner join User on user = usuario.rol where 
dateBreak between :startDate" and :stopDate", [startDate: 
df.parse(startDate), stopDate: df.parse(stopDate)])

你有什么是原始的sql而不是HQL这是一个轻微的变化并使用实际的域对象加入

对于hasMany使用左连接,它可以是典型的一对一关系的空连接

如果一对一关系可以为null,也可以使用左连接

除此之外,您可以将实际查询作为原始SQL查询,如此

resultado = Btr .executeQuery("""select new map (btr.dateBreak as dateBreak, btr.timeBreak as timeBreak, btr.typeBreak as typeBreak, 
u as user, user.usuario.rol  as rol) from Btr btr join btr.user u where 
btr.dateBreak between :startDate and :stopDate""", [startDate: 
df.parse(startDate), stopDate: df.parse(stopDate)])