Przejdź do głównej zawartości

Add-in Show SQL Query and Result




Od dawna brakowało mi przy opcji Show SQL Query podglądu na pobrane dane. Postanowiłem skorzystać z możliwości, które daje CR 2008 i stworzyłem w C# własny dodatek (add-in).

Dodatek o nazwie Show SQL Query and Result, wyświetla zapytanie SQL oraz dodatkowo pobiera wynik zapytania.

Dzięki temu już nie trzeba przeklejać zapytania do innego narzędzia, aby zobaczyć co faktycznie zwraca zapytanie. Co więcej, zapytanie można od ręki modyfikować, ale tylko w celach diagnostycznych - zmodyfikowane zapytanie nie jest zapisywane do raportu, więc nie ma obaw, że "popsujemy" raport.

Instalacja:
2. Skopiuj cscShowSQLQuery.dll do folderu:
C:\Program Files\Business Objects\BusinessObjects Enterprise 12.0\win32_x86\Addins
jeśli nie ma podkatalogu Addins to załóż go.
2. Uruchom lub zrestartuj Crystal Reports
3. Otwórz raport, pojawi się nowe menu Add-ins | Show SQL Query

Ograniczenia
- brak obsługi trusted connection
- błąd, jeśli raport nie jest na bazie sql
poprawię w kolejnej wersji ;-)

Miłego korzystania :)

Mile widziane komentarze.

Komentarze

Anonimowy pisze…
Posiadam CR2011, zainstalowałem VS 2010, Crystal zakomunikował, że pomyślnie zainstalował dodatek, jednak nigdzie nie mogę go uruchomić, czy dodatek dział tylko pod CR2008? ps. Bardzo interesujący blog :)
Marcin pisze…
Tak, w CR 2011 jest problem z dodatkami. Pisałem o tym w poście:
http://sulmar.blogspot.com/2010/12/sap-crystal-reports-2011-bez-sdk.html
Anonimowy pisze…
Zapoznałem się ze wszystkimi postami na Pana blogu :) jednak w poście do którego podał Pan link pisze Pan, że instalacja Visual Studio 2010 rozwiązuje problem. U mnie nie pomogło
Marcin pisze…
Przeczytane wszystkie posty? Jestem pod wrażeniem :)

A czy zainstalował Pan również dodatek Crystal Reports for Visual Studio 2010?

link: http://www.businessobjects.com/jump/xi/crvs2010/default.asp

Unknown pisze…
Ups... Nie. I już widać, że jestem początkującym użytkownikiem - dlatego z dużą ciekawości zapoznawałem się z Blogiem prowadzonym przez pana. Pozdrawiam!
Marcin pisze…
Cieszę się, że mój blog służy nowym użytkownikom.

Na temat CR for VS 2010 pisałem tutaj:
http://sulmar.blogspot.com/2010/12/crystal-reports-for-visual-studio-2010.html
Unknown pisze…
Ten komentarz został usunięty przez autora.
Unknown pisze…
Mógłby Pan udostępnić plik ponownie?

Popularne posty z tego bloga

Konwersja daty w CDN Optima

Crystal Reports jest bardzo często zintegrowany z popularnymi aplikacjami. Przykładem jest system CDN Optima . Początkujących użytkownikom sprawiają kolumny z datą, bo data nie jest zapisana jako datetime lecz jako liczba. Otóż data w CDN Optima zapisana jest w formacie Clarion, czyli liczba dni, które upłynęły od daty 1800-12-28 . (Czy ktoś wie co to za data w historii?) Dlatego jeśli chcemy użyć takiego pola na raporcie, pierwsze co powinniśmy zrobić to dokonać konwersji liczby na datę. W innym przypadku Crystal Reports nie będzie wiedział, że jest to data i żadne formatowanie dat, grupowanie po okresach nie będzie działać. Formuła do konwersji formatu Clarion na datę : Jeśli mamy wiele takich pól to najlepiej utworzyć własną funkcję:

Zamiana daty i czasu na data-czas

Kolejne szkolenie u klienta i kolejne wyzwanie za mną... Chodziło o wygenerowanie raportu czasu pracy z uwzględnieniem, że zmiana następuje o godz. 6:00 a nie o północy. To znaczy, że godziny do 6:00 powinny być jeszcze zaliczane do dnia poprzedniego. Dodatkowym utrudnieniem u klienta był fakt, że data w bazie danych była rozbita na 2 pola: data w formacie: yyyy-mm-dd 00:00:00 godzina w formacie: 1900-01-01 HH:mm W takim razie do dzieła! Załóżmy, że mamy następującą tabelę: 1. Tworzymy formułę która zamieni 2 osobne pola z datą i czasem w jedno pole typu datetime: W ten sposób otrzymamy jedną wartość w formacie yyyy-mm-dd HH:mm 2. Następnie od tak utworzonej daty odejmujemy 6 godzin: Otrzymamy w rezultacie coś takiego: Kolumna WorkDate wyświetla datę do której została zakwalifikowana pozycja. Na podstawie tak utworzonej formuły można utworzyć grupowanie na raporcie.

Koszmar z limitem

Witajcie po dłuższej przerwie. Jakiś czas temu prowadziłem szkolenie w firmie i z jakiegoś powodu nie chciały nam się wyświetlać się wszystkie tabele z ich bazy danych. Na początku myślałem, że to kwestia uprawnień ale okazało się, że użytkownicy mają prawa do odczytu wszystkich tabel a problem wynika z czegoś innego... Okazało się, że winowajcą jest sam Crystal Reports, który ma ustawiony limit(!) na ilość obiektów pobieranych elementów ze struktury bazy danych, czyli tabel, widoków i procedur składowanych razem wziętych. Domyślnie jest to  8000 . Większość baz danych nie przekracza tego limitu, więc możecie spać spokojnie, ale przy większym systemie może nadejść koszmar, który zerwie Was na równe nogi. Pamiętajcie wówczas o moim blogu -  ten limit można zmienić (w praktyce podwyższyć). Niestety nie ma do tego opcji w Crystal Reports, trzeba pogrzebać w rejestrach windows: Zamykamy Crystal Reports Uruchamiamy aplikację Edytor rejestru , z linii poleceń: ...