diff --git a/src/cursor.cpp b/src/cursor.cpp index 5d7d80a4..08002453 100644 --- a/src/cursor.cpp +++ b/src/cursor.cpp @@ -873,8 +873,6 @@ static PyObject* execute(Cursor* cur, PyObject* pSql, PyObject* params, bool ski Py_XDECREF(prevParam->pObject); newParam.BufferLength = newParam.StrLen_or_Ind; newParam.StrLen_or_Ind = SQL_DATA_AT_EXEC; - Py_INCREF(cell); - newParam.pObject = cell; *prevParam = newParam; if(prevParam->ParameterValuePtr == &newParam.Data) { diff --git a/src/params.cpp b/src/params.cpp index c17a9197..6d3e6b49 100644 --- a/src/params.cpp +++ b/src/params.cpp @@ -1266,6 +1266,7 @@ bool BindParameter(Cursor* cur, Py_ssize_t index, ParamInfo& info) { // Bind the TVP's columns --- all need to use DAE PyObject *param = PySequence_GetItem(row, i); + Py_XDECREF(param); GetParameterInfo(cur, i, param, info.nested[i], true); info.nested[i].BufferLength = info.nested[i].StrLen_or_Ind; info.nested[i].StrLen_or_Ind = SQL_DATA_AT_EXEC;