mysql 同时向两张关联表插入数据
高洛峰
高洛峰 2017-04-17 15:14:31
0
4
887
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插入数据吗?

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全員に返信(4)
左手右手慢动作

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

いいねを押す +0
Peter_Zhu

これは、使用するデータ永続層フレームワークによって異なりますが、一般的には問題ありません。
mybatis については、以下をチェックしてください:
http://lavasoft.blog.51cto.com/62575/1384959/
http://my.oschina.net/u/1256344/blog/ 159703

hibernate についても同様です。hibernate/Mybatis を検索して自動インクリメント ID を取得します。

いいねを押す +0
刘奇

私は Hibernate をあまり使用しません。通常は Mybatis を使用します。Mybatis の使用方法について説明します。
先生のテーブル構造では、id が主キーであり、それ自体がインクリメントされます。このように設定します。 mybatis XML ファイルでは、insert の前に

を追加する必要があります。 リーリー

以上です

いいねを押す +0
Peter_Zhu

last_insert_id() は 1 つで、
トリガーも使用できます。 リーリー

大まかに書くと、TeacherCourse には null ではなく、挿入する必要があるものがいくつかあります

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート