Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/57.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 查找mysql查询是执行更新还是插入_Java_Mysql - Fatal编程技术网

Java 查找mysql查询是执行更新还是插入

Java 查找mysql查询是执行更新还是插入,java,mysql,Java,Mysql,我有一个疑问如下 INSERT INTO MYTABLE (f1,f2,f3,f4) VALUES (1,2,3,4) ON DUPLICATE KEY UPDATE f4=5; 我通过 创建连接、语句和执行查询,如下所示 statement.execute(query); 但是,现在我需要找出代码是否执行了插入或更新 有人能帮我吗 提前感谢…您可以使用两条语句:executeUpdate返回受影响的行数。如果该数字为0,则必须执行插入。我不知道任何特定的内置函数或解决方法

我有一个疑问如下

    INSERT INTO MYTABLE (f1,f2,f3,f4) VALUES (1,2,3,4) ON DUPLICATE KEY UPDATE f4=5;
我通过

创建连接、语句和执行查询,如下所示

    statement.execute(query);
但是,现在我需要找出代码是否执行了插入或更新

有人能帮我吗


提前感谢…

您可以使用两条语句:
executeUpdate
返回受影响的行数。如果该数字为0,则必须执行插入。

我不知道任何特定的内置函数或解决方法

但在我的情况下,我会以一种简单的方式使它成为可能

select count(*) as oldcount from MYTABLE;
在此级别执行查询

INSERT INTO MYTABLE (f1,f2,f3,f4) VALUES (1,2,3,4) ON DUPLICATE KEY UPDATE f4=5;

select count(*) as newCount from MYTABLE;

retrive OLDCOUNT and NEW COUNT

if(oldcount != new count)
{
  //InsertPerformed
}

else
{
  //updateperformed
}

在With ON DUPLICATE KEY UPDATE中,如果将行作为新行插入,则每行受影响的行数值为1,如果更新现有行,则每行受影响的行数值为2。是的,但execute()方法仅返回布尔值:没有sridhar想要知道的信息。如果查询是
删除操作,该怎么办?它不是也返回0吗?因为在文档中,
executeUpdate()
方法返回Yes,他还需要从execute()切换到executeUpdate()。。。但我不想使用对DB的后续调用。因为上面的示例使用了3个对DB的调用。我将上传至少2000行到最多100000行。因此,我认为这是不可行的(对我的问题)。再次感谢:)