|
php.net | support | documentation | report a bug | advanced search | search howto | statistics | random bug | login |
PatchesPull RequestsHistoryAllCommentsChangesGit/SVN commits
[2005-07-18 20:39 UTC] tony2001@php.net
[2005-07-18 20:40 UTC] derick@php.net
[2005-07-19 13:43 UTC] nlopess@php.net
|
|||||||||||||||||||||||||||
Copyright © 2001-2025 The PHP GroupAll rights reserved. |
Last updated: Mon Nov 03 17:00:01 2025 UTC |
Description: ------------ Estou realizando um insert. Consigo gravar no banco, por?m est? me ocasionando erro de duplicidade. ? como se o IIS guardasse o comando e o enviasse novamente. Reproduce code: --------------- Trabalho com php e estou fazendo uma conex?o sybase. Primeiro - como sei no php se estou usando sybase-ct ou sybase-db? Segundo - o que e melhor para se trabalhar sybase_pconnect ou sybase_connect? Olha s? estou fazendo o seguinte insert: for ($i = 0; $i <= $total_itens; $i++) { include "inc_busca_conexao_syb.php"; // Grava dados do formul?rio. $item = $_POST["item_$i"]; $descricao = $_POST["descricao_$i"]; if ($item) { $sql = "INSERT INTO tabela "; $sql .= "(coi_item, cos_prot_destino, dat_solicitacao, stv_descricao, "; $sql .= "cos_prot_origem, stc_status) "; $sql .= "values ("; $sql .= "$item, '$prot_destino', convert(datetime,'$data_solicitacao', 103), "; $sql .= "'$descricao','$prot_origem', 'N' "; $sql .= ")"; $resultado = sybase_query(trim($sql),$db_conexao->db_connect_id); sybase_free_result($resultado); sybase_close($db_conexao->db_connect_id); } precisei abrir e fechar a conex?o dentro do for, pois estava dando erro de duplicidade o tempo todo. N?o consegui descobrir o porque. Minha conex?o est? da seguinte forma: $db_user = "xxxxx"; //usuario do banco $db_passwd = "yyyyy"; //senha do usuario $db_database = "BBBBB"; //nome da base de dados $db_server = "CCCCCCC"; //nome da base de dados require("inc_conectardb_syb.php"); $db_conexao = new sql_db; $db_conexao->sql_db($db_server,$db_user,$db_passwd,$db_database) or die ("Falha na chamada de conex?o"); sybase_select_db($db_database, $db_conexao->db_connect_id) or die ("Falha na sele??o do database"); define("SQL_LAYER","sql-sybase"); class sql_db { var $db_connect_id; var $result; var $next_id; var $num_rows = array(); var $current_row = array(); var $field_names = array(); var $field_types = array(); var $result_rowset = array(); var $num_queries = 0; // // Constructor // function sql_db($sqlserver, $sqluser, $sqlpassword, $database, $persistency = false) { $this->persistency = $persistency; $this->server = $sqlserver; $this->user = $sqluser; $this->password = $sqlpassword; $this->dbname = $database; ($this->db_connect_id = ($this->persistency) ? sybase_pconnect ($this->server, $this->user, $this->password) : sybase_connect($this->server, $this->user, $this->password)); return ( $this->db_connect_id ) ? $this->db_connect_id : false; } } TEM COMO ME AJUDAR. N?O QUERIA ABRIR E FECHAR CONEX?O A CADA PASSADA NO FOR. 1 usu?rio(s) lendo este t?pico (0 visitantes e 0 usu?rios an?nimos)