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

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) ইল্লিয়িন হলো সৎকর্মশীলদের (মুমিন ও নেককারদের) আমলনামা সংরক্ষণের স্থান । এটি সপ্তম আসমানের ওপরে সংরক্ষিত এক সম্মানিত স্থান। সূরা আল-মুতাফফিফীন (৮৩:১৮-২১) তে বলা হয়েছে: "كَلَّا إِنَّ كِتَابَ الْأَبْرَارِ لَفِي عِلِّيِّينَ ۝ وَمَا أَدْرَاكَ مَا عِلِّيُّونَ ۝ كِتَابٌ مَرْقُومٌ ۝ يَش...

তারাবিহ সমগ্র - প্রথম আলো

রামাদান ২০২৪ উপলক্ষে প্রথম আলোর নিয়মিত আয়োজন - খতমে তারাবিহ'র সূরা গুলো নিয়ে সংক্ষিপ্ত আলোচনা'র লিংক  নিচে দেওয়া হলো।  লিংকে ক্লিক করলেই আপনাকে আলোচনা তে নিয়ে যাবে। তারাবিহ: ১ | একটি খুন ও গাভি নিয়ে বনি ইসরাইলের বাড়াবাড়ি তারাবিহ: ২ | নারীর মর্যাদা ও অধিকার এবং অলৌকিক তিন ঘটনা তারাবিহ: ৩ | যে ১৪ নারীকে বিয়ে করা হারাম তারাবিতে: ১২ | মহানবী (সা.)–এর আকাশভ্রমণ এবং আসহাবে কাহাফের কাহিনি

রেডমি নোট ৯ এর বিস্তারিত | Redmi Note 9 in Bangla

৩০ এপ্রিল, ২০২০ এ শাওমির ঘোষনা আসে এই ফোনটি নিয়ে। কিন্তু ফোনটি মার্কেটে আসে মে মাসের শেষের দিকে৷ করোনার কারনে ফোনটি বাংলাদেশে আসতে আরো সময় নেয়। বর্তমানে বাংলাদেশে আন অফিশিয়াল ভাবে ফোনটি পাওয়া যাচ্ছে৷ বাংলাদেশে অফিশিয়াল ভাবে এখনো ফোনটি আসার তথ্য নেয়৷ চলুন ফোনটি নিয়ে বিস্তারিত আলোচনা করা যাক। শাওমি নোট সিরিজের ফোন বের করে এদের রেডমি নামে সাব ব্যান্ড৷ এদের কাজ হল এই নোট সিরিজ নিয়ে কাজ করা৷ প্রতিবছর নোট সিরিজের ১/২ টা ফোন বাজারে আসে। সাথে সেই ফোন গুলার বিভিন্ন ভার্সন (যেমন - র‍্যাম ও রমের ভিত্তিতে) বাজারে আসে। এই বছরও তারা রেডমি সিরিজের নোট ৯ বাজারে আনে। এই বছর হয়তো এই সিরিজের আরো ফোন বাজারে আসবে। ডিস্পলেঃ ফোনটির ডিসপ্লে সাইজ ৬.৫৩ ইঞ্চি। এতে আইপিএস এলসিডি ডিসপ্লে ব্যবহার করা হয়েছে। এই ফোনের ডিসপ্লে প্রটেকশন হিসেবে আছে গরিলা গ্লাস ফাইভ। স্ক্রিন আর ফোনের বডির অনুপাত প্রায় ৮৩.৫%। এই ফোনের ডিসপ্লে ফুলএইচডি মানে ১০৮০পি। এই ডিস্পলের দৈর্ঘ্য ১৯.৫ একক এবং প্রস্থ হল ৯ একক। এত বড় ফোনের কারনে এই ফোনের পিপি আই ডেনসিটি ৩৯৫। যা একটু কম। প্লাটফর্মঃ এই ফোনের অপারেটিং সিস্টেম এন্ড্রয়েড ১০ এবং এর...