সরাসরি প্রধান সামগ্রীতে চলে যান

spring boot e mapping table ki entity use kore create korte hobe? amar problem hocche amar mapping table e id nai. only 03 ta field thakbe. arekta table er id use kore multiple data map korbo

হ্যাঁ, Spring Boot + JPA তে mapping table (join table / association table) বানাতে সবসময় আলাদা id ফিল্ড দরকার হয় না। আপনার যেহেতু mapping table-এ মাত্র ৩টা ফিল্ড থাকবে এবং অন্য টেবিলের id দিয়ে multiple data map করবেন, তাই এখানে সবচেয়ে ভাল সমাধান হচ্ছে Composite Primary Key ব্যবহার করা।

আমি পরিষ্কারভাবে ৩টা workable solution দিচ্ছি 👇


✅ Scenario (আপনার সমস্যার ভিত্তিতে অনুমান)

ধরা যাক ২ টা main টেবিল আছে —

Table A: user

| id | | --- | | 1 |

Table B: role

| id | | --- | | 10 |

এখন mapping table:

Table C: user_role_map

| user_id | role_id | extra_value | | --- | --- | --- |

এই mapping table-এ নিজস্ব id নাই, শুধু foreign key + অতিরিক্ত একটা field থাকবে।


✅ Solution 1: @Embeddable + @EmbeddedId (Best Practice ✅)

Step 1: Composite key class বানাও

@Embeddable
public class UserRoleId implements Serializable {
@Column(name = "user_id")
private Long userId;

@Column(name = "role_id")
private Long roleId;

// equals() and hashCode() MUST generate

}


Step 2: Mapping Entity

@Entity
@Table(name = "user_role_map")
public class UserRoleMap {
@EmbeddedId
private UserRoleId id;

@Column(name = "extra_value")
private String extraValue;

@ManyToOne
@MapsId("userId")
@JoinColumn(name="user_id")
private User user;

@ManyToOne
@MapsId("roleId")
@JoinColumn(name="role_id")
private Role role;

}

✅ এখানে আলাদা id লাগে না

✅ database normalization perfect

✅ Duplicate map insert হবে না


✅ Solution 2: Composite Key (@IdClass ব্যবহার করে)

@Entity
@IdClass(UserRoleId.class)
@Table(name="user_role_map")
public class UserRoleMap {
@Id
@Column(name="user_id")
private Long userId;

@Id
@Column(name="role_id")
private Long roleId;

@Column(name="extra_value")
private String extraValue;

}

👉 কিন্তু এটা relational mapping এর জন্য @EmbeddedId থেকে একটু দুর্বল।


✅ Solution 3 (Avoid ❌): আলাদা id বানানো

অনেকে করে:

id | user_id | role_id | value

যেটা আপনার দরকার নাই এবং উচিতও না।


✅ Practical Usage (Save example)

UserRoleId id = new UserRoleId();
id.setUserId(1L);
id.setRoleId(10L);

UserRoleMap map = new UserRoleMap(); map.setId(id); map.setExtraValue("SOME_VALUE");

userRoleRepo.save(map);


✅ Database Table (PostgreSQL)

CREATE TABLE user_role_map (
  user_id BIGINT,
  role_id BIGINT,
  extra_value VARCHAR(255),
  PRIMARY KEY (user_id, role_id)
);

✅ আপনার জন্য Best Recommendation

👉 Solution 1 (@EmbeddedId) use করুন

এটা সবচেয়ে clean, scalable এবং enterprise level standard।

আপনি চাইলে আপনার current table structure দিলে আমি exact entity code বানিয়ে দিতে পারবো আপনার project এর মতো করে।

মন্তব্যসমূহ

এই ব্লগটি থেকে জনপ্রিয় পোস্টগুলি

সিজ্জিন (Sijjin) vs ইল্লিয়িন (Illiyin) পার্থক্য Difference

Sijjin (سِجِّين) এবং Illiyin (عِلِّيِّين) —এ দুটি শব্দ কুরআনে এসেছে এবং দুটোই মানুষের আমলনামা সংরক্ষণ সম্পর্কিত স্থানকে নির্দেশ করে। ১. সিজ্জিন (Sijjin) সিজ্জিন হলো পাপীদের (কাফের, মুনাফিক ও দুরাচারীদের) আমলনামা সংরক্ষণের স্থান। এটি সাত তলদেশের নীচে এক কারাগার বা অন্ধকার জগতে অবস্থিত বলে উল্লেখ রয়েছে। সূরা আল-মুতাফফিফীন (৮৩:৭-৯) তে বলা হয়েছে: "كَلَّا إِنَّ كِتَابَ الْفُجَّارِ لَفِي سِجِّينٍ ۝ وَمَا أَدْرَاكَ مَا سِجِّينٌ ۝ كِتَابٌ مَرْقُومٌ" অর্থ: "না, পাপীদের আমলনামা সিজ্জিনে সংরক্ষিত। তুমি কি জানো, সিজ্জিন কী? এটি এক লিখিত দলিল।" সিজ্জিনকে একটি কারাগার, সংকীর্ণ স্থান, বা নিচের স্তরে অবস্থিত এক অন্ধকার দুনিয়া হিসেবে ব্যাখ্যা করা হয়। ২. ইল্লিয়িন (Illiyin) ইল্লিয়িন হলো সৎকর্মশীলদের (মুমিন ও নেককারদের) আমলনামা সংরক্ষণের স্থান । এটি সপ্তম আসমানের ওপরে সংরক্ষিত এক সম্মানিত স্থান। সূরা আল-মুতাফফিফীন (৮৩:১৮-২১) তে বলা হয়েছে: "كَلَّا إِنَّ كِتَابَ الْأَبْرَارِ لَفِي عِلِّيِّينَ ۝ وَمَا أَدْرَاكَ مَا عِلِّيُّونَ ۝ كِتَابٌ مَرْقُومٌ ۝ يَش...

Allow CSP in Chrome and Firefox and Call Server API in Spring boot Bangla

ঠিক আছে 🔥। আমি তোমার জন্য একটি সম্পূর্ণ README-style document বানাচ্ছি, যেখানে Chrome এবং Firefox দুটোতেই Spring Boot backend-এর জন্য CSP এবং CORS ঠিকভাবে configure করার process step-by-step আছে। README: CSP & CORS Configuration for Spring Boot (Chrome & Firefox) Overview এই document-এ দেখানো হয়েছে কিভাবে: Spring Boot backend থেকে Content Security Policy (CSP) configure করা যায়। Spring Boot backend থেকে Cross-Origin Resource Sharing (CORS) allow করা যায়। Chrome ও Firefox-এ fetch/API calls চালাতে হয় কীভাবে। ⚠️ Important: নিচের setup mostly development/test environment-এর জন্য। Production environment-এ অবশ্যই CSP & CORS secure করে configure করতে হবে। 1. Spring Boot Backend Configuration 1.1 CSP (Content Security Policy) Spring Boot WebFlux বা Spring MVC application-এ CSP header সেট করতে হবে: a) WebFlux (reactive) import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.web....

AWS Lambda কী?

AWS Lambda কী? AWS Lambda হল একটি সার্ভারলেস কম্পিউটিং সার্ভিস, যা AWS ক্লাউডে কোড রান করার জন্য ব্যবহৃত হয়। Lambda ব্যবহারকারীদের কোনো সার্ভার বা ইনফ্রাস্ট্রাকচার ম্যানেজমেন্ট ছাড়াই কোড চালাতে সাহায্য করে। এটি মূলত ইভেন্ট-ড্রিভেন, যেখানে বিভিন্ন AWS সেবা (যেমন S3, DynamoDB, SNS) বা কাস্টম ইভেন্ট দ্বারা Lambda ফাংশন ট্রিগার হতে পারে। Lambda কোড রান করার পর তা একাধিক আউটপুট জেনারেট করতে পারে, অথবা অন্যান্য সিস্টেমে ফলাফল পাঠাতে পারে। Lambda একটি serverless প্ল্যাটফর্ম, যার মানে হল আপনি কোনও সার্ভার বা হোস্টিং ম্যানেজ করবেন না। আপনি শুধুমাত্র আপনার কোড লেখবেন এবং Lambda সার্ভিস তার ইনফ্রাস্ট্রাকচার পরিচালনা করবে। AWS Lambda এর প্রধান সুবিধা: সার্ভার পরিচালনা প্রয়োজন নেই : আপনি কেবল কোড লেখবেন, সার্ভার বা ইনফ্রাস্ট্রাকচার সম্পর্কিত কোনও চিন্তা করার দরকার নেই। স্কেলিং : Lambda স্বয়ংক্রিয়ভাবে ইনফ্রাস্ট্রাকচার স্কেল করতে পারে। আপনার অ্যাপ্লিকেশনের উপর ট্রাফিক বাড়লে Lambda আপনাআপনি সেই অনুযায়ী স্কেল হবে। কোনও ইনিশিয়াল কস্ট নেই : আপনি শুধুমাত্র আপনার কোড রান হওয়া সময়ের জন্য খরচ দেন, স...