This is a discussion on Need good idea within the Oracle Database forums, part of the Database Server Software category; --> Hi guys We have a following problem. For security reasons in each table in our DB we have addition ...
| |||||||
| Register | FAQ | Members List | Calendar | Search | Today's Posts | Mark Forums Read |
| ||||
| Hi guys We have a following problem. For security reasons in each table in our DB we have addition field which is calculated as hash value of all columns in particular row. Every time when some field in particular row is changed we create and call select query from our application to obtain all fields for this row and then re-calculate and update the hash value again. Obviously such approach is very ineffective, the alternative is to create trigger on update event and then execute stored procedure which will re-calculate and update the hash value. The problem with this approach is that end user could then change the date in the tables and then run this store procedure to adjust hash value. We are looking for some solution that could speed up the hash value updating without allowing authorized user to do it Thanks in advance, Leon |
| |||
| Vlad Olevsky wrote: > Hi guys > > We have a following problem. For security reasons in each table in our > DB we have addition field which is calculated as hash value of all > columns in particular row. > > Every time when some field in particular row is changed we create and > call select query from our application to obtain all fields for this > row and then re-calculate and update the hash value again. > > Obviously such approach is very ineffective, the alternative is to > create trigger on update event and then execute stored procedure which > will re-calculate and update the hash value. The problem with this > approach is that end user could then change the date in the tables and > then run this store procedure to adjust hash value. > > We are looking for some solution that could speed up the hash value > updating without allowing authorized user to do it > > Thanks in advance, > Leon In DB2 for LUW you can define the column as a generated column. I presume you have some sort of UDF already that does the actually hashing. Last I heard SS 2005 will have persistent generated columns as well. In general (x-product) you can use a combination of a check constraint and (before) triggers. One must but wonder WHY this column is required. Are you affraid of corruption or sabotage? Cheers Serge -- Serge Rielau DB2 SQL Compiler Development IBM Toronto Lab |
| |||
| Vlad Olevsky wrote: > Hi guys > > We have a following problem. For security reasons in each table in our > DB we have addition field which is calculated as hash value of all > columns in particular row. > > Every time when some field in particular row is changed we create and > call select query from our application to obtain all fields for this > row and then re-calculate and update the hash value again. > > Obviously such approach is very ineffective, the alternative is to > create trigger on update event and then execute stored procedure which > will re-calculate and update the hash value. The problem with this > approach is that end user could then change the date in the tables and > then run this store procedure to adjust hash value. > > We are looking for some solution that could speed up the hash value > updating without allowing authorized user to do it > > Thanks in advance, > Leon And you need to send this to every ng you cal spell? Obviously, you're not aware of the security mechanisms within Oracle. Who allowed the end user to execute that procedure? -- Regards, Frank van Bortel |
| |||
| "Vlad Olevsky" <leonid4142@yahoo.com> schrieb im Newsbeitrag news:50540181.0505030658.64f68390@posting.google.c om... > Obviously such approach is very ineffective, the alternative is to > create trigger on update event and then execute stored procedure which > will re-calculate and update the hash value. The problem with this > approach is that end user could then change the date in the tables and > then run this store procedure to adjust hash value. > > We are looking for some solution that could speed up the hash value > updating without allowing authorized user to do it As Frank pointed out, try to create a trigger which calls a function. Let the function run with the grants of the caller and give only authorized callers the exec grant of the function. Greetings! Volker |
| ||||
| Vlad Olevsky wrote: > Hi guys > > We have a following problem. For security reasons in each table in our > DB we have addition field which is calculated as hash value of all > columns in particular row. > > Every time when some field in particular row is changed we create and > call select query from our application to obtain all fields for this > row and then re-calculate and update the hash value again. > > Obviously such approach is very ineffective, the alternative is to > create trigger on update event and then execute stored procedure which > will re-calculate and update the hash value. The problem with this > approach is that end user could then change the date in the tables and > then run this store procedure to adjust hash value. > > We are looking for some solution that could speed up the hash value > updating without allowing authorized user to do it > > Thanks in advance, > Leon This may come as a shock to you Leon but the solution in each of the products whose usenet group you copied on this uses a completely different solution. I'd suggest you start by apologizing, to all, for your lack of identifying the product and version and for posting to every usenet group you can spell. And then repost in the one, and only, group where your query is appropriate. Thank you. -- Daniel A. Morgan University of Washington damorgan@x.washington.edu (replace 'x' with 'u' to respond) |