mysql的错误1292_Mysql错误:错误代码:1292 . 截断不正确的DOUBLE值

我在mySQL中执行此存储过程时收到此错误:

错误代码:1292 . 截断错误的DOUBLE值:'WHERE s.name ='确认'AND bp.id =''

DROP PROCEDURE IF EXISTS test;

DELIMITER //

CREATE PROCEDURE test (province VARCHAR(100), country VARCHAR(100), departureDate TIMESTAMP, arrivalDate TIMESTAMP, people INTEGER)

BEGIN

DECLARE selectClause VARCHAR(500) DEFAULT "SELECT DISTINCT b.id, b.boat_model_id, b.port_id, b.address_id, b.maximum_discount,

b.discounts_have_subtotals, b.skipper_type_id, b.length, b.people_capacity_id,

b.simple_cabin_id, b.double_cabin_id, b.bathroom_id, year_id ";

DECLARE fromClause VARCHAR(500) DEFAULT "FROM states s, boat_people bp, boat_prices bprd, boat_prices bpra, boats b ";

DECLARE whereClause VARCHAR(1000) DEFAULT "WHERE s.name = 'Confirmed'

AND bp.id = " + people + "

AND b.state_id = s.id

AND b.id NOT IN (SELECT bc.boat_id

FROM boat_calendars bc

WHERE (date(bc.since) <= " + departureDate + " AND date(bc.until) >= " + departureDate + ")

OR (date(bc.since) <= " + arrivalDate + " AND date(bc.until) >= " + arrivalDate + "))

AND bprd.boat_id = b.id

AND date(bprd.since) <= " + departureDate + " AND date(bprd.until) >= " + departureDate + "

AND bpra.boat_id = b.id

AND date(bpra.since) <= " + arrivalDate + " AND date(bpra.until) >= " + arrivalDate + "

AND truncate(((bprd.weekly_price + bpra.weekly_price)/2), 2) > 0";

SET @queryClause = concat(selectClause, fromClause, whereClause);

PREPARE stmt FROM @queryClause;

EXECUTE stmt;

DEALLOCATE PREPARE stmt;

END //

CALL test('Mallorca (Islas Baleares)', 'España', '2016-03-02 16:02:12', '2016-03-02 16:02:12', 1);

表boat_people.id是INT(11) .

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值