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

 twinklezai750 发布于 2022-10-31 14:59
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插入数据吗?

4 个回答
  • last_insert_id()是一种;
    触发器也可以,

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

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

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

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

    即可

    2022-10-31 23:22 回答
  • 这个要看你用的数据持久层框架了,一般来说都是可以的。
    mybatis的话你可以看看这些:
    http://lavasoft.blog.51cto.com/62575/1384959/
    http://my.oschina.net/u/1256344/blog/159703

    hibernate的话也差不多,你搜一下 hibernate/Mybatis 获取自增id 就可以了。

    2022-10-31 23:22 回答
  • 1.select (auto_increment-1) from information_scheme.tables where table_name='TableName'
    2.select last_insert_id()

    2022-10-31 23:22 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有