Untuk membuat data model pada database aplikasi memang perlu dibuat secara normalize, atau se normal mungkin. Tetapi ada kalanya kita perlu melakukan proses denormalize pada table dengan tujuan pertama jelas untuk menyederhanakan data model, kedua mempermudah pembuatan reporting, dan data minning, ketiga untuk mempercepat query.
Saya akan memberikan ilustrasi untuk mempermudah pembaca memahami proses denormalize pada suatu table. Misalkan ada suatu table yang berisi informasi wilayah yang tersusun secara hirarki dari kota, kecamatan, sampai tingkat RT. Struktur tablenya tersusun secara rekursif membentuk skema parent and child.

Ok, sekarang kita coba menampilkan data tersebut ke dalam reporting services. Sepertinya susah sekali kalau langsung di tampilkan ke dalam reporting services. Karena proses grouping di reporting services ditidak dilakukan dari perintah query tadi dari toolnya langsung. Terus gimana nih ? apakah harus menyerah sampe disini ? ooo, tentu tidak. Kita cari cara laen dengan transformasikan data asli pada table normalize diatas menjadi table yang denormalize sehingga data wilayah dari kota sampai tingkat RT terlihat semuanya pada setiap barisnya seperti terlihat pada tampilan dibawah ini :

Dengan tampilan data seperti ini sangat memudahkan kita untuk membentuk report di reporting services, Proses grouping nya pun cukup simple jadi bisa dibuat drilldown dari kota sampai tingkat RT, Untuk memunculkan data diatas kita bisa membuat view dengan yang berisi query denormalize table, berikut contoh querynya :
SELECT
w.NAMA_WIL,
(SELECT NAMA_WIL FROM WILAYAH WHERE ID_WIL = w.ID_WIL_INDUK) AS RW,
(SELECT NAMA_WIL FROM WILAYAH WHERE ID_WIL =
(SELECT ID_WIL_INDUK FROM WILAYAH WHERE ID_WIL = w.ID_WIL_INDUK)) AS KEL,
(SELECT NAMA_WIL FROM WILAYAH WHERE ID_WIL =
(SELECT ID_WIL_INDUK FROM WILAYAH WHERE ID_WIL=
(SELECT ID_WIL_INDUK FROM WILAYAH WHERE ID_WIL = w.ID_WIL_INDUK))) AS KEC,
(SELECT NAMA_WIL FROM WILAYAH WHERE ID_WIL =
(SELECT ID_WIL_INDUK FROM WILAYAH WHERE ID_WIL=
(SELECT ID_WIL_INDUK FROM WILAYAH WHERE ID_WIL =
(SELECT ID_WIL_INDUK FROM WILAYAH WHERE ID_WIL = w.ID_WIL_INDUK) ))) AS KOTA
FROM
(SELECT * FROM WILAYAH WHERE JNS_WIL='RT') AS W
cara kerja querynya adalah dengan melihat entitas yang paling bawah yaitu RT, dari RT kita bisa melihat parent ID nya yaitu RW dan seterusnya sampe ketemua kotanya.
Semoga bisa memberikan pencerahan kepada pembaca ,,,
March 6th, 2009 | Posted in SQL Server | No Comments
Waktu kita melihat di beberapa situs atau portal besar seperti Yahoo, Google, dan lainnya sering kita lihat tampilan url yang susah dimengerti. Tidak seperti layaknya url yang biasa dan mudah dimengerti maksudnya. Contohnya seperti ini:
http://www.google.co.id/setprefs?sig=0_lAlIdPyCDlP9TeBq9tLdQSFVp0I=&hl=jw
Coba lihat tampilan diatas terutama bentuk url setelah sig, bentuknya aneh dan cukup panjang. Apakah betul value dari ’sig’ berisikan data yang panjang seperti diatas ?
Kalau memang betul didesain seperti itu, hmmm sungguh tindakan yg konyol sekali. Sebenarnya data yang asli tidak sepanjang itu. Data tersebut terlihat panjang karena telah dilakukan proses enkripsi. Buat apa sih di enkrip segala ? ya tentunya untuk menyembunyikan index url dan nilainya dengan tujuannya untuk pengamanan aplikasi web dan serangan dari pihak luar yang biasa dilakuan dengan mencoba-coba memasukkan url ke dalam website yang dituju.
beberapa hari yang lalu, saya menemukan komponen bagus dari TSHAK. Komponen ini dipakai untuk mengenkrip query string. Cukup mudah penggunaannya hanya beberapa baris coding saja kita bisa melakukan enkripsi pada url (Query String).
Untuk mengenkrip query string kita membutuhkan kunci encripsi berupa byte array.
Dim qs As TSHAK.Components.SecureQueryString
qs = New TSHAK.Components.SecureQueryString(New Byte() {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2, 3, 4, 5, })
Cara menambahkan nilai query string :
qs("Myname")= "Dale"
qs("MyAge")= 17
Response.Redirect("Page2.aspx?data=" + HttpUtility.UrlEncode(qs.ToString()))
Sekarang, bagaimana cara mendekrip nilai yang ada di Page2.aspx
Dim qs As TSHAK.Components.SecureQueryString
qs= New TSHAK.Components.SecureQueryString(New Byte() {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2, 3, 4, 5, 8}, Request("data"))
Dim myName=qs("MyName")
Dim age=qs("MyAge")
Bagi yang mau mencobanya Anda bisa mendapatkan library TSHAK
disini
selamat mencoba 
January 14th, 2009 | Posted in .Net | No Comments
sebelum data kita inputkan ke dalam database perlu dilakukan proses validasi agar data yang masuk sudah benar-benar valid dan tidak ada data kotor. salah satu dari sekian banyak macam validasi adalah memvalidasi inputan berupa angka (numeric). Proses validasi ini bisa kita lakukan dengan menggunakan function isNumeric yang sudah terdapat di dalam .Net. Ada banyak cara ketika kita ingin memvalidasi inputan angka, proses cek bisa dilakukan dibelakang/ setelah anda submit data atau bisa juga dilakukan pada saat user mengetikkan data di inputan aplikasi.
Dalam tulisan ini saya akan membahas bagaimana cara membatasi hanya data numeric saja yang bisa diinputkan pada sebuah textBox di aplikasi desktop .Net
Pertama buat sebuah textBox pada Windows Form aplikasi, masuk ke dalam view source dan aktifkan code event KeyPress pada textBox yang akan akan digunakan untuk memvalidasi inputan. Tambahkan kode berikut pada event KeyPress tersebut :
Private Sub txtUn_KeyPress(ByVal sender As Object, ByVal e As System.Windows.Forms.KeyPressEventArgs) Handles txtUn.KeyPress
If Not IsNumeric(e.KeyChar) Then
If e.KeyChar = Chr(Keys.Back) Then
e.Handled = False
Else
e.Handled = True
End If
End If
End Sub
October 31st, 2008 | Posted in .Net | No Comments
Sharing jawaban saat ujian catur wulan dengan temanku waktu SMP memang sudah menjadi tradisi. Aku beruntung punya teman yang selalu juara kelas dan belum pernah tergeser dari podium 1. Namanya Chandra, murid favorit dan paling dasyat untuk masalah nilai. Sementara aku dapat merebut podium 5 besar saja sudah syukur. Pagi hari menjelang ujian kami memikirkan cara terbaik agar bisa tetap berkomunikasi untuk tukar jawaban, sedangkan posisi duduk saling berjauhan. Temenku duduk di bangku paling depan sedangkan aku sendiri duduk di bangku paling belakang, jarak yang cukup jauh untuk memanggil temenku dan aku tidak mungkin berbisik-bisik untuk memanggilnya, pasti akan menimbulkan pengawas ujian curiga. Setelah dipikir-pikir tidak ada cara lain untuk menggunakan jalur perantara, gimana caranya ? ya ibaratnya perlu sebuah relay untuk memperkuat sinyal , hehe kayak jaringan aja. Siapa yang dijadikan relay ? kebetulan di antara kami ada temenku cewek dan posisinya sangat strategis untuk dijadikan relay. Aku coba tawarkan kepadanya untuk menyampaikan pesan dariku untuk temenku yang didepan. Dia pun mulai bertanya “pesan apa sih yang mau disampaikan ?” aku tidak menjawabpun akhirnya dia tahu juga isi pesan yang akan aku kirim. Tanpa berpikir panjang dan dengan senang hati dia menerima tawaran kami. Akhirnya masalah yang satu ini sudah terselasaikan. Tiap pesan yang aku kirim dan aku terima tersampaikan dengan lancar, itu semua berkat adanya perantara temenku.
Ujian sudah selesai, tinggal menunggu hasil rapot yang akan dibagikan minggu depan. Saat pembagian rapot semua murid saling menanyakan masalah ranking di kelas. Untuk podium 1 sudah menjadi langganan temenku Chandra, ini sudah hal yang biasa. Alhamdulillah aku bisa masuk podium 3, wah ternyata metode kami berhasil. Situasi kelas mulai ramai ketika ada seorang murid yang tidak terlalu pandai bisa merebut posisi rangking di podium 2. Wah ini kejadian yang luar binasa !!! perlu diketahui siapakah orang tersebut ??? dan ternyata dia adalah temenku cewek yang kami jadikan relay untuk media pertukaran jawaban selama ujian catur wulan kemaren. Dan semua ini hanya kami yang tahu. Sepertinya ada pihak yang diuntungkan dari komunikasi kami, metode kemarin sudah tidak layak lagi untuk digunakan.
Four Mount Later….
Ujian catur wulan berikutnya sudah tiba, kami harus berpikir lagi untuk mencari solusi terbaik agar kami tetap bisa bertukar jawaban tanpa bisa diketahui atau dimanfaatkan oleh temenku. Kebetulan kebanyakan soal didominasi dengan soal pilihan ganda, akhirnya kami punya suatu ide cemerlang dengan membuat aturan sandi. Biasanya jawaban yang kami kirimkan adalah jawaban aslinya, dan sekarang tidak semudah itu. jawaban pilihan ganda A,B,C,D akan digeser satu kali sehigga A => B, B=> C dan seterusnya. Sebelum masuk ruang kelas, temenku cewek menghampiri kami dan menanyakan apakah dia masih difungsikan sebagai relay ? kami pun menjawab “Oh ya kami tetap memperpanjang kontrak kamu sebagai relay sampai akhir tahun ”, hehehee ya asal jangan ditelan mentah-mentah aja, ungkap kami dalam hati. Seperti biasa ujian berjalan seperti ujian kemaren. Komunikasi tetap lancar dan kami makin tenang dengan aturan baru. Setiap selesai ujian kami selalu ketawa-ketiwi, kami ketawa bukan karena ide sandi yang telah kami buat, kami ketawa karena kebodohan temenku yang dengan polosnya menelan mentah2 sandi yang kami kirimkan, dan dia tidak melakukan cross cek atas jawaban tersebut. Semingu setelah ujian rapotpun dibagikan. Tidak ada perubaha posisi rangking dari catur wulan yang kemaren. Hanya saja podium dua tidak lagi tempati oleh temenku cewek. Terus diposisi berapakah dia sekarang ? ya , dia harus tergeser dari posium dua ke posisi 20. Pastinya ini membuat dia curiga tentang kami. Ternyata betul, tak lama setelah pembagian rapot selesai dia mendatangi kami. Terlihat matanya berkaca2 sambil melihat hasil ujiannya yg jelek. Dengan perasaan marah campur jengkel dia memaki-maki kami. Sungguh ini pemandangan terburuk yang pernah kami lihat. Akhirnya kami menyadari imbas dari ide gila ini. Kami mencoba meminta maaf padanya bahwa ini semua salah kami. Sejak kejadian itu aku dan temenku Chandra tidak lagi saling bertukar jawaban saat ujian. Kami tidak ingin ada korban kedua, ketiga dan seterusnya dari ide sandi kami.
Paling tidak ini bisa menjadi kenangan waktu sekolah secara tidak sadar sudah menerapkan konsep krytography. Dan kami senang melakukannya waktu itu.
October 3rd, 2008 | Posted in when I was young | No Comments
bingung mau dibikin apa situs pribadi. setelah dipikir-pikir akhirnya aku coba tanem wordpress aja di sini.
Dan pertualanganku akan segera dimulai …
September 17th, 2008 | Posted in Uncategorized | 1 Comment