Производительность хранимых процедур CLR от SQL ServerC#

Место общения программистов C#
Ответить
Anonymous
 Производительность хранимых процедур CLR от SQL Server

Сообщение Anonymous »

У меня есть хранящаяся процедура SQL CLR, которая анализирует строку tlvber, эта процедура CLR называется каждый раз, когда команда отправляется в DB, ​​есть 6 команд. < /p>
Команды 6 представляют одну транзакцию. Соответствующий столбец/таблица. Важно, чтобы этот тег существовал в DB, ​​я проверяю его через запрос. Кодировал весь процесс в CLR, я сделал много запросов и вставки и обновлений. В целом легче кодировать из C#, чем t-sql. < /p>
под другой рукой, я подумал вставить все теги в одну таблицу, и
ссылаться на эти теги с помощью идентификатора, потому что если я храню все теги в одной таблице
, я буду хранить теги всех команд, отправленных в Database. Тысячи транзакций в минуту. < /p>
В CLR я должен запросить данные из DB (могут ли запросы поставить под угрозу обработку времени из CLR?). < /p>
Следующая проблема находится в конце каждых париров Таблица /столбец, где вставлен или обновляется. Чтобы избежать запуска запросов из CLR, вместо этого было бы лучше запросить необходимые данные в T-SQL и отправить их в CLR, чтобы этот процесс обрабатывал данные и не проводит какого-либо взаимодействия с DB (без подключений, которые генерируют задержки, только обработка данных). Вставки и обновления < /p>
EXEC SP_CLR_PARSEATLVBER @TLV= '00102001010010010100100201007F010101',
@error=@ERRORCLR OUTPUT,
@CMD='OPN'

while (cursor 127)
{
InsertaLog.CommandText = "INSERT INTO DBO.LOGDB values " +
" ('PARSEATLVBER', " +
"'TAG SUPERA LONGITUD'," +
" '227'," +
" SYSDATETIME()" +
" )";
InsertaLog.ExecuteNonQuery();
varlength = 0;
// --*******************AVANCE EN LA CADENA*******************
cursor = cursor + 2;
InsertaLog.CommandText = "INSERT INTO DBO.LOGDB values " +
" ('PARSEATLVBER', " +
" 'Cursor despues de extraer tamaño de TAG(" + tag + "):" +cursor+ "'," +
" '237'," +
" SYSDATETIME()" +
" )";
InsertaLog.ExecuteNonQuery();
// -- /////////////////////////////////////
TotalBytes = varlength - 128;
InsertaLog.CommandText = "INSERT INTO DBO.LOGDB values " +
" ('PARSEATLVBER', " +
" 'Total de Bytes Asignados de la longitud del TAG(" + tag + "):" + TotalBytes+"',"+
" '246'," +
" SYSDATETIME()" +
" )";
InsertaLog.ExecuteNonQuery();
length = TLV.ToString().ToCharArray(cursor, 2);
foreach (char c in length)
Slength = Slength + c;
InsertaLog.CommandText = "INSERT INTO DBO.LOGDB values " +
" ('PARSEATLVBER', " +
" 'TAMAÑO DE TAG:" + Slength + "'," +
" '257'," +
" SYSDATETIME()" +
" )";
InsertaLog.ExecuteNonQuery();
Int32.TryParse(Slength, NumberStyles.HexNumber,
new CultureInfo("en-US"), out varlength);
InsertaLog.CommandText = "INSERT INTO DBO.LOGDB values " +
" ('PARSEATLVBER', " +
" 'TAMAÑO DE TAG(INT):" + varlength.ToString() + "'," +
" '266'," +
" SYSDATETIME()" +
" )";
InsertaLog.ExecuteNonQuery();
varlength = varlength * 2;
//--*******************AVANCE EN LA CADENA*******************
cursor = cursor + (TotalBytes * 2);
// -- /////////////////////////////////////
}
else
{
length = TLV.ToString().ToCharArray(cursor, 2);
Slength = "";
foreach (char c in length)
Slength = Slength + c;
Int32.TryParse(Slength, NumberStyles.HexNumber,
new CultureInfo("en-US"), out varlength);
//--*******************AVANCE EN LA CADENA*******************
cursor = cursor + 2;
InsertaLog.CommandText = "INSERT INTO DBO.LOGDB values " +
" ('PARSEATLVBER', " +
" 'Slength:" + Slength + "'," +
" '286'," +
" SYSDATETIME()" +
" )";
InsertaLog.ExecuteNonQuery();
InsertaLog.CommandText = "INSERT INTO DBO.LOGDB values " +
" ('PARSEATLVBER', " +
" 'TAMAÑO DE TAG(INT):" + varlength.ToString() + "'," +
" '294'," +
" SYSDATETIME()" +
" )";
InsertaLog.ExecuteNonQuery();
// -- /////////////////////////////////////
}
//-- /////////////////////////////////////
//-- * ******************EXTRAE VALOR DE TAG EXTRAIDO *******************
value = TLV.ToString().ToCharArray(cursor, varlength);
foreach (char c in value)
Svalue = Svalue + c;
SeleccionaTipoDato.CommandText = "SELECT dbo.TAGS.tipodato" +
" FROM dbo.TAGS" +
" WHERE dbo.TAGS.id_tag = '" + tag + "'";
SeleccionaTipoDato.Connection = conn;
reader = SeleccionaTipoDato.ExecuteReader();
while (reader.Read())
{
tipoDato = reader.GetSqlString(0).ToString();
}
InsertaLog.CommandText = "INSERT INTO DBO.LOGDB values " +
" ('PARSEATLVBER', " +
" 'TipoDato:" + tipoDato.ToString() + "'," +
" '294'," +
" SYSDATETIME()" +
" )";
InsertaLog.ExecuteNonQuery();
reader.Close();
if (tipoDato.Equals("ASCII"))
{
Convertidor C = new Convertidor();
valorParseadoASCII=C.ValueToASCII(Svalue);
}
cursor = cursor + varlength;
//-- /////////////////////////////////////
//-- ******************* Tabla para agregar tags con su respectivo valor *******************
Tupla.Add(Stag);
Tupla.Add(Svalue);
if(tag.Equals("0x2005"))
TID = Svalue;
if(tag.Equals("0x1003"))
MID = Svalue;
if (tag.Equals("0xE001"))
xid = Convert.ToInt64(Svalue);
CMD.Add(Tupla);
InsertaLog.CommandText = "INSERT INTO DBO.LOGDB values " +
" ('PARSEATLVBER', " +
" 'Tupla Agregada: (" + Tupla[0]+","+Tupla[1] + ")'," +
" '320'," +
" SYSDATETIME()" +
" )";
InsertaLog.ExecuteNonQuery();
Tupla.Clear();
Svalue = "";
Slength = "";
Stag = "";
//-- /////////////////////////////////////
}
// INSERCION DE CAMPO LLAVE
if (cmd.Equals("OPN"))
{
SeleccionaNuevaLLave.CommandText = "SELECT NEXT VALUE FOR dbo.llave";
reader = SeleccionaNuevaLLave.ExecuteReader();
while (reader.Read())
SecuenciaLlave = Convert.ToInt64(reader.GetSqlString(0));
reader = SeleccionaNuevaLLave.ExecuteReader();
SeleccionaNuevaTransId.CommandText = "SELECT NEXT VALUE FOR dbo.transid";
while (reader.Read())
SecuenciaTransid = Convert.ToInt64(reader.GetSqlString(0));
InsertaNuevaTransaccion.CommandText = "INSERT INTO dbo.transaccion"+
" values (xid,trans_id,mid,tid)" +
" ("+SecuenciaLlave + "," +
SecuenciaTransid + "," +
MID + "," +
TID +
" )";
InsertaNuevaTransaccion.CommandText = "INSERT INTO DBO.AMT (xid) values (" + SecuenciaLlave +")"; InsertaNuevaTransaccion.ExecuteNonQuery();
InsertaNuevaTransaccion.CommandText = "INSERT INTO DBO.CRD (xid) values (" + SecuenciaLlave + ")"; InsertaNuevaTransaccion.ExecuteNonQuery();
InsertaNuevaTransaccion.CommandText = "INSERT INTO DBO.DMO (xid) values (" + SecuenciaLlave + ")"; InsertaNuevaTransaccion.ExecuteNonQuery();
InsertaNuevaTransaccion.CommandText = "INSERT INTO DBO.HST (xid) values (" + SecuenciaLlave + ")"; InsertaNuevaTransaccion.ExecuteNonQuery();
InsertaNuevaTransaccion.CommandText = "INSERT INTO DBO.MRC (xid) values (" + SecuenciaLlave + ")"; InsertaNuevaTransaccion.ExecuteNonQuery();
InsertaNuevaTransaccion.CommandText = "INSERT INTO DBO.PRO (xid) values (" + SecuenciaLlave + ")"; InsertaNuevaTransaccion.ExecuteNonQuery();
InsertaNuevaTransaccion.CommandText = "INSERT INTO DBO.RCV (xid) values (" + SecuenciaLlave + ")"; InsertaNuevaTransaccion.ExecuteNonQuery();
InsertaNuevaTransaccion.CommandText = "INSERT INTO DBO.SND (xid) values (" + SecuenciaLlave + ")"; InsertaNuevaTransaccion.ExecuteNonQuery();
}
else
{
SecuenciaLlave = xid;
}

int j = 0;
String tabla,columna;
foreach (ArrayList A in CMD)
{
SeleccionaTipoDato.CommandText = "SELECT dbo.TAGS.tabla,"+
" dbo.TAGS.columna" +
" FROM dbo.TAGS" +
" WHERE dbo.TAGS.id_tag = '" + A[0].ToString() + "'";
reader = SeleccionaTipoDato.ExecuteReader();
while (reader.Read())
{
tabla = reader.GetSqlString(0).ToString();
columna = reader.GetSqlString(1).ToString();
ActualizaTabla.CommandText = "UPDATE "
+tabla+
" SET "
+columna+"='"+A[1]+"'"+
" where "+tabla+".xid="+SecuenciaLlave;
ActualizaTabla.ExecuteNonQuery();
}
}
< /code>
Игнорируйте вставки в dbo.logdb, они предназначены для отладки, другие запросы и вставки и обновления-это критический процесс. Задержка вызова запросов и вставки и обновлений.>

Подробнее здесь: https://stackoverflow.com/questions/347 ... sql-server
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»