草庐IT

return-statements

全部标签

mysql - 是否有可能用 return 之类的东西突破 mysql 存储过程?

在MySQL中是否存在与存储过程中的MSSQL的RETURN语句等效的语句? 最佳答案 您可能正在寻找LEAVE声明--向下滚动到用户的评论以获取使用示例。 关于mysql-是否有可能用return之类的东西突破mysql存储过程?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/958709/

mysql - 如果 "Subquery returns more than 1 row"认为它是 NULL

我正在尝试将新表上的商店ID与此处主表中的ID同步:UPDATEnewtabletSETt.store_id=(SELECTstore_idFROMmaintablesWHEREt.state=s.stateANDs.city=t.cityANDt.name=s.name)每当子查询返回多于一行时,它就会出错并显示“子查询返回多于1行”,但是当它返回零行时,子查询被认为没有返回任何内容,因此newtable上的store_id保持为NULL。这里没有什么新东西,这就是它的工作原理。我想知道是否有可能让子查询在有多个匹配行时输出与没有匹配时相同的输出。这样一来,我将只为主表上的一个匹配行

php - "No data supplied for parameters in prepared statement"

所以我正在重新编写一个脚本以包含准备好的语句。之前它工作正常,但现在我在脚本运行时收到“没有为准备好的语句中的参数提供数据”。这里有什么问题?error;$result=mysqli_query($mysqli,$stmt);if($result===false){echo"Errorenteringdata!";echomysqli_error($mysqli);}else{echo"User$firstnameadded";}?>提前致谢。 最佳答案 您只通过控制字符串“sssd”绑定(bind)了四个参数,但您有很多参数。my

php - Mysql PDO 中 "RETURNING"子句的语法

我正在尝试添加一条记录,同时返回添加的那条记录的ID。我读到可以使用RETURNING子句来实现。$stmt->prepare("INSERTINTOtablename(field1,field2)VALUES(:value1,:value2)RETURNINGid");但是当我添加RETURNING时插入失败。在要添加到的表中有一个名为id的auto-incremented字段。有人能看出我的语法有什么问题吗?或者PDO可能不支持RETURNING? 最佳答案 我觉得跟PDO支持不支持没有关系。RETURNING受Oracle和P

php - PDO/prep statement/whitelisting/set charset,是否足够安全以防止注入(inject)

我正在从扩展mysql转换为PDO,在阅读了SO和其他地方的各位大师的所有资料后,我还有一些疑虑。我想出了以下内容来解决典型查询的sql注入(inject)问题。我只是想知道这是否足够,或者在我将其复制到我的所有应用程序之前,我可能对白名单有点过头了。我不清楚我是否正确地加入了白名单,即我是否也应该以某种方式逃脱。此外,我不确定是否应该为每个查询模拟setAttribute为false还是只为脚本模拟一次。$link=newPDO("mysql:host=$hostname;dbname=$database;charset=utf8",$username,$password);$lin

mysql - 使用 MYSQL : Raw query returns a "duplicate" result 进行 Sequelize

我有这个执行原始查询的方法:Friendship.getFriends=async(userId)=>{constresult=awaitsequelize.query(`selectid,emailfromuserswhereusers.idin(SELECTfriendIdFROMfriendshipswherefriendships.userId=${userId})`);returnresult;};结果似乎包含完全相同的数据,但是两次:[[TextRow{id:6,email:'example3@gmail.com'},TextRow{id:1,email:'yoyo@gma

php - PDO : Error not caught when executing prepared statement 故障排除

这个问题在这里已经有了答案:WhydoesthisPDOstatementsilentlyfail?(1个回答)关闭1年前。我在使用PDO时遇到了问题,因为没有捕获到错误。代码很简单并且工作得很好,我将包含一个示例以避免混淆:$sql='INSERTINTOsomedatetable(something)VALUES(:something)ONDUPLICATEKEYUPDATEsomething=:something';$values=array(":something"=>$something);try{$stmt=$dbh->prepare($sql);$stmt->execut

java - Statement 中的 executeUpdate(String, int) 方法始终返回 1

谁能告诉我为什么下面的方法(executeUpdate)总是返回1,即使我已指定返回其中生成的key?我想在generatedKey变量中获取生成的key。它适用于使用getGeneratedKeys的PreparedStatement,但我想使用Statement。publicinttestQuery(Connectioncon){intgeneratedKey=0;try{Statementstatement=con.createStatement();generatedKey=statement.executeUpdate("INSERTINTOprofile(fullname)

php - Laravel SQLSTATE[HY000] : General error: 1615 Prepared statement needs to be re-prepared

我最近启动了我的基于Laravel的网站,我没有遇到任何问题,但是40分钟前当我检查它时我得到了这个错误:SQLSTATE[HY000]:Generalerror:1615Preparedstatementneedstobere-prepared(SQL:select*from`users`where`id`=1and`remember_token`=mfjLlbv3fR49TYGAqmUgBSqVVAKmoHhq26ws8rojuXxee5qWcvHrcdoTXs6Wlimit1)为什么会这样?一切都很好,现在突然间我什么也做不了了。 最佳答案

mysql - SQL优化: Four statements into one

我有一个包含一些列的表,其中一个包含我用来运行的时间戳目前有四个单选来计算一个SELECTcount()并返回信息像“超过1周的n行”,“超过2周的n行”,...如何将四个查询转化为一个有望实现的SQL-Statement跑得更快?语句如下所示:SELECTcount(foo_pk)ASoneweekFROMfooWHEREfoo_timstamp 最佳答案 我不是MySql的人,但在SQLServer中我会像这样使用CASE语句:SELECTSUM(CASEWHENfoo_timstamp似乎这个语句在MySql中也可用,所以虽然