No, it isn't. The error you're getting is that the string data (for example, 7000) will not fit into the intended column. If you want to insert the number 7000, omit the quotes.
You can forget about all this with DBI by using placeholders. Your statement would be something like:
my $sthC = $dbh->prepare("insert TABLE (col1, col2, ...)
values(?, ?, ?)")
or die "Couldn't prepare: $DBI::errstr";
$sthC->execute('value1', 'value2', ...)
or die "Couldn't execute: $DBI::errstr";
The nice thing is that Perl offers you many ways to tidy that up. For example, if you have an array containing the values to be inserted, you can pass that to execute. Also, you can format the SQL string using all the power of the language. My personal preference is usually something like this (this isn't working code, just an example):
my @values = qw(...);
my $sql = q{
insert
table
( col1
, col2
, ...
)
values
};
$sql .= '(' . join(',', ('?') x scalar(@values)) . ')';
my $sth = $dbh->prepare($sql)
or die "Couldn't prepare $sql: $DBI::errstr";
$sth->execute(@values)
or die "Couldn't execute $sql: $DBI::errstr";
HTH
UPDATE Expanded example. |