- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这个问题混合了几个已经回答的问题,但我无法将所有答案放在一起以使其发挥作用。
我有三张 table :
表 users
:
| user_id | user_name |
表 events
:
| event_id | event_date | event_name |
表 user_event
:
| user_id | event_id |
表 user_event
是前面表中的子表,并将用户与事件相关联(定义到其父表的外键,带有 ON DELETE CASCADE
)。
每个用户都可以添加一个事件,但如果该事件已存在,则不会在表中创建重复 events
,但仍会在 user_event
中插入一行 与 user_id
和现有 event_id
已保存的事件。
如果事件尚不存在,我只需添加一个事件:
INSERT INTO `events` (`event_id`, `event_date`, `event_name`)
SELECT * FROM (SELECT 'event_1', '2014-05-20', 'Meeting') AS tmp
WHERE NOT EXISTS (
SELECT `event_id`, `event_date`, `event_name`
FROM `events`
WHERE `event_name` = 'Meeting'
AND `event_date` = '2014-05-20')
LIMIT 1;
然后我想将其保存到 user_event 表中,以便我知道该用户将参加此事件:
INSERT INTO `user_event` (`user_id`, `event_id`) VALUES ('user_1', 'event_1');
如果它是一个新事件,那没问题,因为我提前知道事件 ID,但如果另一个用户正在创建一个已经存在的事件:
user_2
创建以下事件(与之前插入的相同,但 id 不同):
`event_name` = 'Meeting'
`event_date` = '2014-05-20'
`event_id` = 'event_2'
我想在表中插入user_event
以下条目:
| user_2 | event_1 |
也许可以将这些查询合并到一个用户 SQL 变量中,或者可以通过定义 id = last_insert_id(id)
并在提交第二个查询之前通过 php 检索它,但无法使其工作。
最佳答案
event_id 列是自动递增的吗?
如果您将其放在插入查询的末尾,即使事件中存在重复值,它也会为您提供 php 的 last_insert_id() 值。然后您可以使用它插入用户事件。
ON DUPLICATE KEY UPDATE event_id = LAST_INSERT_ID(event_id)
您必须在 mysql 表中为唯一列 (event_name) 创建一个唯一键才能使其工作。
关于mysql - 如果不存在则添加行,或检索其 id 以供其他查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23680558/
大家好我有一个应用程序可以打开一个包含文本和图像组合的文章的 WebView 。如您所知,文章有不同的字体,我想知道是否有办法让 Web View 呈现几种 Helvetica 字体,就像在安装了这些
我正在寻找一种好的格式来归档旧 Linux 计算机的整个文件系统。 西藏自治区 tar.gz 格式非常适合归档具有 UNIX 样式属性的文件,但由于压缩应用于整个归档,因此设计排除了随机访问。相反,如
我最近一直在苦苦挣扎,因为我不得不更改我不久前编写的一些代码以在 Qt 中进行图像处理和 OpenGl以支持多线程。 问题是我想用它在一组图像上应用批量过滤器, 我正在使用 openMP 来做这样的多
我已成功将两个实际设备连接到 Azure IoTHub(在同一个 IoT 中心),并希望第二个设备接收第一个设备发送的消息。因此,在普通的 MQTT 代理中,第二个设备仅订阅该主题,但 Azure没有
我需要一些 Jenkins 作业才能通过 ssh 通过 shell 命令行访问其他一些机器。 我该怎么做? 我没有目标服务器的密码,但我有一个“ key ”文件,但是当我使用以下命令运行作业时 ssh
我在 Mac OSX Mavericks 上使用 MAMP。我想安装最新的 XDebug v2.2.4。根据 XDebug 向导,我下载了 XDebug 2.2.4 源代码。我的系统上安装了许多版本的
所以我正在制作一个程序,从用户给定的 AZ Lyrics 歌曲中提取歌词。我遇到的问题是,在将字符串转换为 URL 后,它说 Jsoup 无法解析它,因为它不接受字符串,尽管变量是我们传入的 URL。
我已经安装了 AWS .NET SDK通过 MSI 安装程序。我想使用这段代码: static IAmazonS3 client; client = new AmazonS3Client(Amazon
我正在使用 cURL 检索另一个页面,除非我有特定的 cookie,否则我看不到页面内容。 cookie 名称是 seepage,它的值必须设置为 1 才能让我看到页面内容。 我想使用 cURL 加载
目录 1、VLC代码封装 1.1 QT(C++)工程 1.2static 声明 m_instance 优化效率 1.3封装 DLL
我是 Docker 新手,但有一个 Java Web 应用程序项目,我的 Maven 构建会为其生成并安装 Docker 镜像。即 mvn clean install 产品: REPOSITORY
我正在尝试在 Debian Stretch 上做一个带有 uinput 的虚拟键盘,我可以输入字符串,比如“Toto!”,键盘会写入这个字符串。但是,我一直坚持从 C char 到键盘处理的键码的转换
我们正在 Rails 中开发一个 JSON REST API,供我们也在开发的 Android 应用程序使用。有什么方法可以保护 API,使其只能由我们特定的 Android 应用程序使用? API
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
所以我有一个问题,我有 2 个应用程序部署在具有不同端口的同一网站上,一个是登录应用程序,一个是HRIS 系统。 我的问题是,当我的登录应用程序创建 token 时并重定向到我的 hris 系统,hr
在给出的第三段代码的上下文中交谈 on this page , 有一个方法 Messenger named getBinder()返回 the IBinder Messenger 用于与 associ
我目前有一个私有(private) Java 项目,我正在尝试将其完善以供其他开发人员使用。我想做的一件事是让 Ant 自己下载 JUnit、PMD 和 FindBugs 等所需的 JAR,这样开发人
我想在 Qt 中使用 ffmpeg 库进行编程。 如何在 Windows 上将 ffmpeg 编译成 *.lib 文件? 或 如何使用Qt官方发布的编译后的*.dll文件? 还有,哪种方式比较好? 最
我正在为扩展 std::vector 实例化的 C++ 类开发 Python 绑定(bind)。为了让 Python 下标运算符为此类工作,我添加了如下所示的 __getitem__ 函数(我删除了不
我正在为 Amazon SWF 的相当简单的工作流程编写 PHP。我发现自己开始编写一个库来检查某些操作是否已经开始或完成。基本上遍历事件列表以检查事情的进展情况,然后在需要时启动适当的事件。有时这可
我是一名优秀的程序员,十分优秀!