From: Andrea A. <and...@ge...> - 2015-03-29 10:05:10
|
Hi, as an aside to the discussion about how slow ContentDataStore is to check type names, we've found that the Oracle JDBC driver is giving that inefficient code a good help to slow everything down to a cringe. JDBCDataStore.createTypeNames() uses the JDBC metadata to list the available tables. Now, I believe most jdbc drivers will only list the tables available to the user connecting, but the Oracle driver does not, it lists _everything_, regardless of whether you can list it or not. In a large installation, and in cases where one does not specify the schema in order to allow the user to access multiple schemas, we get the list of every single table avalable in the database. This is very slow, but also stupid (think of a app showing the list of tables to the users, when adding a new layer). So, here is the idea, what if we move the jdbc metadata scan down in the dialects, as the default implementation, thus allowing specific db implementations to optimize out the driver in case there are better ways to list only the tables we're interested into? For the Oracle case it seems we could leverage USER_TAB_PRIVS function: the http://docs.oracle.com/cd/B14117_01/server.101/b10755/statviews_2661.htm http://oracle.su/docs/11g/timesten.112/e13070/ttsql388.htm Cheers Andrea -- == GeoServer Professional Services from the experts! Visit http://goo.gl/NWWaa2 for more information. == Ing. Andrea Aime @geowolf Technical Lead GeoSolutions S.A.S. Via Poggio alle Viti 1187 55054 Massarosa (LU) Italy phone: +39 0584 962313 fax: +39 0584 1660272 mob: +39 339 8844549 http://www.geo-solutions.it http://twitter.com/geosolutions_it *AVVERTENZE AI SENSI DEL D.Lgs. 196/2003* Le informazioni contenute in questo messaggio di posta elettronica e/o nel/i file/s allegato/i sono da considerarsi strettamente riservate. Il loro utilizzo è consentito esclusivamente al destinatario del messaggio, per le finalità indicate nel messaggio stesso. Qualora riceviate questo messaggio senza esserne il destinatario, Vi preghiamo cortesemente di darcene notizia via e-mail e di procedere alla distruzione del messaggio stesso, cancellandolo dal Vostro sistema. Conservare il messaggio stesso, divulgarlo anche in parte, distribuirlo ad altri soggetti, copiarlo, od utilizzarlo per finalità diverse, costituisce comportamento contrario ai principi dettati dal D.Lgs. 196/2003. The information in this message and/or attachments, is intended solely for the attention and use of the named addressee(s) and may be confidential or proprietary in nature or covered by the provisions of privacy act (Legislative Decree June, 30 2003, no.196 - Italy's New Data Protection Code).Any use not in accord with its purpose, any disclosure, reproduction, copying, distribution, or either dissemination, either whole or partial, is strictly forbidden except previous formal approval of the named addressee(s). If you are not the intended recipient, please contact immediately the sender by telephone, fax or e-mail and delete the information in this message that has been received in error. The sender does not give any warranty or accept liability as the content, accuracy or completeness of sent messages and accepts no responsibility for changes made after they were sent or for other risks which arise as a result of e-mail transmission, viruses, etc. ------------------------------------------------------- |