Skip to main content

AccessTr.neT


Formdan Tabloya Kayıt Yaparken,,silerken Makro Yerine Vba Kodları Kullanımı

Oğuz Türkyılmaz
Oğuz Türkyılmaz
12
3343

Formdan Tabloya Kayıt Yaparken,,silerken Makro Yerine Vba Kodları Kullanımı

Çözüldü #1
Merhabalar 
Projemde hemen her form düzenlememde İlgili Tabloya 

Kaydı Kaydet - Kaydı Sil - Yeni Kayıt - Formu Kapat - İlk Kayda Git - Son Kayda Git - Önceki Kayıt - Sonraki Kayıt - Formu Kapat katıştırılmış makroları kullanıyorum. Bu işlemleri VB kodlarıyla ilgili butonun olay yordamına yazılması gerekiyor sanırım yanlışım varsa düzeltin lütfen,  belli bir şablonla nasıl yazabilirim. ( Kodun içeriğine ben sadece ilgili tablonun adını yazarak ilgili formlarda tüm katıştırılmış makroları değiştirmek ve yeni formlarda Vba kodlarıyla kod yazmaya kopye çekerek  Img-grin başlamak istiyorum. ( İşin kolayına kaçmak olarak almayın lütfen. ) Forumda arama yaptım bu konuda ama sonuclara ulaşamadım. 
        İsteğim yanlış bir öğrenme metodu olabilir ama bir yerden başlamam lazım diye aklıma gelen çözüm yolu bu oldu.Yardımlarınız için şimdiden teşekkürler.
Access Çekirgesi 
[Resim: img-cray.gif]


Cevapla
#2
(10/10/2018, 07:31)Oğuz Türkyılmaz yazdı: Merhabalar 
Projemde hemen her form düzenlememde İlgili Tabloya 

Kaydı Kaydet - Kaydı Sil - Yeni Kayıt - Formu Kapat - İlk Kayda Git - Son Kayda Git - Önceki Kayıt - Sonraki Kayıt - Formu Kapat katıştırılmış makroları kullanıyorum. Bu işlemleri VB kodlarıyla ilgili butonun olay yordamına yazılması gerekiyor sanırım yanlışım varsa düzeltin lütfen,  belli bir şablonla nasıl yazabilirim. ( Kodun içeriğine ben sadece ilgili tablonun adını yazarak ilgili formlarda tüm katıştırılmış makroları değiştirmek ve yeni formlarda Vba kodlarıyla kod yazmaya kopye çekerek  Img-grin başlamak istiyorum. ( İşin kolayına kaçmak olarak almayın lütfen. ) Forumda arama yaptım bu konuda ama sonuclara ulaşamadım. 
        İsteğim yanlış bir öğrenme metodu olabilir ama bir yerden başlamam lazım diye aklıma gelen çözüm yolu bu oldu.Yardımlarınız için şimdiden teşekkürler.

Bence hepsini tek seferde öğrenmeye çalışmak yerine yavaş yavaş ilerleyin.
Mesela önce kayıt ekleme metodunu öğrenmeye çalışın.

Örnek bir kod satırı aşağıda paylaşıyorum.
Kod:
DoCmd.RunSQL "INSERT INTO tanim_tablosu ([tanim_no]) VALUES ('" & Me.txtanimno & "')"
Açıklama kısmına gelirsek; 
DoCmd.RunSQL: Access arayüz bağlantı komutu. 
Insert Into: ekleme komutu. (Delete silme komutu, Update güncelleme komutu, gibi)
tanim_tablosu: verilerin hangi tabloya ekleneceğini belirtiyoruz.
[tanim_no]: tablodaki veri eklenecek alanın adını belirtiyoruz
'" & Me.txtanimno & "': alana eklenecek verinin bulunduğu formdaki metin kutusunu tanımlıyoruz.

kısaca açıklamaya çalıştım. İşi biraz daha ilerleterek "Where" koşul komutunu da öğrenirsiniz...
Cevapla
#3
(10/10/2018, 15:11)Allback yazdı:
(10/10/2018, 07:31)Oğuz Türkyılmaz yazdı: Merhabalar 
Projemde hemen her form düzenlememde İlgili Tabloya 

Kaydı Kaydet - Kaydı Sil - Yeni Kayıt - Formu Kapat - İlk Kayda Git - Son Kayda Git - Önceki Kayıt - Sonraki Kayıt - Formu Kapat katıştırılmış makroları kullanıyorum. Bu işlemleri VB kodlarıyla ilgili butonun olay yordamına yazılması gerekiyor sanırım yanlışım varsa düzeltin lütfen,  belli bir şablonla nasıl yazabilirim. ( Kodun içeriğine ben sadece ilgili tablonun adını yazarak ilgili formlarda tüm katıştırılmış makroları değiştirmek ve yeni formlarda Vba kodlarıyla kod yazmaya kopye çekerek  Img-grin başlamak istiyorum. ( İşin kolayına kaçmak olarak almayın lütfen. ) Forumda arama yaptım bu konuda ama sonuclara ulaşamadım. 
        İsteğim yanlış bir öğrenme metodu olabilir ama bir yerden başlamam lazım diye aklıma gelen çözüm yolu bu oldu.Yardımlarınız için şimdiden teşekkürler.

Bence hepsini tek seferde öğrenmeye çalışmak yerine yavaş yavaş ilerleyin.
Mesela önce kayıt ekleme metodunu öğrenmeye çalışın.

Örnek bir kod satırı aşağıda paylaşıyorum.
Kod:
DoCmd.RunSQL "INSERT INTO tanim_tablosu ([tanim_no]) VALUES ('" & Me.txtanimno & "')"
Açıklama kısmına gelirsek; 
DoCmd.RunSQL: Access arayüz bağlantı komutu. 
Insert Into: ekleme komutu. (Delete silme komutu, Update güncelleme komutu, gibi)
tanim_tablosu: verilerin hangi tabloya ekleneceğini belirtiyoruz.
[tanim_no]: tablodaki veri eklenecek alanın adını belirtiyoruz
'" & Me.txtanimno & "': alana eklenecek verinin bulunduğu formdaki metin kutusunu tanımlıyoruz.

kısaca açıklamaya çalıştım. İşi biraz daha ilerleterek "Where" koşul komutunu da öğrenirsiniz...
Çok teşekkür ederim. Hemen uygulayıp geri bidirimde bulunurum.
Access Çekirgesi 
[Resim: img-cray.gif]


Cevapla
#4
Sn.Allback

Bu kod satırını kullanarak bir kayıt yapmaya çalıştım doğal olarak beceremedim hata verdi diye yazdım ama sonra başardım , sorum şu tablomda 6 farklı alanım var bu 6 alan için 6 satır yazdım. Fakat bu şekilde her satırı ayrı bir kayıt numarasına kaydetti.  Örnek yazabilirmisiniz formdaki tüm bilgileri tabloda tek satıra kaydetmek için hangi kodu yazmalıyım . Teşekkür ederim.
.rar DENEME.rar (Dosya Boyutu: 30,39 KB | İndirme Sayısı: 10)
Access Çekirgesi 
[Resim: img-cray.gif]


Son Düzenleme: 11/10/2018, 22:04, Düzenleyen: Oğuz Türkyılmaz.
Cevapla
#5
Merhaba,
Formunuzun kayıt kaynağı olduğu için ve metin kutularının denetim kaynağına bu kayıt kaynağındaki alanlar belirlendiği için

 DoCmd.RunCommand acCmdSaveRecord

kodu ile forma girilen veriler tabloya kaydedilmiş olur.

Sizin örnek koddaki insert into olayı hatalı. Uygulamada TBL_001_KISILER adında tablo yok ve formda Me.txmtn_adi adında denetim yok. 
Olmayan denetimin değerini olmayan tabloya kaydedemezsiniz. 

Adı ve soyadı alanındaki veriyi tabloya insert into ile kaydetmeniz için kodun aşağıdaki gibi olması gerekli

DoCmd.RunSQL "INSERT INTO T_001_KISILER ([adi],[soyadi]) VALUES (" & Me.MTN_ADI & ", " & Me.SOYADI & ")"
Cevapla
#6
(11/10/2018, 22:05)ozanakkaya yazdı: Merhaba,
Formunuzun kayıt kaynağı olduğu için ve metin kutularının denetim kaynağına bu kayıt kaynağındaki alanlar belirlendiği için

 DoCmd.RunCommand acCmdSaveRecord

kodu ile forma girilen veriler tabloya kaydedilmiş olur.

Sizin örnek koddaki insert into olayı hatalı. Uygulamada TBL_001_KISILER adında tablo yok ve formda Me.txmtn_adi adında denetim yok. 
Olmayan denetimin değerini olmayan tabloya kaydedemezsiniz. 

Adı ve soyadı alanındaki veriyi tabloya insert into ile kaydetmeniz için kodun aşağıdaki gibi olması gerekli

DoCmd.RunSQL "INSERT INTO T_001_KISILER ([adi],[soyadi]) VALUES (" & Me.MTN_ADI & ", " & Me.SOYADI & ")"

Yanlış tablo göndermişim onları kaydettim sorumuda yeniden düzenlemiştim.
Access Çekirgesi 
[Resim: img-cray.gif]


Cevapla

Bir hesap oluşturun veya yorum yapmak için giriş yapın

Yorum yapmak için üye olmanız gerekiyor

ya da
Task