0

我正试图让这个程序发挥作用,这让我很难过。我只是希望此过程使用 CSV 值表中的分隔值填充临时表。

DELIMITER $$

DROP PROCEDURE IF EXISTS String_Split $$

CREATE PROCEDURE String_Split
(
    vString VARCHAR(255),
    vSeparator VARCHAR(5)
)
BEGIN

DECLARE vDone tinyint(1) DEFAULT 1;
DECLARE vIndex INT DEFAULT 1;
DECLARE vSubString VARCHAR(15);

DROP TABLE IF EXISTS tmpValues;
CREATE TEMPORARY TABLE tmpValues (tmpVal VARCHAR(255));

WHILE vDone > 0 DO
    SET vSubString = SUBSTRING(vString, vIndex,
    IF(LOCATE(vSeparator, vString, vIndex) > 0,
        LOCATE(vSeparator, vString, vIndex) - vIndex,
        LENGTH(vString)
        ));
    IF LENGTH(vSubString) > 0 THEN
        SET vIndex = vIndex + LENGTH(vSubString) + 1;
        INSERT INTO tmpValues VALUES (vSubString);
    ELSE
        SET vDone = 0;
    END IF;
END WHILE;

END; $$

我呼吁:

CALL String_Split(my_csv.keywords, ',');

我得到了这个:错误代码:1109。字段列表中的未知表“my_csv”

我没有得到这个,因为表在那里并且选择了适当的数据库。

CREATE TABLE `my_csv` (
`id` int(10) NOT NULL AUTO_INCREMENT,
`keywords` text NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 $$

INSERT INTO `my_csv` () VALUES
(1, 'featured, 3/8, Diamond, Engagement Ring, 14K, White Gold, Gold'),
(2, '1/3, Diamond, Engagement Ring, 14K, White Gold, Gold'),
(3, 'featured') $$
4

1 回答 1

0

而不是在调用函数中调用表名和字段,需要先获取值,然后调用过程。这是一个工作示例

SELECT @keyword :=keywords from my_csv;
CALL String_Split(@keyword, ',');

编辑: 那只抓住了最后一行。这一个选择了所有这些。此外,这样做vSeparator过程中的变量太小,所以我将其增加到 255。

SELECT @keyword :=group_concat(keywords) FROM my_csv;
CALL String_Split(@keyword, ',');
select * from tmpValues;
于 2013-08-15T20:58:17.953 回答