Maison > Questions et réponses > le corps du texte
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插入数据吗?
ringa_lee2017-04-17 15:16:31
1.select (auto_increment-1) from information_scheme.tables where table_name='TableName'
2.select last_insert_id()
天蓬老师2017-04-17 15:16:31
这个要看你用的数据持久层框架了,一般来说都是可以的。
mybatis的话你可以看看这些:
http://lavasoft.blog.51cto.com/62575/1384959/
http://my.oschina.net/u/1256344/blog/159703
hibernate的话也差不多,你搜一下 hibernate/Mybatis 获取自增id 就可以了。
怪我咯2017-04-17 15:16:31
Hibernate我用的比较少,平时用的是Mybatis,说说Mybatis的做法吧。
你的teacher表结构,id是主键,并且自增,是这样进行配置。mybatis xml文件里,需要在insert前面加上
<selectKey resultType="java.lang.Long" order="AFTER"
keyProperty="id">
SELECT LAST_INSERT_ID()
</selectKey>
即可
天蓬老师2017-04-17 15:16:31
last_insert_id()是一种;
触发器也可以,
create trigger `insert_teacherCourse` AFTER INSERT on `teacher`
for each row
insert into teacherCourse(teacherId) values(NEW.id);
大致写了下,teacherCourse里面还有些是not null的也要插入