WEB开发 - CGI/perl - 应用技巧
   
Perl语言中向数据库中写值的特殊字符问题
 
 



我在编程中遇到过一些这样的问题,就是其他任何操作都正常,但是,用户在页面上输入的数据却写不到数据库中去。后来,经过仔细的检查,发现用户输入的数据中含有一些特殊字符,例如单引号、双引 号等。
这时,可以采用DBI的quote方法进行处理。具体的处理过程如下:
举例说明:
需要输入数据库的数据列名为city,值为Xi'an
use DBI;
my $dsn="DBI:mysql:$db_name:localhost";
my $dbh=DBI->connect($dsn,$db_user,$db_pass,{RaiseError=>1});

my $city=$dbh->quote("Xi'an");
$dbh->do(qq{insert into citylist values($city)});
$dbh->disconnect();

这样,数据就可以顺利的写入数据库了。
其实,quote方法的本质就是使用一种特殊的符号作为数值的分界符,避免和我们常用的特殊字符发生冲突,导致数据库操作失败。

 
上一篇      目录      下一篇
来源:unknown
本站相关教 程
如何在win98/NT上添加perl语言的各种模块
关于GD模块的语法和使用
perl与Mysql连接
使用Perl编写CGI时需要注意的几个问题
perl模块和包的使用
Perl的运算符号字符概述
联网调试CGI程序心得
Perl在CGI程序设计中常用的函数和指令