mysql – 复合主键和Auto_Increment
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql – 复合主键和Auto_Increment,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1319字,纯文字阅读大概需要2分钟。
内容图文
![mysql – 复合主键和Auto_Increment](/upload/InfoBanner/zyjiaocheng/904/8a8148634b9748d1a99408bb831659f3.jpg)
参见英文答案 > mysql two column primary key with auto-increment 4个
我正在尝试使用其中一个自动递增来执行复合键,但是当我尝试输入新行时,它只是继续顺序.
以下是发生的事情的例子:
Item_1 | Item_2
1 | 1
1 | 2
2 | 3
2 | 4
2 | 5
这是我想要的例子:
Item_1 | Item_2
1 | 1
1 | 2
2 | 1
2 | 2
2 | 3
我这样创建表:
CREATE TABLE IF NOT EXISTS `usuarios` (
`cod_user` int(11) NOT NULL AUTO_INCREMENT,
`cod_user_emp` int(11) NOT NULL,
PRIMARY KEY (`cod_user`,`cod_user_emp`),
UNIQUE KEY `user` (`user`),
KEY `cod_user` (`cod_user`)
);
编辑
我解决了服务器端php验证的问题.
$result = $db->query("SELECT * FROM usuarios WHERE cod_user_emp=\"$emp\" ORDER BY cod_user DESC LIMIT 1");
while($row=$result->fetch_array()){
$cod2 = $row['cod_user']+1;
}
解决方法:
删除该AUTO_INCREMENT列,
CREATE TABLE IF NOT EXISTS `usuarios`
(
`cod_user` int(11) NOT NULL,
`cod_user_emp` int(11) NOT NULL,
PRIMARY KEY (`cod_user`,`cod_user_emp`) -- <<== this is enough
);
并且可以创建一个存储过程,为每个Item_1增加Item_2.
DELIMITER $$
CREATE PROCEDURE InsertRecord(IN ItemA INT)
BEGIN
SET @max_id = (
SELECT COALESCE(MAX(Item_2), 0) + 1
FROM TableName
WHERE Item_1 = ItemA
);
INSERT INTO tableName(Item_1, Item_2)
VALUES(ItemA, @max_id)
END $$
DELIMITER ;
并称之为,
CALL InsertRecord(2);
内容总结
以上是互联网集市为您收集整理的mysql – 复合主键和Auto_Increment全部内容,希望文章能够帮你解决mysql – 复合主键和Auto_Increment所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。