From e8412dcd42f6478f70f587d534a92a948cd6dd93 Mon Sep 17 00:00:00 2001 From: Charles Krinke Date: Thu, 17 Jul 2008 13:43:31 +0000 Subject: Mantis#1736. Thank you kindly, StrawberryFride for a patch that: Many issues with handling connections in MSSQL, have rearchitected to ensure that connections are always opened and closed in a timely fashion & disposed of cleanly, and removed unnecessary lock statements. SQL Server performance seems to have improved considerably as a result, and various timeout errors seem to have been fixed. --- OpenSim/Data/MSSQL/AutoClosingSqlCommand.cs | 216 ++++++++++++ OpenSim/Data/MSSQL/MSSQLAssetData.cs | 99 +++--- OpenSim/Data/MSSQL/MSSQLDataStore.cs | 2 +- OpenSim/Data/MSSQL/MSSQLGridData.cs | 123 +++---- OpenSim/Data/MSSQL/MSSQLInventoryData.cs | 357 +++++++++---------- OpenSim/Data/MSSQL/MSSQLLogData.cs | 33 +- OpenSim/Data/MSSQL/MSSQLManager.cs | 141 ++++---- OpenSim/Data/MSSQL/MSSQLUserData.cs | 518 ++++++++++++---------------- 8 files changed, 780 insertions(+), 709 deletions(-) create mode 100644 OpenSim/Data/MSSQL/AutoClosingSqlCommand.cs diff --git a/OpenSim/Data/MSSQL/AutoClosingSqlCommand.cs b/OpenSim/Data/MSSQL/AutoClosingSqlCommand.cs new file mode 100644 index 0000000..6a7d787 --- /dev/null +++ b/OpenSim/Data/MSSQL/AutoClosingSqlCommand.cs @@ -0,0 +1,216 @@ +/* + * Copyright (c) Contributors, http://opensimulator.org/ + * See CONTRIBUTORS.TXT for a full list of copyright holders. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * * Neither the name of the OpenSim Project nor the + * names of its contributors may be used to endorse or promote products + * derived from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY + * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY + * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +using System; +using System.Collections.Generic; +using System.Text; +using System.Data.SqlClient; +using System.Data; + +namespace OpenSim.Data.MSSQL +{ + /// + /// Encapsulates a SqlCommand object but ensures that when it is disposed, its connection is closed and disposed also. + /// + internal class AutoClosingSqlCommand : IDbCommand + { + private SqlCommand realCommand; + + public AutoClosingSqlCommand(SqlCommand cmd) + { + realCommand = cmd; + } + + #region IDbCommand Members + + public void Cancel() + { + realCommand.Cancel(); + } + + public string CommandText + { + get + { + return realCommand.CommandText; + } + set + { + realCommand.CommandText = value; + } + } + + public int CommandTimeout + { + get + { + return realCommand.CommandTimeout; + } + set + { + realCommand.CommandTimeout = value; + } + } + + public CommandType CommandType + { + get + { + return realCommand.CommandType; + } + set + { + realCommand.CommandType = value; + } + } + + IDbConnection IDbCommand.Connection + { + get + { + return realCommand.Connection; + } + set + { + realCommand.Connection = (SqlConnection) value; + } + } + + public SqlConnection Connection + { + get + { + return realCommand.Connection; + } + } + + IDbDataParameter IDbCommand.CreateParameter() + { + return realCommand.CreateParameter(); + } + + public SqlParameter CreateParameter() + { + return realCommand.CreateParameter(); + } + + public int ExecuteNonQuery() + { + return realCommand.ExecuteNonQuery(); + } + + IDataReader IDbCommand.ExecuteReader(CommandBehavior behavior) + { + return realCommand.ExecuteReader(behavior); + } + + public SqlDataReader ExecuteReader(CommandBehavior behavior) + { + return realCommand.ExecuteReader(behavior); + } + + IDataReader IDbCommand.ExecuteReader() + { + return realCommand.ExecuteReader(); + } + + public SqlDataReader ExecuteReader() + { + return realCommand.ExecuteReader(); + } + + public object ExecuteScalar() + { + return realCommand.ExecuteScalar(); + } + + IDataParameterCollection IDbCommand.Parameters + { + get { return realCommand.Parameters; } + } + + public SqlParameterCollection Parameters + { + get { return realCommand.Parameters; } + } + + public void Prepare() + { + realCommand.Prepare(); + } + + IDbTransaction IDbCommand.Transaction + { + get + { + return realCommand.Transaction; + } + set + { + realCommand.Transaction = (SqlTransaction) value; + } + } + + UpdateRowSource IDbCommand.UpdatedRowSource + { + get + { + return realCommand.UpdatedRowSource; + } + set + { + realCommand.UpdatedRowSource = value; + } + } + + #endregion + + #region IDisposable Members + + public void Dispose() + { + SqlConnection conn = realCommand.Connection; + try + { + realCommand.Dispose(); + } + finally + { + try + { + conn.Close(); + } + finally + { + conn.Dispose(); + } + } + } + + #endregion + } +} diff --git a/OpenSim/Data/MSSQL/MSSQLAssetData.cs b/OpenSim/Data/MSSQL/MSSQLAssetData.cs index 108ceb1..e0e20df 100644 --- a/OpenSim/Data/MSSQL/MSSQLAssetData.cs +++ b/OpenSim/Data/MSSQL/MSSQLAssetData.cs @@ -86,19 +86,14 @@ namespace OpenSim.Data.MSSQL /// override public AssetBase FetchAsset(LLUUID assetID) { - AssetBase asset = null; - Dictionary param = new Dictionary(); param["id"] = assetID.ToString(); - IDbCommand result = database.Query("SELECT * FROM assets WHERE id = @id", param); - IDataReader reader = result.ExecuteReader(); - - asset = database.getAssetRow(reader); - reader.Close(); - result.Dispose(); - - return asset; + using (IDbCommand result = database.Query("SELECT * FROM assets WHERE id = @id", param)) + using (IDataReader reader = result.ExecuteReader()) + { + return database.getAssetRow(reader); + } } /// @@ -113,15 +108,13 @@ namespace OpenSim.Data.MSSQL } - SqlCommand cmd = - new SqlCommand( + using (AutoClosingSqlCommand cmd = + database.Query( "INSERT INTO assets ([id], [name], [description], [assetType], [local], [temporary], [data])" + " VALUES " + - "(@id, @name, @description, @assetType, @local, @temporary, @data)", - database.getConnection()); - - using (cmd) + "(@id, @name, @description, @assetType, @local, @temporary, @data)")) { + //SqlParameter p = cmd.Parameters.Add("id", SqlDbType.NVarChar); //p.Value = asset.FullID.ToString(); cmd.Parameters.AddWithValue("id", asset.FullID.ToString()); @@ -135,16 +128,8 @@ namespace OpenSim.Data.MSSQL h.Value = asset.Temporary; SqlParameter i = cmd.Parameters.Add("data", SqlDbType.Image); i.Value = asset.Data; - try - { - cmd.ExecuteNonQuery(); - } - catch (Exception) - { - throw; - } - cmd.Dispose(); + cmd.ExecuteNonQuery(); } } @@ -154,38 +139,40 @@ namespace OpenSim.Data.MSSQL /// the asset override public void UpdateAsset(AssetBase asset) { - SqlCommand command = new SqlCommand("UPDATE assets set id = @id, " + + using (IDbCommand command = database.Query("UPDATE assets set id = @id, " + "name = @name, " + "description = @description," + "assetType = @assetType," + "local = @local," + "temporary = @temporary," + "data = @data where " + - "id = @keyId;", database.getConnection()); - SqlParameter param1 = new SqlParameter("@id", asset.FullID.ToString()); - SqlParameter param2 = new SqlParameter("@name", asset.Name); - SqlParameter param3 = new SqlParameter("@description", asset.Description); - SqlParameter param4 = new SqlParameter("@assetType", asset.Type); - SqlParameter param6 = new SqlParameter("@local", asset.Local); - SqlParameter param7 = new SqlParameter("@temporary", asset.Temporary); - SqlParameter param8 = new SqlParameter("@data", asset.Data); - SqlParameter param9 = new SqlParameter("@keyId", asset.FullID.ToString()); - command.Parameters.Add(param1); - command.Parameters.Add(param2); - command.Parameters.Add(param3); - command.Parameters.Add(param4); - command.Parameters.Add(param6); - command.Parameters.Add(param7); - command.Parameters.Add(param8); - command.Parameters.Add(param9); - - try + "id = @keyId;")) { - command.ExecuteNonQuery(); - } - catch (Exception e) - { - m_log.Error(e.ToString()); + SqlParameter param1 = new SqlParameter("@id", asset.FullID.ToString()); + SqlParameter param2 = new SqlParameter("@name", asset.Name); + SqlParameter param3 = new SqlParameter("@description", asset.Description); + SqlParameter param4 = new SqlParameter("@assetType", asset.Type); + SqlParameter param6 = new SqlParameter("@local", asset.Local); + SqlParameter param7 = new SqlParameter("@temporary", asset.Temporary); + SqlParameter param8 = new SqlParameter("@data", asset.Data); + SqlParameter param9 = new SqlParameter("@keyId", asset.FullID.ToString()); + command.Parameters.Add(param1); + command.Parameters.Add(param2); + command.Parameters.Add(param3); + command.Parameters.Add(param4); + command.Parameters.Add(param6); + command.Parameters.Add(param7); + command.Parameters.Add(param8); + command.Parameters.Add(param9); + + try + { + command.ExecuteNonQuery(); + } + catch (Exception e) + { + m_log.Error(e.ToString()); + } } } @@ -228,12 +215,12 @@ namespace OpenSim.Data.MSSQL /// it use mssql_connection.ini override public void Initialise() { - IniFile GridDataMySqlFile = new IniFile("mssql_connection.ini"); - string settingDataSource = GridDataMySqlFile.ParseFileReadValue("data_source"); - string settingInitialCatalog = GridDataMySqlFile.ParseFileReadValue("initial_catalog"); - string settingPersistSecurityInfo = GridDataMySqlFile.ParseFileReadValue("persist_security_info"); - string settingUserId = GridDataMySqlFile.ParseFileReadValue("user_id"); - string settingPassword = GridDataMySqlFile.ParseFileReadValue("password"); + IniFile gridDataMSSqlFile = new IniFile("mssql_connection.ini"); + string settingDataSource = gridDataMSSqlFile.ParseFileReadValue("data_source"); + string settingInitialCatalog = gridDataMSSqlFile.ParseFileReadValue("initial_catalog"); + string settingPersistSecurityInfo = gridDataMSSqlFile.ParseFileReadValue("persist_security_info"); + string settingUserId = gridDataMSSqlFile.ParseFileReadValue("user_id"); + string settingPassword = gridDataMSSqlFile.ParseFileReadValue("password"); database = new MSSQLManager(settingDataSource, settingInitialCatalog, settingPersistSecurityInfo, settingUserId, diff --git a/OpenSim/Data/MSSQL/MSSQLDataStore.cs b/OpenSim/Data/MSSQL/MSSQLDataStore.cs index d9d41e0..46e4107 100644 --- a/OpenSim/Data/MSSQL/MSSQLDataStore.cs +++ b/OpenSim/Data/MSSQL/MSSQLDataStore.cs @@ -1758,7 +1758,7 @@ namespace OpenSim.Data.MSSQL } catch (SqlException) { - m_log.Info("[REGION DB]: MySql Database doesn't exist... creating"); + m_log.Info("[REGION DB]: MS Sql Database doesn't exist... creating"); InitDB(conn); } diff --git a/OpenSim/Data/MSSQL/MSSQLGridData.cs b/OpenSim/Data/MSSQL/MSSQLGridData.cs index 1ed412b..0abd0d0 100644 --- a/OpenSim/Data/MSSQL/MSSQLGridData.cs +++ b/OpenSim/Data/MSSQL/MSSQLGridData.cs @@ -84,17 +84,17 @@ namespace OpenSim.Data.MSSQL /// private void TestTables() { - IDbCommand cmd = database.Query("SELECT TOP 1 * FROM "+m_regionsTableName, new Dictionary()); - - try - { - cmd.ExecuteNonQuery(); - cmd.Dispose(); - } - catch (Exception) + using (IDbCommand cmd = database.Query("SELECT TOP 1 * FROM " + m_regionsTableName, new Dictionary())) { - m_log.Info("[GRID DB]: MSSQL Database doesn't exist... creating"); - database.ExecuteResourceSql("Mssql-regions.sql"); + try + { + cmd.ExecuteNonQuery(); + } + catch (Exception) + { + m_log.Info("[GRID DB]: MSSQL Database doesn't exist... creating"); + database.ExecuteResourceSql("Mssql-regions.sql"); + } } } @@ -103,7 +103,7 @@ namespace OpenSim.Data.MSSQL /// override public void Close() { - database.Close(); + // nothing to close } /// @@ -146,32 +146,22 @@ namespace OpenSim.Data.MSSQL /// Sim profile override public RegionProfileData GetProfileByHandle(ulong handle) { - IDataReader reader = null; + + Dictionary param = new Dictionary(); + param["handle"] = handle.ToString(); + try { - if (database.getConnection().State == ConnectionState.Closed) + using (IDbCommand result = database.Query("SELECT * FROM " + m_regionsTableName + " WHERE regionHandle = @handle", param)) + using (IDataReader reader = result.ExecuteReader()) { - database.Reconnect(); + return database.getRegionRow(reader); } - Dictionary param = new Dictionary(); - param["handle"] = handle.ToString(); - IDbCommand result = database.Query("SELECT * FROM " + m_regionsTableName + " WHERE regionHandle = @handle", param); - reader = result.ExecuteReader(); - - RegionProfileData row = database.getRegionRow(reader); - reader.Close(); - result.Dispose(); - - return row; } - catch (Exception) + catch { - if (reader != null) - { - reader.Close(); - } + return null; } - return null; } /// @@ -183,14 +173,13 @@ namespace OpenSim.Data.MSSQL { Dictionary param = new Dictionary(); param["uuid"] = uuid.ToString(); - IDbCommand result = database.Query("SELECT * FROM " + m_regionsTableName + " WHERE uuid = @uuid", param); - IDataReader reader = result.ExecuteReader(); - RegionProfileData row = database.getRegionRow(reader); - reader.Close(); - result.Dispose(); + using (IDbCommand result = database.Query("SELECT * FROM " + m_regionsTableName + " WHERE uuid = @uuid", param)) + using (IDataReader reader = result.ExecuteReader()) + { + return database.getRegionRow(reader); + } - return row; } /// @@ -204,25 +193,19 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) + Dictionary param = new Dictionary(); + // Add % because this is a like query. + param["?regionName"] = regionName + "%"; + // Order by statement will return shorter matches first. Only returns one record or no record. + using (IDbCommand result = database.Query("SELECT top 1 * FROM " + m_regionsTableName + " WHERE regionName like ?regionName order by regionName", param)) + using (IDataReader reader = result.ExecuteReader()) { - Dictionary param = new Dictionary(); - // Add % because this is a like query. - param["?regionName"] = regionName + "%"; - // Order by statement will return shorter matches first. Only returns one record or no record. - IDbCommand result = database.Query("SELECT top 1 * FROM " + m_regionsTableName + " WHERE regionName like ?regionName order by regionName", param); - IDataReader reader = result.ExecuteReader(); - - RegionProfileData row = database.getRegionRow(reader); - reader.Close(); - result.Dispose(); - - return row; + return database.getRegionRow(reader); } + } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); return null; } @@ -324,12 +307,13 @@ namespace OpenSim.Data.MSSQL try { - IDbCommand result = database.Query(sql, parameters); + using (IDbCommand result = database.Query(sql, parameters)) + { - if (result.ExecuteNonQuery() == 1) - returnval = true; + if (result.ExecuteNonQuery() == 1) + returnval = true; - result.Dispose(); + } } catch (Exception e) { @@ -347,17 +331,15 @@ namespace OpenSim.Data.MSSQL { //Insert new region string sql = - "INSERT INTO " + m_regionsTableName + " ([regionHandle], [regionName], [uuid], [regionRecvKey], [regionSecret], [regionSendKey], [regionDataURI], "; - sql += - "[serverIP], [serverPort], [serverURI], [locX], [locY], [locZ], [eastOverrideHandle], [westOverrideHandle], [southOverrideHandle], [northOverrideHandle], [regionAssetURI], [regionAssetRecvKey], "; - sql += - "[regionAssetSendKey], [regionUserURI], [regionUserRecvKey], [regionUserSendKey], [regionMapTexture], [serverHttpPort], [serverRemotingPort], [owner_uuid]) VALUES "; - - sql += "(@regionHandle, @regionName, @uuid, @regionRecvKey, @regionSecret, @regionSendKey, @regionDataURI, "; - sql += - "@serverIP, @serverPort, @serverURI, @locX, @locY, @locZ, @eastOverrideHandle, @westOverrideHandle, @southOverrideHandle, @northOverrideHandle, @regionAssetURI, @regionAssetRecvKey, "; - sql += - "@regionAssetSendKey, @regionUserURI, @regionUserRecvKey, @regionUserSendKey, @regionMapTexture, @serverHttpPort, @serverRemotingPort, @owner_uuid);"; + "INSERT INTO " + m_regionsTableName + @" ([regionHandle], [regionName], [uuid], [regionRecvKey], [regionSecret], [regionSendKey], [regionDataURI], + [serverIP], [serverPort], [serverURI], [locX], [locY], [locZ], [eastOverrideHandle], [westOverrideHandle], + [southOverrideHandle], [northOverrideHandle], [regionAssetURI], [regionAssetRecvKey], [regionAssetSendKey], + [regionUserURI], [regionUserRecvKey], [regionUserSendKey], [regionMapTexture], [serverHttpPort], + [serverRemotingPort], [owner_uuid]) + VALUES (@regionHandle, @regionName, @uuid, @regionRecvKey, @regionSecret, @regionSendKey, @regionDataURI, + @serverIP, @serverPort, @serverURI, @locX, @locY, @locZ, @eastOverrideHandle, @westOverrideHandle, + @southOverrideHandle, @northOverrideHandle, @regionAssetURI, @regionAssetRecvKey, @regionAssetSendKey, + @regionUserURI, @regionUserRecvKey, @regionUserSendKey, @regionMapTexture, @serverHttpPort, @serverRemotingPort, @owner_uuid);"; Dictionary parameters = new Dictionary(); @@ -393,12 +375,11 @@ namespace OpenSim.Data.MSSQL try { - IDbCommand result = database.Query(sql, parameters); - - if (result.ExecuteNonQuery() == 1) - returnval = true; - - result.Dispose(); + using (IDbCommand result = database.Query(sql, parameters)) + { + if (result.ExecuteNonQuery() == 1) + returnval = true; + } } catch (Exception e) { diff --git a/OpenSim/Data/MSSQL/MSSQLInventoryData.cs b/OpenSim/Data/MSSQL/MSSQLInventoryData.cs index 3177325..4a8d6e9 100644 --- a/OpenSim/Data/MSSQL/MSSQLInventoryData.cs +++ b/OpenSim/Data/MSSQL/MSSQLInventoryData.cs @@ -67,12 +67,12 @@ namespace OpenSim.Data.MSSQL public void Initialise(string connect) { // TODO: actually use the provided connect string - IniFile GridDataMySqlFile = new IniFile("mssql_connection.ini"); - string settingDataSource = GridDataMySqlFile.ParseFileReadValue("data_source"); - string settingInitialCatalog = GridDataMySqlFile.ParseFileReadValue("initial_catalog"); - string settingPersistSecurityInfo = GridDataMySqlFile.ParseFileReadValue("persist_security_info"); - string settingUserId = GridDataMySqlFile.ParseFileReadValue("user_id"); - string settingPassword = GridDataMySqlFile.ParseFileReadValue("password"); + IniFile gridDataMSSqlFile = new IniFile("mssql_connection.ini"); + string settingDataSource = gridDataMSSqlFile.ParseFileReadValue("data_source"); + string settingInitialCatalog = gridDataMSSqlFile.ParseFileReadValue("initial_catalog"); + string settingPersistSecurityInfo = gridDataMSSqlFile.ParseFileReadValue("persist_security_info"); + string settingUserId = gridDataMSSqlFile.ParseFileReadValue("user_id"); + string settingPassword = gridDataMSSqlFile.ParseFileReadValue("password"); database = new MSSQLManager(settingDataSource, settingInitialCatalog, settingPersistSecurityInfo, settingUserId, @@ -165,29 +165,26 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) - { - List items = new List(); + List items = new List(); - Dictionary param = new Dictionary(); - param["parentFolderID"] = folderID.ToString(); + Dictionary param = new Dictionary(); + param["parentFolderID"] = folderID.ToString(); - IDbCommand result = - database.Query("SELECT * FROM inventoryitems WHERE parentFolderID = @parentFolderID", param); - IDataReader reader = result.ExecuteReader(); + using (IDbCommand result = + database.Query("SELECT * FROM inventoryitems WHERE parentFolderID = @parentFolderID", param)) + using (IDataReader reader = result.ExecuteReader()) + { while (reader.Read()) items.Add(readInventoryItem(reader)); reader.Close(); - result.Dispose(); - - return items; } + + return items; } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); return null; } @@ -202,30 +199,26 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) - { - Dictionary param = new Dictionary(); - param["uuid"] = user.ToString(); - param["zero"] = LLUUID.Zero.ToString(); + Dictionary param = new Dictionary(); + param["uuid"] = user.ToString(); + param["zero"] = LLUUID.Zero.ToString(); - IDbCommand result = - database.Query( - "SELECT * FROM inventoryfolders WHERE parentFolderID = @zero AND agentID = @uuid", param); - IDataReader reader = result.ExecuteReader(); + using (IDbCommand result = + database.Query( + "SELECT * FROM inventoryfolders WHERE parentFolderID = @zero AND agentID = @uuid", param)) + using (IDataReader reader = result.ExecuteReader()) + { List items = new List(); while (reader.Read()) items.Add(readInventoryFolder(reader)); - reader.Close(); - result.Dispose(); - return items; } + } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); return null; } @@ -240,16 +233,15 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) - { - Dictionary param = new Dictionary(); - param["uuid"] = user.ToString(); - param["zero"] = LLUUID.Zero.ToString(); + Dictionary param = new Dictionary(); + param["uuid"] = user.ToString(); + param["zero"] = LLUUID.Zero.ToString(); - IDbCommand result = - database.Query( - "SELECT * FROM inventoryfolders WHERE parentFolderID = @zero AND agentID = @uuid", param); - IDataReader reader = result.ExecuteReader(); + using (IDbCommand result = + database.Query( + "SELECT * FROM inventoryfolders WHERE parentFolderID = @zero AND agentID = @uuid", param)) + using (IDataReader reader = result.ExecuteReader()) + { List items = new List(); while (reader.Read()) @@ -267,15 +259,12 @@ namespace OpenSim.Data.MSSQL rootFolder = items[0]; } - reader.Close(); - result.Dispose(); - return rootFolder; } + } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); return null; } @@ -290,30 +279,23 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) - { - Dictionary param = new Dictionary(); - param["parentFolderID"] = parentID.ToString(); - - - IDbCommand result = - database.Query("SELECT * FROM inventoryfolders WHERE parentFolderID = @parentFolderID", param); - IDataReader reader = result.ExecuteReader(); + Dictionary param = new Dictionary(); + param["parentFolderID"] = parentID.ToString(); + using (IDbCommand result = + database.Query("SELECT * FROM inventoryfolders WHERE parentFolderID = @parentFolderID", param)) + using (IDataReader reader = result.ExecuteReader()) + { List items = new List(); while (reader.Read()) items.Add(readInventoryFolder(reader)); - reader.Close(); - result.Dispose(); - return items; } } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); return null; } @@ -369,28 +351,23 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) - { - Dictionary param = new Dictionary(); - param["inventoryID"] = itemID.ToString(); + Dictionary param = new Dictionary(); + param["inventoryID"] = itemID.ToString(); - IDbCommand result = - database.Query("SELECT * FROM inventoryitems WHERE inventoryID = @inventoryID", param); - IDataReader reader = result.ExecuteReader(); + using (IDbCommand result = + database.Query("SELECT * FROM inventoryitems WHERE inventoryID = @inventoryID", param)) + using (IDataReader reader = result.ExecuteReader()) + { InventoryItemBase item = null; if (reader.Read()) item = readInventoryItem(reader); - reader.Close(); - result.Dispose(); - return item; } } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); } return null; @@ -431,25 +408,22 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) - { - Dictionary param = new Dictionary(); - param["uuid"] = folderID.ToString(); + Dictionary param = new Dictionary(); + param["uuid"] = folderID.ToString(); - IDbCommand result = database.Query("SELECT * FROM inventoryfolders WHERE folderID = @uuid", param); - IDataReader reader = result.ExecuteReader(); + using (IDbCommand result = database.Query("SELECT * FROM inventoryfolders WHERE folderID = @uuid", param)) + using (IDataReader reader = result.ExecuteReader()) + { reader.Read(); + InventoryFolderBase folder = readInventoryFolder(reader); - reader.Close(); - result.Dispose(); return folder; } } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); return null; } @@ -479,9 +453,8 @@ namespace OpenSim.Data.MSSQL + ", @inventoryBasePermissions, @inventoryEveryOnePermissions, @salePrice, @saleType" + ", @creationDate, @groupID, @groupOwned, @flags);"; - try + using (AutoClosingSqlCommand command = database.Query(sql)) { - SqlCommand command = new SqlCommand(sql, database.getConnection()); command.Parameters.AddWithValue("inventoryID", item.ID.ToString()); command.Parameters.AddWithValue("assetID", item.AssetID.ToString()); command.Parameters.AddWithValue("assetType", item.AssetType.ToString()); @@ -502,13 +475,16 @@ namespace OpenSim.Data.MSSQL command.Parameters.AddWithValue("groupOwned", item.GroupOwned); command.Parameters.AddWithValue("flags", ConvertUint32BitFieldToInt32(item.Flags)); - command.ExecuteNonQuery(); - command.Dispose(); - } - catch (SqlException e) - { - m_log.Error(e.ToString()); + try + { + command.ExecuteNonQuery(); + } + catch (SqlException e) + { + m_log.Error(e.ToString()); + } } + } /// @@ -517,7 +493,7 @@ namespace OpenSim.Data.MSSQL /// Inventory item to update public void updateInventoryItem(InventoryItemBase item) { - SqlCommand command = new SqlCommand("UPDATE inventoryitems set inventoryID = @inventoryID, " + + using (AutoClosingSqlCommand command = database.Query("UPDATE inventoryitems set inventoryID = @inventoryID, " + "assetID = @assetID, " + "assetType = @assetType," + "parentFolderID = @parentFolderID," + @@ -529,42 +505,44 @@ namespace OpenSim.Data.MSSQL "invType = @invType," + "creatorID = @creatorID," + "inventoryBasePermissions = @inventoryBasePermissions," + - "inventoryEveryOnePermissions = @inventoryEveryOnePermissions," + + "inventoryEveryOnePermissions = @inventoryEveryOnePermissions," + "salePrice = @salePrice," + - "saleType = @saleType," + + "saleType = @saleType," + "creationDate = @creationDate," + - "groupID = @groupID," + - "groupOwned = @groupOwned," + + "groupID = @groupID," + + "groupOwned = @groupOwned," + "flags = @flags where " + - "inventoryID = @keyInventoryID;", database.getConnection()); - command.Parameters.AddWithValue("inventoryID", item.ID.ToString()); - command.Parameters.AddWithValue("assetID", item.AssetID.ToString()); - command.Parameters.AddWithValue("assetType", item.AssetType.ToString()); - command.Parameters.AddWithValue("parentFolderID", item.Folder.ToString()); - command.Parameters.AddWithValue("avatarID", item.Owner.ToString()); - command.Parameters.AddWithValue("inventoryName", item.Name); - command.Parameters.AddWithValue("inventoryDescription", item.Description); - command.Parameters.AddWithValue("inventoryNextPermissions", ConvertUint32BitFieldToInt32(item.NextPermissions)); - command.Parameters.AddWithValue("inventoryCurrentPermissions", ConvertUint32BitFieldToInt32(item.CurrentPermissions)); - command.Parameters.AddWithValue("invType", item.InvType); - command.Parameters.AddWithValue("creatorID", item.Creator.ToString()); - command.Parameters.AddWithValue("inventoryBasePermissions", ConvertUint32BitFieldToInt32(item.BasePermissions)); - command.Parameters.AddWithValue("inventoryEveryOnePermissions", ConvertUint32BitFieldToInt32(item.EveryOnePermissions)); - command.Parameters.AddWithValue("salePrice", item.SalePrice); - command.Parameters.AddWithValue("saleType", item.SaleType); - command.Parameters.AddWithValue("creationDate", item.CreationDate); - command.Parameters.AddWithValue("groupID", item.GroupID.ToString()); - command.Parameters.AddWithValue("groupOwned", item.GroupOwned); - command.Parameters.AddWithValue("flags", ConvertUint32BitFieldToInt32(item.Flags)); - command.Parameters.AddWithValue("@keyInventoryID", item.ID.ToString()); - - try - { - command.ExecuteNonQuery(); - } - catch (Exception e) + "inventoryID = @keyInventoryID;")) { - m_log.Error(e.ToString()); + command.Parameters.AddWithValue("inventoryID", item.ID.ToString()); + command.Parameters.AddWithValue("assetID", item.AssetID.ToString()); + command.Parameters.AddWithValue("assetType", item.AssetType.ToString()); + command.Parameters.AddWithValue("parentFolderID", item.Folder.ToString()); + command.Parameters.AddWithValue("avatarID", item.Owner.ToString()); + command.Parameters.AddWithValue("inventoryName", item.Name); + command.Parameters.AddWithValue("inventoryDescription", item.Description); + command.Parameters.AddWithValue("inventoryNextPermissions", ConvertUint32BitFieldToInt32(item.NextPermissions)); + command.Parameters.AddWithValue("inventoryCurrentPermissions", ConvertUint32BitFieldToInt32(item.CurrentPermissions)); + command.Parameters.AddWithValue("invType", item.InvType); + command.Parameters.AddWithValue("creatorID", item.Creator.ToString()); + command.Parameters.AddWithValue("inventoryBasePermissions", ConvertUint32BitFieldToInt32(item.BasePermissions)); + command.Parameters.AddWithValue("inventoryEveryOnePermissions", ConvertUint32BitFieldToInt32(item.EveryOnePermissions)); + command.Parameters.AddWithValue("salePrice", item.SalePrice); + command.Parameters.AddWithValue("saleType", item.SaleType); + command.Parameters.AddWithValue("creationDate", item.CreationDate); + command.Parameters.AddWithValue("groupID", item.GroupID.ToString()); + command.Parameters.AddWithValue("groupOwned", item.GroupOwned); + command.Parameters.AddWithValue("flags", ConvertUint32BitFieldToInt32(item.Flags)); + command.Parameters.AddWithValue("@keyInventoryID", item.ID.ToString()); + + try + { + command.ExecuteNonQuery(); + } + catch (Exception e) + { + m_log.Error(e.ToString()); + } } } @@ -579,13 +557,13 @@ namespace OpenSim.Data.MSSQL Dictionary param = new Dictionary(); param["uuid"] = itemID.ToString(); - IDbCommand cmd = database.Query("DELETE FROM inventoryitems WHERE inventoryID=@uuid", param); - cmd.ExecuteNonQuery(); - cmd.Dispose(); + using (IDbCommand cmd = database.Query("DELETE FROM inventoryitems WHERE inventoryID=@uuid", param)) + { + cmd.ExecuteNonQuery(); + } } catch (SqlException e) { - database.Reconnect(); m_log.Error(e.ToString()); } } @@ -601,23 +579,24 @@ namespace OpenSim.Data.MSSQL sql += "(@folderID, @agentID, @parentFolderID, @folderName, @type, @version);"; - SqlCommand command = new SqlCommand(sql, database.getConnection()); - command.Parameters.AddWithValue("folderID", folder.ID.ToString()); - command.Parameters.AddWithValue("agentID", folder.Owner.ToString()); - command.Parameters.AddWithValue("parentFolderID", folder.ParentID.ToString()); - command.Parameters.AddWithValue("folderName", folder.Name); - command.Parameters.AddWithValue("type", folder.Type); - command.Parameters.AddWithValue("version", Convert.ToInt32(folder.Version)); - - try + using (AutoClosingSqlCommand command = database.Query(sql)) { - //IDbCommand result = database.Query(sql, param); - command.ExecuteNonQuery(); - command.Dispose(); - } - catch (Exception e) - { - m_log.Error(e.ToString()); + command.Parameters.AddWithValue("folderID", folder.ID.ToString()); + command.Parameters.AddWithValue("agentID", folder.Owner.ToString()); + command.Parameters.AddWithValue("parentFolderID", folder.ParentID.ToString()); + command.Parameters.AddWithValue("folderName", folder.Name); + command.Parameters.AddWithValue("type", folder.Type); + command.Parameters.AddWithValue("version", Convert.ToInt32(folder.Version)); + + try + { + //IDbCommand result = database.Query(sql, param); + command.ExecuteNonQuery(); + } + catch (Exception e) + { + m_log.Error(e.ToString()); + } } } @@ -627,35 +606,37 @@ namespace OpenSim.Data.MSSQL /// Folder to update public void updateInventoryFolder(InventoryFolderBase folder) { - SqlCommand command = new SqlCommand("UPDATE inventoryfolders set folderID = @folderID, " + + using (IDbCommand command = database.Query("UPDATE inventoryfolders set folderID = @folderID, " + "agentID = @agentID, " + "parentFolderID = @parentFolderID," + "folderName = @folderName," + "type = @type," + "version = @version where " + - "folderID = @keyFolderID;", database.getConnection()); - SqlParameter param1 = new SqlParameter("@folderID", folder.ID.ToString()); - SqlParameter param2 = new SqlParameter("@agentID", folder.Owner.ToString()); - SqlParameter param3 = new SqlParameter("@parentFolderID", folder.ParentID.ToString()); - SqlParameter param4 = new SqlParameter("@folderName", folder.Name); - SqlParameter param5 = new SqlParameter("@type", folder.Type); - SqlParameter param6 = new SqlParameter("@version", Convert.ToInt32(folder.Version)); - SqlParameter param7 = new SqlParameter("@keyFolderID", folder.ID.ToString()); - command.Parameters.Add(param1); - command.Parameters.Add(param2); - command.Parameters.Add(param3); - command.Parameters.Add(param4); - command.Parameters.Add(param5); - command.Parameters.Add(param6); - command.Parameters.Add(param7); - - try - { - command.ExecuteNonQuery(); - } - catch (Exception e) - { - m_log.Error(e.ToString()); + "folderID = @keyFolderID;")) + { + SqlParameter param1 = new SqlParameter("@folderID", folder.ID.ToString()); + SqlParameter param2 = new SqlParameter("@agentID", folder.Owner.ToString()); + SqlParameter param3 = new SqlParameter("@parentFolderID", folder.ParentID.ToString()); + SqlParameter param4 = new SqlParameter("@folderName", folder.Name); + SqlParameter param5 = new SqlParameter("@type", folder.Type); + SqlParameter param6 = new SqlParameter("@version", Convert.ToInt32(folder.Version)); + SqlParameter param7 = new SqlParameter("@keyFolderID", folder.ID.ToString()); + command.Parameters.Add(param1); + command.Parameters.Add(param2); + command.Parameters.Add(param3); + command.Parameters.Add(param4); + command.Parameters.Add(param5); + command.Parameters.Add(param6); + command.Parameters.Add(param7); + + try + { + command.ExecuteNonQuery(); + } + catch (Exception e) + { + m_log.Error(e.ToString()); + } } } @@ -665,23 +646,25 @@ namespace OpenSim.Data.MSSQL /// Folder to update public void moveInventoryFolder(InventoryFolderBase folder) { - SqlCommand command = new SqlCommand("UPDATE inventoryfolders set folderID = @folderID, " + + using (IDbCommand command = database.Query("UPDATE inventoryfolders set folderID = @folderID, " + "parentFolderID = @parentFolderID," + - "folderID = @keyFolderID;", database.getConnection()); - SqlParameter param1 = new SqlParameter("@folderID", folder.ID.ToString()); - SqlParameter param2 = new SqlParameter("@parentFolderID", folder.ParentID.ToString()); - SqlParameter param3 = new SqlParameter("@keyFolderID", folder.ID.ToString()); - command.Parameters.Add(param1); - command.Parameters.Add(param2); - command.Parameters.Add(param3); - - try - { - command.ExecuteNonQuery(); - } - catch (Exception e) + "folderID = @keyFolderID;")) { - m_log.Error(e.ToString()); + SqlParameter param1 = new SqlParameter("@folderID", folder.ID.ToString()); + SqlParameter param2 = new SqlParameter("@parentFolderID", folder.ParentID.ToString()); + SqlParameter param3 = new SqlParameter("@keyFolderID", folder.ID.ToString()); + command.Parameters.Add(param1); + command.Parameters.Add(param2); + command.Parameters.Add(param3); + + try + { + command.ExecuteNonQuery(); + } + catch (Exception e) + { + m_log.Error(e.ToString()); + } } } @@ -721,13 +704,13 @@ namespace OpenSim.Data.MSSQL Dictionary param = new Dictionary(); param["folderID"] = folderID.ToString(); - IDbCommand cmd = database.Query("DELETE FROM inventoryfolders WHERE folderID=@folderID", param); - cmd.ExecuteNonQuery(); - cmd.Dispose(); + using (IDbCommand cmd = database.Query("DELETE FROM inventoryfolders WHERE folderID=@folderID", param)) + { + cmd.ExecuteNonQuery(); + } } catch (SqlException e) { - database.Reconnect(); m_log.Error(e.ToString()); } } @@ -744,14 +727,14 @@ namespace OpenSim.Data.MSSQL param["parentFolderID"] = folderID.ToString(); - IDbCommand cmd = - database.Query("DELETE FROM inventoryitems WHERE parentFolderID=@parentFolderID", param); - cmd.ExecuteNonQuery(); - cmd.Dispose(); + using (IDbCommand cmd = + database.Query("DELETE FROM inventoryitems WHERE parentFolderID=@parentFolderID", param)) + { + cmd.ExecuteNonQuery(); + } } catch (SqlException e) { - database.Reconnect(); m_log.Error(e.ToString()); } } @@ -762,7 +745,7 @@ namespace OpenSim.Data.MSSQL /// Id of folder to delete public void deleteInventoryFolder(LLUUID folderID) { - lock (database) + // lock (database) { List subFolders = getFolderHierarchy(folderID); diff --git a/OpenSim/Data/MSSQL/MSSQLLogData.cs b/OpenSim/Data/MSSQL/MSSQLLogData.cs index c75290e..849d0fb 100644 --- a/OpenSim/Data/MSSQL/MSSQLLogData.cs +++ b/OpenSim/Data/MSSQL/MSSQLLogData.cs @@ -31,7 +31,7 @@ using System.Data; namespace OpenSim.Data.MSSQL { /// - /// An interface to the log database for MySQL + /// An interface to the log database for MSSQL /// internal class MSSQLLogData : ILogData { @@ -46,26 +46,27 @@ namespace OpenSim.Data.MSSQL public void Initialise(string connect) { // TODO: do something with the connect string - IniFile GridDataMySqlFile = new IniFile("mssql_connection.ini"); - string settingDataSource = GridDataMySqlFile.ParseFileReadValue("data_source"); - string settingInitialCatalog = GridDataMySqlFile.ParseFileReadValue("initial_catalog"); - string settingPersistSecurityInfo = GridDataMySqlFile.ParseFileReadValue("persist_security_info"); - string settingUserId = GridDataMySqlFile.ParseFileReadValue("user_id"); - string settingPassword = GridDataMySqlFile.ParseFileReadValue("password"); + IniFile gridDataMSSqlFile = new IniFile("mssql_connection.ini"); + string settingDataSource = gridDataMSSqlFile.ParseFileReadValue("data_source"); + string settingInitialCatalog = gridDataMSSqlFile.ParseFileReadValue("initial_catalog"); + string settingPersistSecurityInfo = gridDataMSSqlFile.ParseFileReadValue("persist_security_info"); + string settingUserId = gridDataMSSqlFile.ParseFileReadValue("user_id"); + string settingPassword = gridDataMSSqlFile.ParseFileReadValue("password"); database = new MSSQLManager(settingDataSource, settingInitialCatalog, settingPersistSecurityInfo, settingUserId, settingPassword); - IDbCommand cmd = database.Query("select top 1 * from logs", new Dictionary()); - try - { - cmd.ExecuteNonQuery(); - cmd.Dispose(); - } - catch + using (IDbCommand cmd = database.Query("select top 1 * from logs", new Dictionary())) { - database.ExecuteResourceSql("Mssql-logs.sql"); + try + { + cmd.ExecuteNonQuery(); + } + catch + { + database.ExecuteResourceSql("Mssql-logs.sql"); + } } } @@ -88,7 +89,7 @@ namespace OpenSim.Data.MSSQL } catch { - database.Reconnect(); + // it didn't log, don't worry about it } } diff --git a/OpenSim/Data/MSSQL/MSSQLManager.cs b/OpenSim/Data/MSSQL/MSSQLManager.cs index e421c5d..fe4ca77 100644 --- a/OpenSim/Data/MSSQL/MSSQLManager.cs +++ b/OpenSim/Data/MSSQL/MSSQLManager.cs @@ -45,11 +45,6 @@ namespace OpenSim.Data.MSSQL private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); /// - /// The database connection object - /// - private IDbConnection dbcon; - - /// /// Connection string for ADO.net /// private readonly string connectionString; @@ -57,11 +52,24 @@ namespace OpenSim.Data.MSSQL public MSSQLManager(string dataSource, string initialCatalog, string persistSecurityInfo, string userId, string password) { - connectionString = "Data Source=" + dataSource + ";Initial Catalog=" + initialCatalog + - ";Persist Security Info=" + persistSecurityInfo + ";User ID=" + userId + ";Password=" + - password + ";"; - dbcon = new SqlConnection(connectionString); - dbcon.Open(); + SqlConnectionStringBuilder builder = new SqlConnectionStringBuilder(); + + builder.DataSource = dataSource; + builder.InitialCatalog = initialCatalog; + builder.PersistSecurityInfo = Convert.ToBoolean(persistSecurityInfo); + builder.UserID = userId; + builder.Password = password; + builder.ApplicationName = Assembly.GetEntryAssembly().Location; + + connectionString = builder.ToString(); + } + + private SqlConnection createConnection() + { + SqlConnection conn = new SqlConnection(connectionString); + conn.Open(); + + return conn; } //private DataTable createRegionsTable() @@ -121,7 +129,7 @@ namespace OpenSim.Data.MSSQL } /// - /// + /// Define Table function /// /// /// @@ -178,35 +186,11 @@ namespace OpenSim.Data.MSSQL } } - /// - /// Shuts down the database connection - /// - public void Close() - { - dbcon.Close(); - dbcon = null; - } - /// - /// Reconnects to the database - /// - public void Reconnect() + private static readonly Dictionary emptyDictionary = new Dictionary(); + internal AutoClosingSqlCommand Query(string sql) { - lock (dbcon) - { - try - { - // Close the DB connection - dbcon.Close(); - // Try reopen it - dbcon = new SqlConnection(connectionString); - dbcon.Open(); - } - catch (Exception e) - { - m_log.Error("Unable to reconnect to database " + e.ToString()); - } - } + return Query(sql, emptyDictionary); } /// @@ -215,18 +199,20 @@ namespace OpenSim.Data.MSSQL /// The SQL string - replace any variables such as WHERE x = "y" with WHERE x = @y /// The parameters - index so that @y is indexed as 'y' /// A Sql DB Command - public IDbCommand Query(string sql, Dictionary parameters) + internal AutoClosingSqlCommand Query(string sql, Dictionary parameters) { - SqlCommand dbcommand = (SqlCommand)dbcon.CreateCommand(); + SqlCommand dbcommand = createConnection().CreateCommand(); dbcommand.CommandText = sql; foreach (KeyValuePair param in parameters) { dbcommand.Parameters.AddWithValue(param.Key, param.Value); } - return (IDbCommand)dbcommand; + return new AutoClosingSqlCommand(dbcommand); } + + /// /// Runs a database reader object and returns a region row /// @@ -400,7 +386,6 @@ namespace OpenSim.Data.MSSQL if (reader.Read()) { // Region Main - asset = new AssetBase(); asset.Data = (byte[])reader["data"]; asset.Description = (string)reader["description"]; @@ -443,19 +428,20 @@ namespace OpenSim.Data.MSSQL bool returnval = false; - try + using (IDbCommand result = Query(sql, parameters)) { - IDbCommand result = Query(sql, parameters); + try + { - if (result.ExecuteNonQuery() == 1) - returnval = true; + if (result.ExecuteNonQuery() == 1) + returnval = true; - result.Dispose(); - } - catch (Exception e) - { - m_log.Error(e.ToString()); - return false; + } + catch (Exception e) + { + m_log.Error(e.ToString()); + return false; + } } return returnval; @@ -467,19 +453,12 @@ namespace OpenSim.Data.MSSQL /// the ressource string public void ExecuteResourceSql(string name) { - SqlCommand cmd = new SqlCommand(getResourceString(name), (SqlConnection)dbcon); - cmd.ExecuteNonQuery(); - cmd.Dispose(); + using (IDbCommand cmd = Query(getResourceString(name), new Dictionary())) + { + cmd.ExecuteNonQuery(); + } } - /// - /// - /// - /// The actual SqlConnection - public SqlConnection getConnection() - { - return (SqlConnection)dbcon; - } /// /// Given a list of tables, return the version of the tables, as seen in the database @@ -487,30 +466,29 @@ namespace OpenSim.Data.MSSQL /// public void GetTableVersion(Dictionary tableList) { - lock (dbcon) + Dictionary param = new Dictionary(); + param["dbname"] = new SqlConnectionStringBuilder(connectionString).InitialCatalog; + + using (IDbCommand tablesCmd = + Query("SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_CATALOG=@dbname", param)) + using (IDataReader tables = tablesCmd.ExecuteReader()) { - Dictionary param = new Dictionary(); - param["dbname"] = dbcon.Database; - IDbCommand tablesCmd = - Query("SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_CATALOG=@dbname", param); - using (IDataReader tables = tablesCmd.ExecuteReader()) + while (tables.Read()) { - while (tables.Read()) + try { - try - { - string tableName = (string)tables["TABLE_NAME"]; - if (tableList.ContainsKey(tableName)) - tableList[tableName] = tableName; - } - catch (Exception e) - { - m_log.Error(e.ToString()); - } + string tableName = (string)tables["TABLE_NAME"]; + if (tableList.ContainsKey(tableName)) + tableList[tableName] = tableName; + } + catch (Exception e) + { + m_log.Error(e.ToString()); } - tables.Close(); } + tables.Close(); } + } /// @@ -546,7 +524,6 @@ namespace OpenSim.Data.MSSQL // string dllName = module.Assembly.ManifestModule.Name; Version dllVersion = module.Assembly.GetName().Version; - return string.Format("{0}.{1}.{2}.{3}", dllVersion.Major, dllVersion.Minor, dllVersion.Build, dllVersion.Revision); diff --git a/OpenSim/Data/MSSQL/MSSQLUserData.cs b/OpenSim/Data/MSSQL/MSSQLUserData.cs index cb5ba24..20c3acd 100644 --- a/OpenSim/Data/MSSQL/MSSQLUserData.cs +++ b/OpenSim/Data/MSSQL/MSSQLUserData.cs @@ -44,7 +44,7 @@ namespace OpenSim.Data.MSSQL private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); /// - /// Database manager for MySQL + /// Database manager for MSSQL /// public MSSQLManager database; @@ -100,36 +100,41 @@ namespace OpenSim.Data.MSSQL /// private bool TestTables() { - IDbCommand cmd; - cmd = database.Query("select top 1 * from " + m_usersTableName, new Dictionary()); - try - { - cmd.ExecuteNonQuery(); - } - catch + using (IDbCommand cmd = database.Query("select top 1 * from " + m_usersTableName, new Dictionary())) { - database.ExecuteResourceSql("Mssql-users.sql"); + try + { + cmd.ExecuteNonQuery(); + } + catch + { + database.ExecuteResourceSql("Mssql-users.sql"); + } } - cmd = database.Query("select top 1 * from " + m_agentsTableName, new Dictionary()); - try - { - cmd.ExecuteNonQuery(); - } - catch + using (IDbCommand cmd = database.Query("select top 1 * from " + m_agentsTableName, new Dictionary())) { - database.ExecuteResourceSql("Mssql-agents.sql"); + try + { + cmd.ExecuteNonQuery(); + } + catch + { + database.ExecuteResourceSql("Mssql-agents.sql"); + } } - cmd = database.Query("select top 1 * from " + m_userFriendsTableName, new Dictionary()); - try + using (IDbCommand cmd = database.Query("select top 1 * from " + m_userFriendsTableName, new Dictionary())) { - cmd.ExecuteNonQuery(); - } - catch - { - database.ExecuteResourceSql("CreateUserFriendsTable.sql"); + try + { + cmd.ExecuteNonQuery(); + } + catch + { + database.ExecuteResourceSql("CreateUserFriendsTable.sql"); + } } return true; @@ -145,27 +150,18 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) - { - Dictionary param = new Dictionary(); - param["first"] = user; - param["second"] = last; - - IDbCommand result = - database.Query("SELECT * FROM " + m_usersTableName + " WHERE username = @first AND lastname = @second", param); - IDataReader reader = result.ExecuteReader(); + Dictionary param = new Dictionary(); + param["first"] = user; + param["second"] = last; - UserProfileData row = database.readUserRow(reader); - - reader.Close(); - result.Dispose(); - - return row; + using (IDbCommand result = database.Query("SELECT * FROM " + m_usersTableName + " WHERE username = @first AND lastname = @second", param)) + using (IDataReader reader = result.ExecuteReader()) + { + return database.readUserRow(reader); } } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); return null; } @@ -191,32 +187,30 @@ namespace OpenSim.Data.MSSQL try { - lock (database) + using (IDbCommand adder = + database.Query( + "INSERT INTO " + m_userFriendsTableName + " " + + "(ownerID,friendID,friendPerms,datetimestamp) " + + "VALUES " + + "(@ownerID,@friendID,@friendPerms,@datetimestamp)", + param)) { - IDbCommand adder = - database.Query( - "INSERT INTO " + m_userFriendsTableName + " " + - "(ownerID,friendID,friendPerms,datetimestamp) " + - "VALUES " + - "(@ownerID,@friendID,@friendPerms,@datetimestamp)", - param); - adder.ExecuteNonQuery(); - - adder = - database.Query( - "INSERT INTO " + m_userFriendsTableName + " " + - "(ownerID,friendID,friendPerms,datetimestamp) " + - "VALUES " + - "(@friendID,@ownerID,@friendPerms,@datetimestamp)", - param); + } + + using (IDbCommand adder = + database.Query( + "INSERT INTO " + m_userFriendsTableName + " " + + "(ownerID,friendID,friendPerms,datetimestamp) " + + "VALUES " + + "(@friendID,@ownerID,@friendPerms,@datetimestamp)", + param)) + { adder.ExecuteNonQuery(); - } } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); return; } @@ -236,27 +230,26 @@ namespace OpenSim.Data.MSSQL try { - lock (database) + using (IDbCommand updater = + database.Query( + "delete from " + m_userFriendsTableName + " where ownerID = @ownerID and friendID = @friendID", + param)) { - IDbCommand updater = - database.Query( - "delete from " + m_userFriendsTableName + " where ownerID = @ownerID and friendID = @friendID", - param); updater.ExecuteNonQuery(); + } - updater = - database.Query( - "delete from " + m_userFriendsTableName + " where ownerID = @friendID and friendID = @ownerID", - param); + using (IDbCommand updater = + database.Query( + "delete from " + m_userFriendsTableName + " where ownerID = @friendID and friendID = @ownerID", + param)) + { updater.ExecuteNonQuery(); - } + } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); - return; } } @@ -276,23 +269,19 @@ namespace OpenSim.Data.MSSQL try { - lock (database) + using (IDbCommand updater = + database.Query( + "update " + m_userFriendsTableName + + " SET friendPerms = @friendPerms " + + "where ownerID = @ownerID and friendID = @friendID", + param)) { - IDbCommand updater = - database.Query( - "update " + m_userFriendsTableName + - " SET friendPerms = @friendPerms " + - "where ownerID = @ownerID and friendID = @friendID", - param); - updater.ExecuteNonQuery(); } } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); - return; } } @@ -310,17 +299,14 @@ namespace OpenSim.Data.MSSQL try { - lock (database) + //Left Join userfriends to itself + using (IDbCommand result = + database.Query( + "select a.ownerID,a.friendID,a.friendPerms,b.friendPerms as ownerperms from " + m_userFriendsTableName + " as a, " + m_userFriendsTableName + " as b" + + " where a.ownerID = @ownerID and b.ownerID = a.friendID and b.friendID = a.ownerID", + param)) + using (IDataReader reader = result.ExecuteReader()) { - //Left Join userfriends to itself - IDbCommand result = - database.Query( - "select a.ownerID,a.friendID,a.friendPerms,b.friendPerms as ownerperms from " + m_userFriendsTableName + " as a, " + m_userFriendsTableName + " as b" + - " where a.ownerID = @ownerID and b.ownerID = a.friendID and b.friendID = a.ownerID", - param); - IDataReader reader = result.ExecuteReader(); - - while (reader.Read()) { FriendListItem fli = new FriendListItem(); @@ -333,15 +319,11 @@ namespace OpenSim.Data.MSSQL Lfli.Add(fli); } - reader.Close(); - result.Dispose(); } } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); - return Lfli; } return Lfli; @@ -375,19 +357,13 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) - { - Dictionary param = new Dictionary(); - param["first"] = querysplit[0]; - param["second"] = querysplit[1]; - - IDbCommand result = - database.Query( - "SELECT UUID,username,lastname FROM " + m_usersTableName + " WHERE username = @first AND lastname = @second", - param); - IDataReader reader = result.ExecuteReader(); - + Dictionary param = new Dictionary(); + param["first"] = querysplit[0]; + param["second"] = querysplit[1]; + using (IDbCommand result = database.Query("SELECT UUID,username,lastname FROM " + m_usersTableName + " WHERE username = @first AND lastname = @second", param)) + using (IDataReader reader = result.ExecuteReader()) + { while (reader.Read()) { AvatarPickerAvatar user = new AvatarPickerAvatar(); @@ -395,34 +371,24 @@ namespace OpenSim.Data.MSSQL user.firstName = (string)reader["username"]; user.lastName = (string)reader["lastname"]; returnlist.Add(user); - } - reader.Close(); - result.Dispose(); + } } } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); - return returnlist; } } else if (querysplit.Length == 1) { try { - lock (database) - { - Dictionary param = new Dictionary(); - param["first"] = querysplit[0]; - - IDbCommand result = - database.Query( - "SELECT UUID,username,lastname FROM " + m_usersTableName + " WHERE username = @first OR lastname = @first", - param); - IDataReader reader = result.ExecuteReader(); - + Dictionary param = new Dictionary(); + param["first"] = querysplit[0]; + using (IDbCommand result = database.Query("SELECT UUID,username,lastname FROM " + m_usersTableName + " WHERE username = @first OR lastname = @first", param)) + using (IDataReader reader = result.ExecuteReader()) + { while (reader.Read()) { AvatarPickerAvatar user = new AvatarPickerAvatar(); @@ -431,15 +397,11 @@ namespace OpenSim.Data.MSSQL user.lastName = (string)reader["lastname"]; returnlist.Add(user); } - reader.Close(); - result.Dispose(); } - } + } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); - return returnlist; } } return returnlist; @@ -454,25 +416,17 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) - { - Dictionary param = new Dictionary(); - param["uuid"] = uuid.ToString(); - - IDbCommand result = database.Query("SELECT * FROM " + m_usersTableName + " WHERE UUID = @uuid", param); - IDataReader reader = result.ExecuteReader(); + Dictionary param = new Dictionary(); + param["uuid"] = uuid.ToString(); - UserProfileData row = database.readUserRow(reader); - - reader.Close(); - result.Dispose(); - - return row; + using (IDbCommand result = database.Query("SELECT * FROM " + m_usersTableName + " WHERE UUID = @uuid", param)) + using (IDataReader reader = result.ExecuteReader()) + { + return database.readUserRow(reader); } } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); return null; } @@ -509,25 +463,17 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) - { - Dictionary param = new Dictionary(); - param["uuid"] = uuid.ToString(); - - IDbCommand result = database.Query("SELECT * FROM " + m_agentsTableName + " WHERE UUID = @uuid", param); - IDataReader reader = result.ExecuteReader(); - - UserAgentData row = database.readAgentRow(reader); + Dictionary param = new Dictionary(); + param["uuid"] = uuid.ToString(); - reader.Close(); - result.Dispose(); - - return row; + using (IDbCommand result = database.Query("SELECT * FROM " + m_agentsTableName + " WHERE UUID = @uuid", param)) + using (IDataReader reader = result.ExecuteReader()) + { + return database.readAgentRow(reader); } } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); return null; } @@ -554,21 +500,17 @@ namespace OpenSim.Data.MSSQL { try { - lock (database) - { - InsertUserRow(user.ID, user.FirstName, user.SurName, user.PasswordHash, user.PasswordSalt, - user.HomeRegion, user.HomeLocation.X, user.HomeLocation.Y, - user.HomeLocation.Z, - user.HomeLookAt.X, user.HomeLookAt.Y, user.HomeLookAt.Z, user.Created, - user.LastLogin, user.UserInventoryURI, user.UserAssetURI, - user.CanDoMask, user.WantDoMask, - user.AboutText, user.FirstLifeAboutText, user.Image, - user.FirstLifeImage, user.WebLoginKey); - } + InsertUserRow(user.ID, user.FirstName, user.SurName, user.PasswordHash, user.PasswordSalt, + user.HomeRegion, user.HomeLocation.X, user.HomeLocation.Y, + user.HomeLocation.Z, + user.HomeLookAt.X, user.HomeLookAt.Y, user.HomeLookAt.Z, user.Created, + user.LastLogin, user.UserInventoryURI, user.UserAssetURI, + user.CanDoMask, user.WantDoMask, + user.AboutText, user.FirstLifeAboutText, user.Image, + user.FirstLifeImage, user.WebLoginKey); } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); } } @@ -646,16 +588,13 @@ namespace OpenSim.Data.MSSQL parameters["profileFirstImage"] = firstImage.ToString(); parameters["webLoginKey"] = LLUUID.Random().ToString(); - bool returnval = false; try { - IDbCommand result = database.Query(sql, parameters); - - if (result.ExecuteNonQuery() == 1) - returnval = true; - - result.Dispose(); + using (IDbCommand result = database.Query(sql, parameters)) + { + return (result.ExecuteNonQuery() == 1); + } } catch (Exception e) { @@ -663,7 +602,6 @@ namespace OpenSim.Data.MSSQL return false; } - return returnval; } /// @@ -682,7 +620,7 @@ namespace OpenSim.Data.MSSQL /// override public bool UpdateUserProfile(UserProfileData user) { - SqlCommand command = new SqlCommand("UPDATE " + m_usersTableName + " set UUID = @uuid, " + + using (IDbCommand command = database.Query("UPDATE " + m_usersTableName + " set UUID = @uuid, " + "username = @username, " + "lastname = @lastname," + "passwordHash = @passwordHash," + @@ -705,71 +643,66 @@ namespace OpenSim.Data.MSSQL "profileImage = @profileImage," + "profileFirstImage = @profileFirstImage, " + "webLoginKey = @webLoginKey where " + - "UUID = @keyUUUID;", database.getConnection()); - SqlParameter param1 = new SqlParameter("@uuid", user.ID.ToString()); - SqlParameter param2 = new SqlParameter("@username", user.FirstName); - SqlParameter param3 = new SqlParameter("@lastname", user.SurName); - SqlParameter param4 = new SqlParameter("@passwordHash", user.PasswordHash); - SqlParameter param5 = new SqlParameter("@passwordSalt", user.PasswordSalt); - SqlParameter param6 = new SqlParameter("@homeRegion", Convert.ToInt64(user.HomeRegion)); - SqlParameter param7 = new SqlParameter("@homeLocationX", user.HomeLocation.X); - SqlParameter param8 = new SqlParameter("@homeLocationY", user.HomeLocation.Y); - SqlParameter param9 = new SqlParameter("@homeLocationZ", user.HomeLocation.Y); - SqlParameter param10 = new SqlParameter("@homeLookAtX", user.HomeLookAt.X); - SqlParameter param11 = new SqlParameter("@homeLookAtY", user.HomeLookAt.Y); - SqlParameter param12 = new SqlParameter("@homeLookAtZ", user.HomeLookAt.Z); - SqlParameter param13 = new SqlParameter("@created", Convert.ToInt32(user.Created)); - SqlParameter param14 = new SqlParameter("@lastLogin", Convert.ToInt32(user.LastLogin)); - SqlParameter param15 = new SqlParameter("@userInventoryURI", user.UserInventoryURI); - SqlParameter param16 = new SqlParameter("@userAssetURI", user.UserAssetURI); - SqlParameter param17 = new SqlParameter("@profileCanDoMask", Convert.ToInt32(user.CanDoMask)); - SqlParameter param18 = new SqlParameter("@profileWantDoMask", Convert.ToInt32(user.WantDoMask)); - SqlParameter param19 = new SqlParameter("@profileAboutText", user.AboutText); - SqlParameter param20 = new SqlParameter("@profileFirstText", user.FirstLifeAboutText); - SqlParameter param21 = new SqlParameter("@profileImage", user.Image.ToString()); - SqlParameter param22 = new SqlParameter("@profileFirstImage", user.FirstLifeImage.ToString()); - SqlParameter param23 = new SqlParameter("@keyUUUID", user.ID.ToString()); - SqlParameter param24 = new SqlParameter("@webLoginKey", user.WebLoginKey.UUID.ToString()); - command.Parameters.Add(param1); - command.Parameters.Add(param2); - command.Parameters.Add(param3); - command.Parameters.Add(param4); - command.Parameters.Add(param5); - command.Parameters.Add(param6); - command.Parameters.Add(param7); - command.Parameters.Add(param8); - command.Parameters.Add(param9); - command.Parameters.Add(param10); - command.Parameters.Add(param11); - command.Parameters.Add(param12); - command.Parameters.Add(param13); - command.Parameters.Add(param14); - command.Parameters.Add(param15); - command.Parameters.Add(param16); - command.Parameters.Add(param17); - command.Parameters.Add(param18); - command.Parameters.Add(param19); - command.Parameters.Add(param20); - command.Parameters.Add(param21); - command.Parameters.Add(param22); - command.Parameters.Add(param23); - command.Parameters.Add(param24); - try - { - int affected = command.ExecuteNonQuery(); - if (affected != 0) + "UUID = @keyUUUID;")) + { + SqlParameter param1 = new SqlParameter("@uuid", user.ID.ToString()); + SqlParameter param2 = new SqlParameter("@username", user.FirstName); + SqlParameter param3 = new SqlParameter("@lastname", user.SurName); + SqlParameter param4 = new SqlParameter("@passwordHash", user.PasswordHash); + SqlParameter param5 = new SqlParameter("@passwordSalt", user.PasswordSalt); + SqlParameter param6 = new SqlParameter("@homeRegion", Convert.ToInt64(user.HomeRegion)); + SqlParameter param7 = new SqlParameter("@homeLocationX", user.HomeLocation.X); + SqlParameter param8 = new SqlParameter("@homeLocationY", user.HomeLocation.Y); + SqlParameter param9 = new SqlParameter("@homeLocationZ", user.HomeLocation.Y); + SqlParameter param10 = new SqlParameter("@homeLookAtX", user.HomeLookAt.X); + SqlParameter param11 = new SqlParameter("@homeLookAtY", user.HomeLookAt.Y); + SqlParameter param12 = new SqlParameter("@homeLookAtZ", user.HomeLookAt.Z); + SqlParameter param13 = new SqlParameter("@created", Convert.ToInt32(user.Created)); + SqlParameter param14 = new SqlParameter("@lastLogin", Convert.ToInt32(user.LastLogin)); + SqlParameter param15 = new SqlParameter("@userInventoryURI", user.UserInventoryURI); + SqlParameter param16 = new SqlParameter("@userAssetURI", user.UserAssetURI); + SqlParameter param17 = new SqlParameter("@profileCanDoMask", Convert.ToInt32(user.CanDoMask)); + SqlParameter param18 = new SqlParameter("@profileWantDoMask", Convert.ToInt32(user.WantDoMask)); + SqlParameter param19 = new SqlParameter("@profileAboutText", user.AboutText); + SqlParameter param20 = new SqlParameter("@profileFirstText", user.FirstLifeAboutText); + SqlParameter param21 = new SqlParameter("@profileImage", user.Image.ToString()); + SqlParameter param22 = new SqlParameter("@profileFirstImage", user.FirstLifeImage.ToString()); + SqlParameter param23 = new SqlParameter("@keyUUUID", user.ID.ToString()); + SqlParameter param24 = new SqlParameter("@webLoginKey", user.WebLoginKey.UUID.ToString()); + command.Parameters.Add(param1); + command.Parameters.Add(param2); + command.Parameters.Add(param3); + command.Parameters.Add(param4); + command.Parameters.Add(param5); + command.Parameters.Add(param6); + command.Parameters.Add(param7); + command.Parameters.Add(param8); + command.Parameters.Add(param9); + command.Parameters.Add(param10); + command.Parameters.Add(param11); + command.Parameters.Add(param12); + command.Parameters.Add(param13); + command.Parameters.Add(param14); + command.Parameters.Add(param15); + command.Parameters.Add(param16); + command.Parameters.Add(param17); + command.Parameters.Add(param18); + command.Parameters.Add(param19); + command.Parameters.Add(param20); + command.Parameters.Add(param21); + command.Parameters.Add(param22); + command.Parameters.Add(param23); + command.Parameters.Add(param24); + try { - return true; + int affected = command.ExecuteNonQuery(); + return (affected != 0); } - else + catch (Exception e) { - return false; + m_log.Error(e.ToString()); } } - catch (Exception e) - { - m_log.Error(e.ToString()); - } return false; } @@ -805,28 +738,21 @@ namespace OpenSim.Data.MSSQL // return new AvatarAppearance(); try { - lock (database) - { Dictionary param = new Dictionary(); param["@UUID"] = user.ToString(); - IDbCommand result = - database.Query("SELECT * FROM avatarappearance WHERE owner = @UUID", param); - IDataReader reader = result.ExecuteReader(); - - AvatarAppearance item = null; - if (reader.Read()) - item = readUserAppearance(reader); - - reader.Close(); - result.Dispose(); - - return item; - } + using (IDbCommand result = + database.Query("SELECT * FROM avatarappearance WHERE owner = @UUID", param)) + using (IDataReader reader = result.ExecuteReader()) + { + AvatarAppearance item = null; + if (reader.Read()) + item = readUserAppearance(reader); + return item; + } } catch (Exception e) { - database.Reconnect(); m_log.Error(e.ToString()); } return null; @@ -906,49 +832,49 @@ namespace OpenSim.Data.MSSQL sql += "@jacket_item, @jacket_asset, @gloves_item, @gloves_asset, @undershirt_item, @undershirt_asset, @underpants_item, @underpants_asset, "; sql += "@skirt_item, @skirt_asset)"; - SqlCommand cmd = new SqlCommand(sql, database.getConnection()); - cmd.Parameters.AddWithValue("@owner", appearance.Owner.ToString()); - cmd.Parameters.AddWithValue("@serial", appearance.Serial); - cmd.Parameters.AddWithValue("@visual_params", appearance.VisualParams); - cmd.Parameters.AddWithValue("@texture", appearance.Texture.ToBytes()); - cmd.Parameters.AddWithValue("@avatar_height", appearance.AvatarHeight); - cmd.Parameters.AddWithValue("@body_item", appearance.BodyItem.ToString()); - cmd.Parameters.AddWithValue("@body_asset", appearance.BodyAsset.ToString()); - cmd.Parameters.AddWithValue("@skin_item", appearance.SkinItem.ToString()); - cmd.Parameters.AddWithValue("@skin_asset", appearance.SkinAsset.ToString()); - cmd.Parameters.AddWithValue("@hair_item", appearance.HairItem.ToString()); - cmd.Parameters.AddWithValue("@hair_asset", appearance.HairAsset.ToString()); - cmd.Parameters.AddWithValue("@eyes_item", appearance.EyesItem.ToString()); - cmd.Parameters.AddWithValue("@eyes_asset", appearance.EyesAsset.ToString()); - cmd.Parameters.AddWithValue("@shirt_item", appearance.ShirtItem.ToString()); - cmd.Parameters.AddWithValue("@shirt_asset", appearance.ShirtAsset.ToString()); - cmd.Parameters.AddWithValue("@pants_item", appearance.PantsItem.ToString()); - cmd.Parameters.AddWithValue("@pants_asset", appearance.PantsAsset.ToString()); - cmd.Parameters.AddWithValue("@shoes_item", appearance.ShoesItem.ToString()); - cmd.Parameters.AddWithValue("@shoes_asset", appearance.ShoesAsset.ToString()); - cmd.Parameters.AddWithValue("@socks_item", appearance.SocksItem.ToString()); - cmd.Parameters.AddWithValue("@socks_asset", appearance.SocksAsset.ToString()); - cmd.Parameters.AddWithValue("@jacket_item", appearance.JacketItem.ToString()); - cmd.Parameters.AddWithValue("@jacket_asset", appearance.JacketAsset.ToString()); - cmd.Parameters.AddWithValue("@gloves_item", appearance.GlovesItem.ToString()); - cmd.Parameters.AddWithValue("@gloves_asset", appearance.GlovesAsset.ToString()); - cmd.Parameters.AddWithValue("@undershirt_item", appearance.UnderShirtItem.ToString()); - cmd.Parameters.AddWithValue("@undershirt_asset", appearance.UnderShirtAsset.ToString()); - cmd.Parameters.AddWithValue("@underpants_item", appearance.UnderPantsItem.ToString()); - cmd.Parameters.AddWithValue("@underpants_asset", appearance.UnderPantsAsset.ToString()); - cmd.Parameters.AddWithValue("@skirt_item", appearance.SkirtItem.ToString()); - cmd.Parameters.AddWithValue("@skirt_asset", appearance.SkirtAsset.ToString()); - - try - { - cmd.ExecuteNonQuery(); - cmd.Dispose(); - } - catch (Exception e) - { - m_log.Error(e.ToString()); + using (AutoClosingSqlCommand cmd = database.Query(sql)) + { + cmd.Parameters.AddWithValue("@owner", appearance.Owner.ToString()); + cmd.Parameters.AddWithValue("@serial", appearance.Serial); + cmd.Parameters.AddWithValue("@visual_params", appearance.VisualParams); + cmd.Parameters.AddWithValue("@texture", appearance.Texture.ToBytes()); + cmd.Parameters.AddWithValue("@avatar_height", appearance.AvatarHeight); + cmd.Parameters.AddWithValue("@body_item", appearance.BodyItem.ToString()); + cmd.Parameters.AddWithValue("@body_asset", appearance.BodyAsset.ToString()); + cmd.Parameters.AddWithValue("@skin_item", appearance.SkinItem.ToString()); + cmd.Parameters.AddWithValue("@skin_asset", appearance.SkinAsset.ToString()); + cmd.Parameters.AddWithValue("@hair_item", appearance.HairItem.ToString()); + cmd.Parameters.AddWithValue("@hair_asset", appearance.HairAsset.ToString()); + cmd.Parameters.AddWithValue("@eyes_item", appearance.EyesItem.ToString()); + cmd.Parameters.AddWithValue("@eyes_asset", appearance.EyesAsset.ToString()); + cmd.Parameters.AddWithValue("@shirt_item", appearance.ShirtItem.ToString()); + cmd.Parameters.AddWithValue("@shirt_asset", appearance.ShirtAsset.ToString()); + cmd.Parameters.AddWithValue("@pants_item", appearance.PantsItem.ToString()); + cmd.Parameters.AddWithValue("@pants_asset", appearance.PantsAsset.ToString()); + cmd.Parameters.AddWithValue("@shoes_item", appearance.ShoesItem.ToString()); + cmd.Parameters.AddWithValue("@shoes_asset", appearance.ShoesAsset.ToString()); + cmd.Parameters.AddWithValue("@socks_item", appearance.SocksItem.ToString()); + cmd.Parameters.AddWithValue("@socks_asset", appearance.SocksAsset.ToString()); + cmd.Parameters.AddWithValue("@jacket_item", appearance.JacketItem.ToString()); + cmd.Parameters.AddWithValue("@jacket_asset", appearance.JacketAsset.ToString()); + cmd.Parameters.AddWithValue("@gloves_item", appearance.GlovesItem.ToString()); + cmd.Parameters.AddWithValue("@gloves_asset", appearance.GlovesAsset.ToString()); + cmd.Parameters.AddWithValue("@undershirt_item", appearance.UnderShirtItem.ToString()); + cmd.Parameters.AddWithValue("@undershirt_asset", appearance.UnderShirtAsset.ToString()); + cmd.Parameters.AddWithValue("@underpants_item", appearance.UnderPantsItem.ToString()); + cmd.Parameters.AddWithValue("@underpants_asset", appearance.UnderPantsAsset.ToString()); + cmd.Parameters.AddWithValue("@skirt_item", appearance.SkirtItem.ToString()); + cmd.Parameters.AddWithValue("@skirt_asset", appearance.SkirtAsset.ToString()); + + try + { + cmd.ExecuteNonQuery(); + } + catch (Exception e) + { + m_log.Error(e.ToString()); + } } - return; } /// @@ -958,7 +884,7 @@ namespace OpenSim.Data.MSSQL /// the item UUID override public void AddAttachment(LLUUID user, LLUUID item) { - return; + // TBI? } /// @@ -968,7 +894,7 @@ namespace OpenSim.Data.MSSQL /// the item UUID override public void RemoveAttachment(LLUUID user, LLUUID item) { - return; + // TBI? } /// -- cgit v1.1