通过主键列进行关联

时间:2012-11-23 14:31:54

标签: mysql

我有两个表,其中包含不等数据行,需要通过“第三方”列进行关联。此第三方列是两个表的DATETIME主键。

以下是表格

|XKey       |XColumn            |
|-------------------------------|
|2012-01-00 |0.17
|2012-02-00 |0.24
|2012-03-00 |0.33
|2012-04-00 |0.41
|--------------------------------




Y TABLE
=======

|YKey       |YColumn            |
|-------------------------------|
|2012-01-01 |0.21
|2012-01-15 |0.12
|2012-02-01 |0.26
|2012-02-15 |0.27
|2012-03-01 |0.14
|2012-03-15 |0.11
|2012-04-01 |0.74
|2012-04-15 |0.66
|2012-05-01 |0.14
|--------------------------------

y表中的值应与x表中xkey值小于或等于相应ykey值的相应值相关。

这个准备好的声明只是产生空值!我能俯瞰什么?

SET @sql_run =  CONCAT(
        'SET @correl = (SELECT (1/(?-1))*SUM(((a.'
        ,XColumn
        ,' - ?)/?)*((b.'
        ,YColumn
        ,' - ?)/?)) FROM '
        ,XTable
        ,' a JOIN '
        ,YTable
        ,' b ON a.'
        ,XKey
        ,' <= b.'
        ,YKey
        ,' GROUP BY a.'
        ,XKey
        ,', b.'
        ,YKey
        ,' HAVING COUNT(a.'
        ,XKey
        ,') < 2 ORDER BY a.'
        ,XKey
        ,', b.'
        ,YKey
        ,')'
        );      
PREPARE statement_run FROM @sql_run ;
EXECUTE statement_run USING @num, @x_avg, @x_std, @y_avg, @y_std ;
DEALLOCATE PREPARE statement_run ;

在xtable am中辅助了日期值现在得到错误'子查询返回多行“

1 个答案:

答案 0 :(得分:0)

您的XKey日期值无效。尝试将它们设置为月份的第一个而不是0。