mysql 同时向两张关联表插入数据

create table teacher(
    id int(11) not null auto_increment,
    name varchar(10) not null,
    primary key(id)
)engine=innodb;

create table teacherCourse(
    teacherId int(11) not null,
    courseNum int(10) not null,
    courseName varchar(50) not null,
    constraint foreign key(teacherId) references staff(id) on delete cascade,
    primary key(teacherId, courseNum)
)engine=innodb;

我想在teacher表增加一条记录的同时也要为teacherCourse增加一条记录,问题是表1的id是自增的,能先获取刚插入自增的id然后作为表2的teacherId插入数据吗?

阅读 22.5k
4 个回答

1.select (auto_increment-1) from information_scheme.tables where table_name='TableName'
2.select last_insert_id()

Hibernate我用的比较少,平时用的是Mybatis,说说Mybatis的做法吧。
你的teacher表结构,id是主键,并且自增,是这样进行配置。mybatis xml文件里,需要在insert前面加上

<selectKey resultType="java.lang.Long" order="AFTER"
            keyProperty="id">
            SELECT LAST_INSERT_ID()
</selectKey>

即可

last_insert_id()是一种;
触发器也可以,

create trigger `insert_teacherCourse` AFTER INSERT on `teacher`
for each row 
insert into teacherCourse(teacherId) values(NEW.id);

大致写了下,teacherCourse里面还有些是not null的也要插入

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进