Çarşamba, Şubat 20, 2008

MySQL Error Number 1005

Bu hataya ilişkin faydalı bir yazı Şu adresten alınma
MySQL Error Number 1005
Can't create table './erehber/#sql-7451_16aa06.frm' (errno: 150)
Benim hata her iki tablonunda innoDB olması ile çözüldü.
____________________________________________________

Filed Under (MySQL) by Jason on 22-10-2006

MySQL Error Number 1005
Can’t create table ‘.\mydb\#sql-328_45.frm’ (errno: 150)

If you get this error while trying to create a foreign key, it can be pretty frustrating. The error about not being able to create a .frm file seems like it would be some kind of OS file permission error or something but this is not the case. This error has been reported as a bug on the MySQL developer list for ages, but it is actually just a misleading error message.

In every case this is due to something about the relationship that MySQL doesn’t like. Unfortunately it doesn’t specify what the exact issue is. Here is a running list of causes that people have reported for the dreaded errno 150. I’ve tried to put them in order based on the frequency that I hear about a particular cause.

You may want to start by running the MySQL command “SHOW INNODB STATUS” immediately after receiving the error. This command displays log info and error details. (Thanks Jonathan for the tip)

Known Causes:

  1. The two key fields type and/or size doesn’t match exactly. For example, if one is INT(10) the key field needs to be INT(10) as well and not INT(11) or TINYINT. You may want to confirm the field size using SHOW CREATE TABLE because Query Browser will sometimes visually show just INTEGER for both INT(10) and INT(11). You should also check that one is not SIGNED and the other is UNSIGNED. They both need to be exactly the same. (More about signed vs unsigned here).
  2. One of the key field that you are trying to reference does not have an index and/or is not a primary key. If one of the fields in the relationship is not a primary key, you must create an index for that field. (thanks to Venkatesh and Erichero and Terminally Incoherent for this tip)
  3. The foreign key name is a duplicate of an already existing key. Check that the name of your foreign key is unique within your database. Just add a few random characters to the end of your key name to test for this. (Thanks to Niels for this tip)
  4. One or both of your tables is a MyISAM table. In order to use foreign keys, the tables must both be InnoDB. (Actually, if both tables are MyISAM then you won’t get an error message - it just won’t create the key.) In Query Browser, you can specify the table type.
  5. You have specified a cascade ON DELETE SET NULL, but the relevant key field is set to NOT NULL. You can fix this by either changing your cascade or setting the field to allow NULL values. (Thanks to Sammy and J Jammin)
  6. Make sure that the Charset and Collate options are the same both at the table level as well as individual field level for the key columns. (Thanks to FRR for this tip)
  7. You have a default value (ie default=0) on your foreign key column (Thanks to Omar for the tip)
  8. One of the fields in the relationship is part of a combination key & does not have it’s own index. You must create a separate index for the key field in order to use it in a constraint. (Thanks to Alex for this tip)
  9. You have a syntax error in your ALTER statement (Thanks to Christian for the tip)

The MySQL documentation includes a page explaining requirements for foreign keys. Though they don’t specifically indicate it, these are all potential causes of errno 150. If you still haven’t solved your problem you may want to check there for deeper technical explainations.If you run into this error and find that it’s caused by something else, please leave a comment and I’ll add it to the list.

Perşembe, Şubat 14, 2008

Oracle

Ms SQL Server, MySql, Sybase derken yeni gözdem Oracle. Daha önce hiç tanışmadığım benim için bu yeni RDMS ile bakalım ne kadar yol katedebileceğim.
Dün 10g Enterprise kurmayı başardım. Kurulum sırasında önemli bir ayrıntı varmış. Regional Settingse takılıyor niyeyse. Regional Settings'i İngilizce yapınca sorunsuz kuruluyor. E tabi Enterprise bir sistem olduğu için midir bilinmez, şu anda belleğimin 300mbytını kendine ayırmış keyf ediyor görünüyor.

Oracle kaldırmak

Google Cache ten bir zamanlar www.zevkli.org/oraclei-sistemden-kaldirmak-t393196.html adresinde yer alan Oracle'ın kaldırılması hakkında yazıyı buraya kopyaladım. Belki cachete de bulunmaz falan..

Eğer Oracle Veritabanına ihtiyacınız kalmadıysa ya da tüm veritabanı sistemini başta kurmak istiyorsanız doğal olarak makineninizdeki mevcut Oracle veritabanını kaldırmanız gerekir. Bu yazıda, Oracle 10g'nin sistemden tamamen kaldırılması ele alınmakta.
Eğer Oracle Veritabanına ihtiyacınız kalmadıysa ya da tüm veritabanı sistemini baştan kurmak istiyorsanız doğal olarak makineninizdeki mevcut Oracle veritabanını kaldırmanız gerekir. Ama bir Oracle Veritabanını sistemden tamamıyla kaldırma işlemi kurulu diğer programlara göre zahmetli bir iştir.
Bunun için öncelikle bilgisayarınızda yüklenmiş olan Oracle servislerini kapatmalısınız. Bu servisleri kısa yoldan görebilmek için bilgisayarınızda “başlat” düğmesine tıkladıktan sora “çalıştır” düğmesine basın. Çıkan pencereye “services.msc” yazıp “enter” düğmesine basın.

Normal şartlarda aşağıdakine benzer bir pencere karşınıza gelecektir.


Bu pencereden adı Oracle ile başlayan servisleri bulun ve bunları (üzerine gelip sağa tıkladıktan sonra “dur” a basarak) durdurun.

Bütün Oracle servislerini durdurduktan sonra servisler penceresini kapatın.
Şimdi makinemizde kurulu Oracle sunucusunu kaldıracağız. Oracle Sunucusunu Windows un Denetim Masasından Program ekle/kaldır menüsünden kaldıramayız. Mevcut sunucuyu silmek için Başlat -> Programlar -> oracle – OraDB Home1 -> Oracle Installation Products -> Universal Installer’ı başlatın.
Installer programi karşınıza kısa bir süre için siyah ekran açıp kapatacktır. Daha sonra karşınıza gelen wellcome penceresinde “Deinstall products” ı tıklayın.

Gelen penceredeki kutucukları işaretleyip “remove” a tıklayın.

Gelen onay penceresinde “yes” e tıklayın. Karşınıza silme penceresi gelecektir



Silme işlemi biraz zaman alabilir. Bu arada çay/kahve içebilirsiniz.
Silme işi bittiğinde aşağıdaki pencereyle karşılaşacaksınız. Close a basarak kapatırsanız
ana pencereye döneceksiniz.


Ana pencere tekrar karşınıza gelecektir. Ana pencereyi kapatmak için üzerinde “cancel” a basın.

Gelen onay penceresinde “evet” diyerek çıkın.

Eğer bu aşamada servisler menüsüne girerseniz, hala silinmemiş bazı servislerle karşılaşabilirsiniz. Hatta Başlat Menüsünden programlar a girerseniz hala Oracle ile ilgili bazı kayıtların varlığıyla karşılaşabilirsiniz. Bunları temizlemek için “çalıştır” komut girdisine “regedit” yazarak Windows Kayıt Defterine girin.

Karşınıza gelen pencerede “HKEY_LOCAL_MACINE” klasörünü açtıktan sonra “SOFTWARE” klasörünü açın.

ORACLE” klasörünü bulun ve silin. Artık Oracle, Programlar menüsünden silinmiş olmalıdır.

Daha sonra yine “HKEY_LOCAL_MACHINE” klasöründeki “SYSTEM” alt klasöründen CurrentControlSet klasörünü, onun içinden de “Services” klasörünü açın.

Gelen pencerede Oracle klasörlerini bulun ve silin.

Silme işleminden sonra makinenizi yeniden başlattığınızda Hizmetler menüsünden Oracle servisleri kalkmış olacaktır.
Şimdi sıra sistemdeki Oracle klasörlerini silmeye geldi. Bunun için Oracle Veritabanını kurduğunuz klasörü bulun. Bu klasör tipik olarak “oracle” ismindedir ve içinde ora90 (9i için) ya da product (10g için) alt klasörünü barındıran ana klasördür. Bu klasörü içindekilerle birlikte “Shift+del” komutuyla silin.
Son olarak “Program Files” altındaki “Oracle” isimli klasörü silmeniz gerekiyor.
Tüm bu işlemleri bitirdiğinizde sisteminizden Oracle Veritabanını tamamıyle kaldırmış olacaksınız.
Geçmiş olsun.