diff options
Diffstat (limited to 'OpenSim/Region/Storage')
-rw-r--r-- | OpenSim/Region/Storage/OpenSim.DataStore.MonoSqlite/MonoSqliteDataStore.cs | 148 |
1 files changed, 46 insertions, 102 deletions
diff --git a/OpenSim/Region/Storage/OpenSim.DataStore.MonoSqlite/MonoSqliteDataStore.cs b/OpenSim/Region/Storage/OpenSim.DataStore.MonoSqlite/MonoSqliteDataStore.cs index 0a73880..60736aa 100644 --- a/OpenSim/Region/Storage/OpenSim.DataStore.MonoSqlite/MonoSqliteDataStore.cs +++ b/OpenSim/Region/Storage/OpenSim.DataStore.MonoSqlite/MonoSqliteDataStore.cs | |||
@@ -114,11 +114,50 @@ namespace OpenSim.DataStore.MonoSqliteStorage | |||
114 | return data; | 114 | return data; |
115 | } | 115 | } |
116 | 116 | ||
117 | private SqliteCommand createInsertCommand(Dictionary<string, DbType> defs) | 117 | private SqliteCommand createPrimInsertCommand(Dictionary<string, DbType> defs) |
118 | { | 118 | { |
119 | SqliteCommand cmd = new SqliteCommand(); | 119 | /** |
120 | * This is subtle enough to deserve some commentary. | ||
121 | * Instead of doing *lots* and *lots of hardcoded strings | ||
122 | * for database definitions we'll use the fact that | ||
123 | * realistically all insert statements look like "insert | ||
124 | * into A(b, c) values(:b, :c) on the parameterized query | ||
125 | * front. If we just have a list of b, c, etc... we can | ||
126 | * generate these strings instead of typing them out. | ||
127 | */ | ||
128 | string[] cols = new string[defs.Keys.Count]; | ||
129 | defs.Keys.CopyTo(cols, 0); | ||
130 | |||
120 | string sql = "insert into prims("; | 131 | string sql = "insert into prims("; |
132 | sql += String.Join(", ", cols); | ||
133 | // important, the first ':' needs to be here, the rest get added in the join | ||
134 | sql += ") values (:"; | ||
135 | sql += String.Join(", :", cols); | ||
136 | sql += ")"; | ||
137 | SqliteCommand cmd = new SqliteCommand(sql); | ||
121 | 138 | ||
139 | // this provides the binding for all our parameters, so | ||
140 | // much less code than it used to be | ||
141 | foreach (KeyValuePair<string, DbType> kvp in defs) { | ||
142 | cmd.Parameters.Add(createSqliteParameter(kvp.Key, kvp.Value)); | ||
143 | } | ||
144 | return cmd; | ||
145 | } | ||
146 | |||
147 | private SqliteCommand createPrimUpdateCommand(Dictionary<string, DbType> defs) | ||
148 | { | ||
149 | string sql = "update prims set "; | ||
150 | foreach (string key in defs.Keys) { | ||
151 | sql += key + "= :" + key + ", "; | ||
152 | } | ||
153 | sql += " where UUID=:UUID"; | ||
154 | SqliteCommand cmd = new SqliteCommand(sql); | ||
155 | |||
156 | // this provides the binding for all our parameters, so | ||
157 | // much less code than it used to be | ||
158 | foreach (KeyValuePair<string, DbType> kvp in defs) { | ||
159 | cmd.Parameters.Add(createSqliteParameter(kvp.Key, kvp.Value)); | ||
160 | } | ||
122 | return cmd; | 161 | return cmd; |
123 | } | 162 | } |
124 | 163 | ||
@@ -126,111 +165,16 @@ namespace OpenSim.DataStore.MonoSqliteStorage | |||
126 | { | 165 | { |
127 | Dictionary<string, DbType> primDataDefs = createPrimDataDefs(); | 166 | Dictionary<string, DbType> primDataDefs = createPrimDataDefs(); |
128 | 167 | ||
129 | da.InsertCommand = createInsertCommand(primDataDefs); | 168 | da.InsertCommand = createPrimInsertCommand(primDataDefs); |
130 | /* | 169 | da.InsertCommand.Connection = conn; |
131 | * Create all the bound parameters. Try to keep these in the same order | ||
132 | * as the sql file, with comments in the same places, or your head will probably | ||
133 | * explode trying to do corolations | ||
134 | */ | ||
135 | SqliteParameter UUID = createSqliteParameter("UUID", DbType.String); | ||
136 | SqliteParameter ParentID = createSqliteParameter("ParentID", DbType.Int32); | ||
137 | SqliteParameter CreationDate = createSqliteParameter("CreationDate", DbType.Int32); | ||
138 | SqliteParameter Name = createSqliteParameter("Name", DbType.String); | ||
139 | // various text fields | ||
140 | SqliteParameter Text = createSqliteParameter("Text", DbType.String); | ||
141 | SqliteParameter Description = createSqliteParameter("Description", DbType.String); | ||
142 | SqliteParameter SitName = createSqliteParameter("SitName", DbType.String); | ||
143 | SqliteParameter TouchName = createSqliteParameter("TouchName", DbType.String); | ||
144 | // permissions | ||
145 | SqliteParameter CreatorID = createSqliteParameter("CreatorID", DbType.String); | ||
146 | SqliteParameter OwnerID = createSqliteParameter("OwnerID", DbType.String); | ||
147 | SqliteParameter GroupID = createSqliteParameter("GroupID", DbType.String); | ||
148 | SqliteParameter LastOwnerID = createSqliteParameter("LastOwnerID", DbType.String); | ||
149 | SqliteParameter OwnerMask = createSqliteParameter("OwnerMask", DbType.Int32); | ||
150 | SqliteParameter NextOwnerMask = createSqliteParameter("NextOwnerMask", DbType.Int32); | ||
151 | SqliteParameter GroupMask = createSqliteParameter("GroupMask", DbType.Int32); | ||
152 | SqliteParameter EveryoneMask = createSqliteParameter("EveryoneMask", DbType.Int32); | ||
153 | SqliteParameter BaseMask = createSqliteParameter("BaseMask", DbType.Int32); | ||
154 | // vectors | ||
155 | SqliteParameter PositionX = createSqliteParameter("PositionX", DbType.Double); | ||
156 | SqliteParameter PositionY = createSqliteParameter("PositionY", DbType.Double); | ||
157 | SqliteParameter PositionZ = createSqliteParameter("PositionZ", DbType.Double); | ||
158 | SqliteParameter VelocityX = createSqliteParameter("VelocityX", DbType.Double); | ||
159 | SqliteParameter VelocityY = createSqliteParameter("VelocityY", DbType.Double); | ||
160 | SqliteParameter VelocityZ = createSqliteParameter("VelocityZ", DbType.Double); | ||
161 | SqliteParameter AngularVelocityX = createSqliteParameter("AngularVelocityX", DbType.Double); | ||
162 | SqliteParameter AngularVelocityY = createSqliteParameter("AngularVelocityY", DbType.Double); | ||
163 | SqliteParameter AngularVelocityZ = createSqliteParameter("AngularVelocityZ", DbType.Double); | ||
164 | SqliteParameter AccelerationX = createSqliteParameter("AccelerationX", DbType.Double); | ||
165 | SqliteParameter AccelerationY = createSqliteParameter("AccelerationY", DbType.Double); | ||
166 | SqliteParameter AccelerationZ = createSqliteParameter("AccelerationZ", DbType.Double); | ||
167 | // quaternions | ||
168 | SqliteParameter RotationX = createSqliteParameter("RotationX", DbType.Double); | ||
169 | SqliteParameter RotationY = createSqliteParameter("RotationY", DbType.Double); | ||
170 | SqliteParameter RotationZ = createSqliteParameter("RotationZ", DbType.Double); | ||
171 | SqliteParameter RotationW = createSqliteParameter("RotationW", DbType.Double); | ||
172 | 170 | ||
171 | da.UpdateCommand = createPrimUpdateCommand(primDataDefs); | ||
172 | da.UpdateCommand.Connection = conn; | ||
173 | 173 | ||
174 | SqliteCommand delete = new SqliteCommand("delete from prims where UUID = :UUID"); | 174 | SqliteCommand delete = new SqliteCommand("delete from prims where UUID = :UUID"); |
175 | delete.Parameters.Add(createSqliteParameter("UUID", DbType.String)); | ||
175 | delete.Connection = conn; | 176 | delete.Connection = conn; |
176 | |||
177 | SqliteCommand insert = | ||
178 | new SqliteCommand("insert into prims(" + | ||
179 | "UUID, ParentID, CreationDate, Name, " + | ||
180 | "Text, Description, SitName, TouchName, " + | ||
181 | "CreatorID, OwnerID, GroupID, LastOwnerID, " + | ||
182 | "OwnerMask, NextOwnerMask, GroupMask, EveryoneMask, BaseMask, " + | ||
183 | "PositionX, PositionY, PositionZ, " + | ||
184 | "VelocityX, VelocityY, VelocityZ, " + | ||
185 | "AngularVelocityX, AngularVelocityY, AngularVelocityZ, " + | ||
186 | "AccelerationX, AccelerationY, AccelerationZ, " + | ||
187 | "RotationX, RotationY, RotationZ, RotationW" + | ||
188 | ") values (" + | ||
189 | ":UUID, :ParentID, :CreationDate, :Name, " + | ||
190 | ":Text, :Description, :SitName, :TouchName, " + | ||
191 | ":CreatorID, :OwnerID, :GroupID, :LastOwnerID, " + | ||
192 | ":OwnerMask, :NextOwnerMask, :GroupMask, :EveryoneMask, :BaseMask, " + | ||
193 | ":PositionX, :PositionY, :PositionZ, " + | ||
194 | ":VelocityX, :VelocityY, :VelocityZ, " + | ||
195 | ":AngularVelocityX, :AngularVelocityY, :AngularVelocityZ, " + | ||
196 | ":AccelerationX, :AccelerationY, :AccelerationZ, " + | ||
197 | ":RotationX, :RotationY, :RotationZ, :RotationW)"); | ||
198 | |||
199 | insert.Connection = conn; | ||
200 | |||
201 | SqliteCommand update = | ||
202 | new SqliteCommand("update prims set " + | ||
203 | "UUID = :UUID, ParentID = :ParentID, CreationDate = :CreationDate, Name = :Name, " + | ||
204 | "Text = :Text, Description = :Description, SitName = :SitName, TouchName = :TouchName, " + | ||
205 | "CreatorID = :CreatorID, OwnerID = :OwnerID, GroupID = :GroupID, LastOwnerID = :LastOwnerID, " + | ||
206 | "OwnerMask = :OwnerMask, NextOwnerMask = :NextOwnerMask, GroupMask = :GroupMask, = :EveryoneMask, = :BaseMask, " + | ||
207 | " = :PositionX, = :PositionY, = :PositionZ, " + | ||
208 | " = :VelocityX, = :VelocityY, = :VelocityZ, " + | ||
209 | " = :AngularVelocityX, = :AngularVelocityY, = :AngularVelocityZ, " + | ||
210 | " = :AccelerationX, = :AccelerationY, = :AccelerationZ, " + | ||
211 | " = :RotationX, = :RotationY, = :RotationZ, = :RotationW " + | ||
212 | "where UUID = :UUID"); | ||
213 | update.Connection = conn; | ||
214 | |||
215 | delete.Parameters.Add(UUID); | ||
216 | |||
217 | insert.Parameters.Add(UUID); | ||
218 | insert.Parameters.Add(Name); | ||
219 | insert.Parameters.Add(CreationDate); | ||
220 | insert.Parameters.Add(PositionX); | ||
221 | insert.Parameters.Add(PositionY); | ||
222 | insert.Parameters.Add(PositionZ); | ||
223 | |||
224 | update.Parameters.Add(UUID); | ||
225 | update.Parameters.Add(Name); | ||
226 | update.Parameters.Add(CreationDate); | ||
227 | update.Parameters.Add(PositionX); | ||
228 | update.Parameters.Add(PositionY); | ||
229 | update.Parameters.Add(PositionZ); | ||
230 | |||
231 | da.DeleteCommand = delete; | 177 | da.DeleteCommand = delete; |
232 | da.InsertCommand = insert; | ||
233 | da.UpdateCommand = update; | ||
234 | } | 178 | } |
235 | 179 | ||
236 | private void StoreSceneObject(SceneObject obj) | 180 | private void StoreSceneObject(SceneObject obj) |