亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫(kù)
最近訪問板塊 發(fā)新帖
查看: 3086 | 回復(fù): 7
打印 上一主題 下一主題

奇怪的字符串打印問題 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2009-06-15 21:49 |只看該作者 |倒序?yàn)g覽
字符串是


  1. my $sql = << "EOS";
  2. UPDATE virus
  3.     SET longlat = GeomFromText
  4.     ( 'POINT ( $long $lat ) ', 4326 )
  5.     WHERE id = (
  6.         SELECT vir_id FROM sequence WHERE accession = '$acc'
  7.     );
  8. EOS
復(fù)制代碼


其中 $long, $lat 和 $acc 是變量。


  1. print $sql, "\n";
復(fù)制代碼


結(jié)果就成了


  1. UPDATE virus
  2.     SET longlat = GeomFromText
  3. ) ', 4326 ) ( 78.96288 20.593684
  4.     WHERE id = (
  5.         SELECT vir_id FROM sequence WHERE accession = 'FJ904812'
  6.     );
復(fù)制代碼


其中
$acc = 'FJ904812'
$long = 78.96288
$lat = 20.593684

一下子不清楚是什么原因?

論壇徽章:
95
程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-05 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-17 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-18 06:20:002015亞冠之阿爾艾因
日期:2015-09-18 10:35:08月度論壇發(fā)貼之星
日期:2015-09-30 22:25:002015亞冠之阿爾沙巴布
日期:2015-10-03 08:57:39程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-10-05 06:20:00每日論壇發(fā)貼之星
日期:2015-10-05 06:20:002015年亞冠紀(jì)念徽章
日期:2015-10-06 10:06:482015亞冠之塔什干棉農(nóng)
日期:2015-10-19 19:43:35程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-10-21 06:20:00每日論壇發(fā)貼之星
日期:2015-09-14 06:20:00
2 [報(bào)告]
發(fā)表于 2009-06-15 23:30 |只看該作者
試下這個(gè)
lee@debian:/tmp$ cat t.pl
#!/usr/bin/perl
use strict;
use warnings;

my $acc = 'FJ904812';
my $long = 78.96288;
my $lat = 20.593684;

my $sql = << "EOS";
UPDATE virus
    SET longlat = GeomFromText
( 'POINT ( $long $lat ) ', 4326 )
    WHERE id = (
    SELECT vir_id FROM sequence WHERE accession = '$acc'
);
EOS

print $sql, "\n";
lee@debian:/tmp$ ./t.pl
UPDATE virus
    SET longlat = GeomFromText
( 'POINT ( 78.96288 20.593684 ) ', 4326 )
    WHERE id = (
    SELECT vir_id FROM sequence WHERE accession = 'FJ904812'
);

[ 本帖最后由 MMMIX 于 2009-6-15 23:31 編輯 ]

論壇徽章:
1
雙魚座
日期:2014-08-25 19:13:11
3 [報(bào)告]
發(fā)表于 2009-06-16 00:46 |只看該作者

回復(fù) #2 MMMIX 的帖子

暈死。。。不小心點(diǎn)到了臭蛋,是在抱歉。。。我本無惡意,不知道如何取消!

論壇徽章:
0
4 [報(bào)告]
發(fā)表于 2009-06-16 10:57 |只看該作者

回復(fù) #2 MMMIX 的帖子

謝謝 MMMIX!

不過還是不明白為什么會(huì)出現(xiàn)這樣的問題。

是否是因?yàn)樵谳敵鲎址蛿?shù)值時(shí),由于變量替換,perl 當(dāng)成了運(yùn)算?

[ 本帖最后由 longbow0 于 2009-6-16 11:00 編輯 ]

論壇徽章:
95
程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-05 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-17 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-18 06:20:002015亞冠之阿爾艾因
日期:2015-09-18 10:35:08月度論壇發(fā)貼之星
日期:2015-09-30 22:25:002015亞冠之阿爾沙巴布
日期:2015-10-03 08:57:39程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-10-05 06:20:00每日論壇發(fā)貼之星
日期:2015-10-05 06:20:002015年亞冠紀(jì)念徽章
日期:2015-10-06 10:06:482015亞冠之塔什干棉農(nóng)
日期:2015-10-19 19:43:35程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-10-21 06:20:00每日論壇發(fā)貼之星
日期:2015-09-14 06:20:00
5 [報(bào)告]
發(fā)表于 2009-06-16 10:59 |只看該作者
原帖由 longbow0 于 2009-6-16 10:57 發(fā)表
謝謝 MMMIX!

不過還是不明白為什么會(huì)出現(xiàn)這樣的問題。

把你能復(fù)現(xiàn)問題的完整代碼貼上來。

論壇徽章:
0
6 [報(bào)告]
發(fā)表于 2009-06-16 12:29 |只看該作者
一切正常啊
loser@loserking:~/chinaunix$ ./print.pl
UPDATE virus
    SET longlat = GeomFromText
    ( 'POINT ( 78.96288 20.593684 ) ', 4326 )
    WHERE id = (
        SELECT vir_id FROM sequence WHERE accession = 'FJ904812'
    );

論壇徽章:
1
雙魚座
日期:2014-08-25 19:13:11
7 [報(bào)告]
發(fā)表于 2009-06-16 12:57 |只看該作者

回復(fù) #1 longbow0 的帖子

不知道你想說什么。。。

論壇徽章:
0
8 [報(bào)告]
發(fā)表于 2009-06-16 13:41 |只看該作者
我想找到原因了。

為了捕獲數(shù)據(jù)庫(kù)更新的異常,用了 eval {};同時(shí)要處理的數(shù)據(jù)很多,把 $sql 查詢的構(gòu)造語句也放到了 eval {} 塊中。


  1. eval {
  2.     while (<IN>) {
  3.         my ($acc, $long, $lat) = split(/,/, $_)
  4.    
  5.         my $sql = << "EOS";
  6. UPDATE virus
  7.     SET longlat = GeomFromText
  8. ( 'POINT ( $long $lat ) ', 4326 )
  9.     WHERE id = (
  10.     SELECT vir_id FROM sequence WHERE accession = '$acc'
  11. );
  12. EOS

  13.         print $sql, "\n";    # 這里出錯(cuò)

  14.         $dbh->do($sql);
  15.     }
  16.     $dbh->commit;
  17. };

  18. if ($@) {
  19.     $dbh->rollback;
  20. }
復(fù)制代碼
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國(guó)互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP