Cohorts
  • Discover
  • About Us
  • Blog
  • Patika.dev
  • Web3

Node.js

Node.js Nedir?
Çalışma Ortamının Kurulması
Asal Sayılar Çalışması
Node.js REPL Ortamı
Ödev 1 - Node.JS Komut Satırı Kullanımı

Node.js'in Asenkron Yapısı
Callback Nedir?
Promise Nedir?
Async - Await Yapısı
Ödev 2 - Post Sıralama ve Post Ekleme

Olay Odaklı - Bloklamayan
Modül Kavramı
Ödev 3 - Daire Modülü
FS Modülü Kullanımı
Ödev 4 - FS Modülü Çalışması
NPM ve Package.json Kavramları
Request - Response Döngüsü
Bir Web Sunucusu Yazmak
Ödev 5 - Kendi Web Sunucumuz
Express.js Giriş
Ödev 6 - Koa.js ile Web Sunucusu Yazımı

PCAT Proje Tanıtımı
PCAT Projesi Çalışma Ortamı
PCAT Projesi Express Nodemon Kurulumu
Clean Blog Proje - 1. Bölüm - Ödev 7
Statik Dosyalar - Middleware Giriş
Template Engine Kavramı
Clean Blog Proje - 2. Bölüm - Ödev 8
MongoDB Giriş
MongoDB - Compass Kurulumu
Mingo Kurulumu
MongoDB - CRUD İşlemleri
Mongoose CRUD İşlemleri
Request Body Nesnesi
Model ve Dinamik İçerik
Clean Blog Proje - 3. Bölüm - Ödev 9
Tekil Fotoğraf Sayfaları
Clean Blog Proje - 4. Bölüm - Ödev 10
Görsel Yüklemek
Fotoğraf Bilgisi Güncellemek
Fotoğraf Silmek
MVC Yeniden Düzenleme
Clean Blog Proje - 5. Bölüm - Ödev 11
PCAT Sayfalama
Heroku - MongoDB Atlas Deployment
Clean Blog Proje - 6. Bölüm - Ödev 12

Smartedu Projesi Tanıtım
HTTP Durum Kodları
Linkleri Güncellemek
Routing - Yönlendirme
Kurs Modeli
Postman ve API
Kursları Listelemek
Tekil Kurs Sayfası ve Slugify
Kategori Oluşturmak ve Listelemek
Kayıt Sayfası ve Bcrypt Paketi
Giriş Sayfası ve Giriş İşlemi
Session Nedir?
Çıkış İşlemi
Kişiye Özel İçerik
Özel Middleware
Kullanıcı Rolleri
Kurs Oluşturmak
Kurs - Öğretmen İlişkisi
Kurs - Öğrenci İlişkisi
Kurs - Öğrenci İlişkisi II
Search Alanı
İletişim Sayfası ve Mail Göndermek
Bildirim Mesajları
Kayıt ve Kullanıcı Doğrulama
Kurs Silmek
Kurs Güncellemek
Admin Alanı ve Kullanıcı Silmek
Kategori Eklemek ve Silmek
Smartedu Deployment

Kurs - Öğretmen İlişkisi


Bu çalışmamızda öğretmen rolüne sahip kullanıcıyla oluşturduğu kurs ilişkisini oluşturacağız. Bunun için ilgili kursta user alanı oluşturacağız. Bu alanın referans yani ilişkili olduğu model iser User modelimiz.


user: {
    type:mongoose.Schema.Types.ObjectId,
    ref:'User'
  }


Bu şekilde kurs ile onu oluşturan kullanıcı arasında bir ilişki kurabildik. Artık yeni bir kurs oluşturulurken sadece kurs bilgilerini değil o kursu oluşturan kullanıcıyı da kullanabiliriz. O halde o kursu oluşturan kullanıcıyı nasıl bulacağız? Tabii ki sessionda bulunan userID ile.


  const course = await Course.create({
      name: req.body.name,
      description: req.body.name,
      category: req.body.category,
      user: req.session.userID
    });


Artık Kurs modelinin içerisinde bulunan kullanıcı bilgisine populate ile ulaşabiliriz.


const course = await Course.findOne({slug: req.params.slug}).populate('user')


İlgili template dosyasında kursu oluşturan kullanıcının örneğin isim bilgisine ulaşabiliriz.


<h3 class="author_name"><a href="#"><%= course.user.name %></a></h3>



Proje GitHub


Çalışma Özel GitHub

Previous
Next

Lesson discussion

Swap insights and ask questions about “Node.js”.

Enroll to participate
Start the course to unlock the discussion. Enrolling helps us keep conversations relevant to learners.
Cohorts
WebsiteDiscoverBlogPatika.devRise In
CoursesCircleRustSoliditySolanaWeb3 FundamentalsBlockchain Basics
CompanyAbout UsTerms of UsePrivacy PolicyGDPR NoticeCookies
Don't miss any update!

Disclaimer: The information, programs, and events provided on https://cohorts.patika.dev is strictly for upskilling and networking purposes related to the technical infrastructure of blockchain platforms. We do not provide financial or investment advice, nor do we make any representations regarding the value, profitability, or future price of any blockchain or cryptocurrency. Users are encouraged to conduct their own research and consult with licensed financial professionals before engaging in any investment activities. https://cohorts.patika.dev disclaims any responsibility for financial decisions made by users based on the information provided here.

© 2026 Cohorts, All rights reserved