Halaman

Jumat, 28 Mei 2010

Indikator

Indikator adalah acuan untuk mengetahui kenormalan dalam suatu sistem. Dengan indikator kita dapat mengetahui dimana kita berada, kemana kita bergerak, seberapa jauh pencapaian/kinerja atau seberapa jauh kita dari posisi acuan. Indikator merupakan ukuran, referensi atau indeks yang menjadi detektor dalam mengenali suatu hasil proses, yang pada gilirannya dapat memberikan petunjuk mengenai apa yang harus dibenahi.

Contoh indikator dapat ditemui dalam hasil pemeriksaan darah yang berisi angka penunjuk tentang jumlah trombosit, hematoktrit, dsb. Disertai dengan informasi dari pasien atau jika perlu dengan tambahan indikator lain, para Diagnoser dapat menegakkan diagnosa. Saat berjalan di kawasan pabrik, dan melihat kepulan asap yang hitam pekat, para engineer bisa menduga what happen there, atau saat mengendarai mobil, kita dapat mengetahui apakah kecepatan saat ini sesuai dengan Max. Speed, jika tidak maka prrriiiit...kena tilang.

Perjalanan Menuju Kota Tujuan
Pada tahun 1988, saya naik bis dari Jember ke Jakarta. Berangkat jam 4 sore dan tiba di Pulogadung pukul 10 pagi keesokan harinya. Perlu waktu 22 jam dengan biaya sekitar 100 ribu. Saat naik pesawat, dari Jakarta ke Medan diperlukan waktu sekitar 2 jam. Tarifnya pun tergantung pada airlines yang digunakan, jika diratakan sekitar 1,5 juta. Naik Ferry ke Tomok, Samosir perlu waktu 1 jam, dan dari sini ke kampung saya di Sideak merupakan perjalanan yang indah dengan viewnya Tao Toba na uli.

Dalam "perjalanan" ini sang Sopir mengantar penumpangnya sampai di tempat tujuan.
Apa yang ada dalam benak keluarga jika dalam 25 jam, belum tiba di Jakarta? Berbagai kontak telepon dilakukan untuk mengetahui kabar.

Apa yang ada dalam benak penumpang pesawat, saat melihat jam tangan dan ternyata sudah 2 jam 30 menit dan Anda belum landing? Dari balik mikropon sang Stewardess/Pilot menyampaikan bahwa ban pesawat tidak terbuka dan berupaya menenangkan penumpang. Penumpang tegang panik, serta merta berbagai doa dipanjatkan kepadaNya.

Indikator sederhana untuk sampai di tempat tujuan adalah Keselamatan. Disisi lain faktor Waktu dan Biaya menjadi interest factors saat pembicaraan memasuki area efektifitas dan efisiensi.

Perjalanan Menuju Penyelesaian Studi
Saat belajar ukuran keberhasilan siswa tercermin dalam Rapor atau KHS. IP yang diperoleh merupakan indikator kepuasan atas hasil studi mahasiswa. Mungkin saja seseorang dengan IP rendah -dapat berhasil dalam kehidupannya- jika dibandingkan IP yang diraihnya, namun IP 3 adalah tiket bagi para pencari kerja untuk lolos persyaratan administrasi pada semua jenis lowongan pekerjaan. Bagaimana dengan lama Studi? Ya beberapa organisasi memiliki kriteria seleksi yang lebih ketat.

Dalam "perjalanan" ini, sang Mahasiswa menjadi Manager bagi dirinya sendiri. Dengan resources yang ada padanya Ia mengorganisir dan mengarahkannya untuk mencapai tujuan yang didambakan saat di kelas 3 SMA. Bagaimana jika setelah 5 tahun, sang Mahasiswa belum selesai studi? Para stakeholders akan bertanya-tanya.

Ayah: Mas, kapan lulus?
Mhs: Sebentar lagi Ayah, saya susah ketemu dosen pembimbing Skripsi. Kuliah sekarang susah, banyak yg harus dipelajari. Doakan Ayah supaya saya cepat lulus.
(Ferry: kalo alasan kayak gini...hehehe pembaca pasti dapat membuat interpretasi logis sendiri.)

Ayah: Mas, kapan lulus?
Mhs: Semester kemarin saya ngulang untuk mata kuliah Ekonometrika, ingin buat IP 3, dan semester depan saya ambil Skripsi. Lulusnya 9 bulan lagi setelah skripsi selesai. Doakan Ayah supaya saya cepat lulus.
(Ferry: yaa...cukup logis, rupanya sang Siswa ingin IP 3).

Indikator sederhana untuk lulus S1, yaitu Lama Studi dan IP. Biaya studi mungkin menjadi interest factors dalam studi penelitian kelulusan.

Perjalanan Menuju Kemenangan Pertandingan
Sekitar 2 minggu lalu saya menonton pertandingan Pro Liga Volly antara Samator dan BNI. Pertandingan yang seru dan menarik ditunjukkan oleh kedua tim. Saya turut tegang, mungkin juga para pihak yang secara emosional terikat dalam keluarga besar maupun fans, apalagi Organ Tim yang selama ini bekerja keras untuk masuk final.

Dengan skor sebagai indikatornya, Pelatih dan Manajer Tim mengubah strategi dan taktik bertanding, dan dengan catatan pada recording log pemain, mereka mengganti dan mengistirahatkan pemain, memberi semangat, mengarahkan semua sumber daya untuk mencapai tujuan "to be a winner". BNI akhirnya tak terbendung oleh Samator sang juara bertahan.

Setelah kedua Tim kembali ke markas mereka, apa yang dilakukan? Yes, mengapresiasi perjuangan berat dan tentu Evaluasi untuk perbaikan berikutnya. Indikator keberhasilan adalah Win atau Loss. Bagi para Tim interest factors mungkin berupa Skor, kesalahan/ keberhasilan individu pemain, kekuatan lawan.

Perjalanan Pencapaian Visi
Dalam operasional sektor private maupun sektor publik terdapat indikator pencapaian/kinerja. Dari sisi manajemen Keuangan, Operasional, Pemasaran, SDM, dan Strategi (waah saya baru sadar nih sama dengan jumlahnya Pilihan Konsentrasi/Penjurusan saat kuliah) akan diukur dan kemudian dievaluasi. Caranya pun beragam dengan melibatkan Sejawat Satu Level, oleh atasan Satu Level di atas, oleh bawahan Satu Level di bawah, bahkan dengan Customer maupun Ownernya.

Indikatornya tertuang misalnya dalam KPI, KGI, Strategic Objectives, Standar Pelayanan Minimal. Misalnya dalam bidang kesehatan kita, mengetahui visi tentang "Indonesia Sehat 2010". Disana tertuang detail kriterianya. Dalam bidang ekonomi makro ada studi indikatornya dan bidang perbankan.

Ukuran keberhasilan Sopir adalah No Accident dan penumpang tiba di Terminal tujuan, bagi Pelatih adalah kemenangan, dan bagi Siswa adalah kelulusan. Indikator ini begitu jelas dan mudah diinderai.

Bagaimana dengan ukuran di sektor private dan publik? Beberapa diantaranya Growth, Profit,
Sustainability...silahkan baca Laporan dan Juknisnya.

Inti Indikator adalah measurable dan observable.

Selasa, 18 Mei 2010

Export PostgreSQL table into CSV file

1. Change directory to PostgreSQL binary folder or just type this command if the search path is already listed in your environment paths.

C:\pgsql83\bin>psql -dmydb -Uferry

mydb# COPY customer TO 'C:/myfolder/allcust.csv' DELIMITER ';';
COPY 5076

mydb# COPY (SELECT * FROM customer WHERE city ='PNK') TO E'C:\\myfolder\cityPNK.csv' DELIMITER ';' CSV;
COPY 502

mydb# \q

See: Import from CSV files into PostgreSQL Table

Importing a CSV file into PostgreSQL table

1. Export your data into CSV format. Remember the field delimiter you specify here (I prefer the semicolon) and you must pay attention or change it later if the import process fails. Also uncheck the option for first line as a header so that the CSV file contains only data.

2. If not exists, create a table in PostgreSQL with the data type that can accommodate the data to be imported.

3. Change directory to PostgreSQL binary folder or just type this command if the search path is already listed in your environment paths.

C:\pgsql83\bin>psql -dmydb -Uferry
mydb# COPY dest_table FROM 'C:/myfolder/myfile.csv' USING DELIMITERS ';';
COPY 10537

mydb# COPY another_dest_table FROM 'C:/myfolder/myfile22.csv' USING DELIMITERS ';';
COPY 300024

mydb# \q

See: Export from PostgreSQL to CSV files

Sabtu, 15 Mei 2010

My list show only one record after doing edit-close form repeatedly

I was coding a form with a datagridview for single table. All Insert, Update, and Delete operations work well and satisfy me. But I saw a strange behaviour, when I did these:

1. Open the form, Edit some data, then click Save button..(data updated successfully!)
2. Close the form.
3. Do step 1-2 repeatedly.

After n times opening-editing-closing the form, the datagridview only show one record???
My list show only one record after doing edit-close form repeatedly.

public partial class frmCoa : mybasefrm.frmMainGrdView
{
private MySqlDataAdapter gda;
private DataTable gdt;
private DBOPS.SqlHelper;

private void frmCoa_Load(object sender, EventArgs e)
{
gHelper = new DBOPS.SqlHelper();
gda = gHelper.getDataAdapter("SELECT * FROM akun");
MySqlCommandBuilder gcmdBldr = new MySqlCommandBuilder(gda);
gdt = new DataTable();
gda.Fill(gdt);
bindSrc0.DataSource = gdt;
bindNav0.BindingSource = bindSrc0;
dgv.DataSource = bindSrc0;
...do binding
}

private void btnSave_Click(object sender, EventArgs e)
{
try
{
Validate();
bindSrc0.EndEdit();
gda.Update(gdt);
startingEdit(false);
base.buttonNormal();
}
catch (System.Exception ex)
{
MessageBox.Show("Error: " + ex.Message);
return;
}
dgv.Enabled = true;
}
}


.

The form has a Query button, then without closing the application, I did some query to display all or some data, all query work as expected.

Don't know why this happened, and my guess is related to connection and data adapter (Fill method). I disable pooling connection in my connection string, and this seems quite resolve my problem. Any idea?

Selasa, 11 Mei 2010

Backup and restore all database between MySQL instances

I have two instances of MySQL, one using 5.0.27 and the other 5.5.3. My requirement is to transfer all database to a new one. I try to backup all database and restore using My SQL Administration Tools. All database successfully restored (imported) to the new instance, but got problem with privilege that reports Column count of mysql.proc is wrong. Expected 20, found 16. The table is probably corrupted.

Then I look at the backup script but could not found command to create/insert user privilege on mysql database. Probably I missed something, and glad to hear from you. I switch the way, and try following steps:

1. Do backup:
shell5027>mysqldump -uroot -ppass --all-database > C:\temp\sqldataku.sql

Then opened the backup script and found commands to create-insert users privileges on mysql database, something like these:

CREATE DATABASE /*!32312 IF NOT EXISTS*/ `mysql` /*!40100 DEFAULT CHARACTER SET latin1 */;
USE `mysql`;
DROP TABLE IF EXISTS `db`;
CREATE TABLE `db` ( .... )...;
INSERT INTO `db` VALUES ('%','cms','fercms','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y'),....);

INSERT INTO `user` VALUES ('localhost','root','*7775476747C6AD73358FA54DAED7828A72014B4E','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0),('%','fercms','*778F407DE7C65307389FA34AAED7828A72014B4E','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','','','','',0,0,0,0), ...);

mysql.user table contains user list (with passwords) and their global privileges, mysql.db handles users' database-level privileges.

2. Do restore:
shell553>mysql -uroot -ppass < C:\temp\sqldataku.sql

3. Do flush privilege:
shell553>mysql -uroot -ppass
mysql> flush privileges;
mysql>\q

Test the database using myprogram or tools but come with error message: Column count of mysql.proc is wrong. Expected 20, found 16. The table is probably corrupted;

4. Do upgrade, by run this command:
shell553>mysql_upgrade -uroot -ppass --tmpdir=C:\temp\

Looking for 'mysql.exe' as: shell553\mysql.exe
Looking for 'mysqlcheck.exe' as: shell553\mysqlcheck.exe
Running 'mysqlcheck' with connection arguments: "--port=3306"
drupal64.access OK
drupal64.actions OK
fkm.phpbb_acl_groups OK
fkm.phpbb_acl_options OK
Running 'mysql_fix_privilege_tables'...
ERROR 1547 (HY000) at line 167: Column count of mysql.proc is wrong. Expected 20, found 16. The table is probably corrupted
ERROR 1547 (HY000) at line 168: Column count of mysql.proc is wrong. Expected 20, found 16. The table is probably corrupted
ERROR 1547 (HY000) at line 181: Column count of mysql.proc is wrong. Expected 20, found 16. The table is probably corrupted
WARNING: NULL values of the 'character_set_client' column ('mysql.proc' table) have been updated with a default value (cp850). Please verify if necessary.
WARNING: NULL values of the 'collation_connection' column ('mysql.proc' table) have been updated with a default value (cp850_general_ci). Please verify if necessary.
WARNING: NULL values of the 'db_collation' column ('mysql.proc' table) have been updated with default values. Please verify if necessary.
FATAL ERROR: Upgrade failed

Once again I run the command:
shell553>mysql_upgrade -uroot -ppass --tmpdir=C:\temp\
...
...
Running 'mysql_fix_privilege_tables'...
OK

I did the command again, and reported that "This installation of MySQL is already upgraded to 5.5.3-m3, use --force if you still need to run mysql_upgrade".

If these solve my requirement above (I have to see in future), than I suspect that first try using MySQL Administration Tools should work as well.

Senin, 10 Mei 2010

SELECT command denied for table 'proc'

By using MySQL Administrator Tool or phpMyAdmin, we could administer users. For example create Esterina as a new user then grant all available privilege to her. One of the privilige granted was run by this command.

GRANT CREATE ROUTINE ON mydb.* TO esterina@ 'localhost';

The CREATE ROUTINE privilege is needed to create stored routines (procedures and functions).

On her desk, she open TOAD, create some table then create a procedure with this command:

DROP PROCEDURE IF EXISTS mydb.'tester';
CREATE PROCEDURE mydb.'tester'(IN stat INT)
BEGIN
set @STATUS=stat;
END;

The procedure created successfully, but she could not see the procedure on TOAD GUI. She will receive an error message:

MySQL Database Error
SELECT command denied to user esterina@ 'localhost'
for table 'proc';

For her to be able to see her procedure, she must contact her boss, then with super user privilege the adminstrator run this:

GRANT SELECT ON mysql.proc TO esterina@ 'localhost';

Esterina back to her workbench, with tons of plan!

Minggu, 09 Mei 2010

Does SQLite support foreign keys?

Short Answer:
FOREIGN KEY constraints are parsed but are not enforced. However, the equivalent constraint enforcement can be achieved using triggers.

A. Foreign Key (FK)
FK is a referential constraint between two tables. A FK is a field(s) that reference to the primary key of another table. The purpose of the FK is to ensure referential integrity of the data. The values in one row of the referencing columns must occur in a single row in the referenced table. Thus, a row in the referencing table cannot contain values that don't exist in the referenced table (except potentially NULL).

This way references can be made to link information together and it is an essential part of database normalization. Multiple rows in the referencing table may refer to the same row in the referenced table. Most of the time, it reflects the one (master table, or referenced table) to many (child table, or referencing table) relationship.

FK is defined in DDL (Data Definition Language), so we do not code in our application. Once we define FK constraints, they must remain true while inputting/modifying/deleting data in the database. Constraints are used to enforce table rules and prevent data dependent deletion (enforce database integrity).


B. Enforce Foreign Key Constraint using PRAGMA
The PRAGMA statement is a SQL extension specific to SQLite and used to modify the operation of the SQLite library or to query the SQLite library for internal (non-table) data. The foreign_keys pragma controls the enforcement of foreign key constraints in all of the attached databases. If set to off, foreign key constraints are ignored. The default value is off.

For many years SQLite would parse foreign key constraints, but was unable to enforce them. When native support for foreign key constraints was finally added to the SQLite core, enforcement was left off by default to avoid any backwards compatibility issues.

This default value may change in future releases. To avoid problems, it is recommended that an application explicitly set the pragma one way or the other. This pragma cannot be set when there is an active transaction in progress.

1. Parent table: We define Primary Key
CREATE TABLE parentorder (
jmid VARCHAR(16) NOT NULL PRIMARY KEY,
jmdate DATE NOT NULL,
jmsupp VARCHAR(6) NOT NULL);


2. Child table: We define a reference to primary key above
CREATE TABLE childorder (
jm2id VARCHAR(16) NOT NULL CONSTRAINT fk_childorder_id REFERENCES parentorder(jmid),
jm2no VARCHAR(3) NOT NULL,
jm2itemid VARCHAR(6) NOT NULL,
jm2qty INTEGER NOT NULL,
PRIMARY KEY (jm2id,jm2no));

Test them in SQLite
sqlite>select sqlite_version();
3.6.23.1
sqlite> insert into parentorder values ('A1','2010-05-08','SUP1');
sqlite> insert into childorder values ('A1','P','CODE1', 10.5);
sqlite> insert into childorder values ('A1','V','CODE2', 11);

here we try with unexisting key in the primary key of parentorder table.
sqlite> insert into childorder values ('A2','X','CODE3', 12);

We see, FK constraint does not work, because the data A2 successfully inserted! It should raise an error for A2 is not exist in parent table.

Let's continue...with the PRAGMA statement
sqlite> PRAGMA foreign_keys;
0

Here we enforce the foreign key constraint to ON by using PRAGMA statement
sqlite> PRAGMA foreign_keys=1;
sqlite> update childorder set jm2id='A3' WHERE jm2id='A2';
Error: foreign key constraint failed


Look! We could not change A2 to A3, it means the FK constraint works!

sqlite> update childorder set jm2id='A1' WHERE jm2id='A2';
sqlite> select * from childorder;
A1 P CODE1 10.5
A1 V CODE2 11
A1 X CODE3 12


sqlite> select * from parentorder;
A1 2010-05-08 SUP1

sqlite> update childorder set jm2id='A3' WHERE jm2id='A1';
Error: foreign key constraint failed

C. Using Pragma in Program
using C#:
conn = new SQLiteConnection(connString);
conn.Open();
const string sqlString = "PRAGMA foreign_keys = ON;";
SQLiteCommand command = new SQLiteCommand(sqlString, conn); command.ExecuteNonQuery();


D. Trigger
Maintain FK constraints in above scenario might be not simple as it should be, such as enforce FK constraint each time we use database or when using application through connection string, or set the pragma in SQLite command line. For these reason, below we implemet triggers for FK constraints. See more.

-- Foreign Key Preventing insert
CREATE TRIGGER fki_childorder_jm2id_parentorder_jmid
BEFORE INSERT ON [childorder]
FOR EACH ROW
BEGIN
SELECT RAISE(ROLLBACK, 'insert on table "childorder" violates foreign key constraint "fki_childorder_jm2id_parentorder_jmid"')
WHERE (SELECT jmid FROM parentorder WHERE jmid = NEW.jm2id) IS NULL;
END;

-- Foreign key preventing update
CREATE TRIGGER
fku_childorder_jm2id_parentorder_jmid
BEFORE UPDATE ON [childorder] FOR EACH ROW
BEGIN
SELECT RAISE(ROLLBACK, 'update on table "childorder" violates foreign key constraint "fku_childorder_jm2id_parentorder_jmid"')
WHERE
(SELECT jmid FROM parentorder WHERE jmid = NEW.jm2id) IS NULL;
END;

-- Foreign key preventing delete
CREATE TRIGGER fkd_childorder_jm2id_parentorder_jmid
BEFORE DELETE ON parentorder
FOR EACH ROW
BEGIN
SELECT RAISE(ROLLBACK, 'delete on table "parentorder" violates foreign key constraint "fkd_childorder_jm2id_parentorder_jmid"')
WHERE
(SELECT jm2id FROM childorder WHERE jm2id = OLD.jmid) IS NOT NULL;
END;

E. Testing Trigger Code
sqllite>.exit
C:\sqllite3>sqlite tesdb
SQLite version 3.6.23.1

sqlite> copy-paste fki_childorder_jm2id_parentorder_jmid trigger above!
sqlite> insert into childorder values ('A1ERR','P','CODE1', 10.5);
Error: insert on table "childorder" violates foreign key constraint "fki_childorder_jm2id_parentorder_jmid"

sqlite> do the same for fku_childorder_jm2id_parentorder_jmid!
sqlite> update childorder set jm2id='TESTING';
Error: update on table "childorder" violates foreign key constraint "fku_childorder_jm2id_parentorder_jmid"

sqlite> do the same for fkd_childorder_jm2id_parentorder_jmid!
sqlite> delete from parentorder;Error: delete on table "parentorder" violates foreign key constraint "fkd_childorder_jm2id_parentorder_jmid"

--This pragma returns one row for each foreign key that references a column in the argument table.
sqlite> pragma foreign_key_list('childorder');
0 0 parentorder jm2id jmid NO ACTION NO ACTION NONE


F. Utility
1. Use this utility to generate triggers to enforce foreign key constraints with sqlite, operates on database schema and understands most CREATE TABLE syntax. Win32 and linux x86 binaries included, public domain source code.

2. The triggers code above is generated using this web tool. You could try by copy-paste the two Create Table statement above (B.1 and B.2) then click Submit.


G. Trigger vs Constraint
Constraint is a rule define in DDL statement (Foreign Key, Primary Key, etc).
Trigger is a rule define using DML statement.
Both are useful in special situation.

Using triggers we could define complex processing logic, and also support all of the functionality of constraints; however, DML triggers are not always the best method for a given feature.

Entity integrity should always be enforced at the lowest level by indexes that are part of PRIMARY KEY and UNIQUE constraints or are created independently of constraints. Domain integrity should be enforced through CHECK constraints, and referential integrity (RI) should be enforced through FOREIGN KEY constraints, assuming their features meet the functional needs of the application. DML triggers are most useful when the features supported by constraints cannot meet the functional needs of the application.

Each RDBMS has their way for implementation of constraints and triggers, and we also know that there is SQL standards to meet. For constraints and triggers,  I keep these guidance:
-FK constraints can validate a column value only with an exact match to a value in another column, unless the REFERENCES clause defines a cascading referential action.
-Constraints can communicate about errors only through standardized system error messages.
-DML triggers can cascade changes through related tables in the database; however, these changes can be executed more efficiently through cascading referential integrity constraints.
-DML triggers can disallow or roll back changes that violate referential integrity, thereby canceling the attempted data modification. Such a trigger might go into effect when you change a foreign key and the new value does not match its primary key. However, FOREIGN KEY constraints are usually used for this purpose.
-If constraints exist on the trigger table, they are checked after the INSTEAD OF trigger execution but prior to the AFTER trigger execution. If the constraints are violated, the INSTEAD OF trigger actions are rolled back and the AFTER trigger is not executed.

Wish that in the next officials release of SQLite, the foreign keys constraints come with default on.