草庐IT

logically_deleted_y

全部标签

php - mySQL 语句的第一个词不能是 DELETE 或 UPDATE

我目前正在写一个查询数据库的页面,而不是使用命令行(它只是为了练习PHP如何与整个数据库交互)。现在,我正在尝试限制删除或更新数据,即没有DELETE、DROP或UPDATE语句。修剪所有空格(包括\r和\s等)后,仅扫描第一个单词以确定它是什么类型的查询就足够了吗?换句话说,是否可以编写DELETE、DROP或UPDATE查询而不将它们作为修剪空格后的第一个词?我目前正在使用mysqli_query,因此无法执行多个查询。编辑1:添加相关代码@Tim。$queryCheck=strtolower($query);$queryCheck=preg_replace("/\s+/","",

mysql - Google Cloud SQL 是否支持 MySQL 的 ON CASCADE DELETE 功能?

GoogleCloudSQL是否支持MySQL的级联删除功能?我在Google和Google对CloudSQL的支持上搜索了这个,但找不到答案。 最佳答案 是的,是的。你可以自己试试这个,但是,基本上,根据tothedocs:您可以创建第一代或第二代实例。第一代支持MySQL5.5和5.6,第二代支持MySQL5.6或5.7所有这些MySQL版本都已支持thisoperation虽然两代CloudSQL实例都存在一些限制,但它们确实支持此功能。 关于mysql-GoogleCloudSQ

mysql - 转mysql select to delete statement - 我怎么办?

这个问题在这里已经有了答案:HowtoturnthisMySQLSELECTqueryintoaDELETEquery?(6个答案)关闭8年前。我只想从一个表中删除,但我必须根据相关表中的条件进行选择。我之前在此处找到的示例讨论了从一张表中删除的内容。如何将下面的select变成delete语句?selectr.id,r.reminder_date,c.full_name,c.companyfromremindersrleftjoinclientsconr.client_id=c.idwhere(c.full_nameisnullorc.full_name="")AND(c.compa

mysql - DELETing w/Using 时限制删除的记录

我通过将多个列移动到它们自己的表并改用外键来规范化数据库。我正在尝试更新应用程序中的查询以尽可能使用联接。在删除数据的查询中,我不希望查找键值而只是运行带有连接的删除。我发现唯一可行的方法是将USING添加到查询中-但这会破坏我对LIMIT子句的使用。DELETEFROMprism_dataUSINGprism_dataINNERJOINprism_playerspONp.player_id=prism_data.player_idINNERJOINprism_actionsaONa.action_id=prism_data.action_idWHERE(a.action='water

mysql - 为什么我们在多个删除中的 'DELETE' 之后提供别名

这可能是一个非常愚蠢的问题,但我很想知道是否有人有任何建议:单表删除正确查询:deletefromvehicle_ownerwhereid=3;单表删除错误查询:deletefromvehicle_ownervwherev.id=3多表删除:删除v,sfromvehiclev,categoryswherev.id=3andv.id=s.id;问题1:我想知道为什么第一个是正确的,为什么第二个是不正确的。基本上我正在寻找逻辑答案,这解释了为什么在删除查询中提供别名是不正确的。问题2:为什么我们在'DELETE'关键字后保留两个别名用于多次删除。无论如何,我们在加入条件中提供了完整的细节。

mysql - Rails 3 - delete_all 不支持限制范围,而 MySQL 支持它

我有一个包含900万条记录的表。我定期将此数据同步到第三方。我保留了一个列,告诉特定行是否已经同步。现在我需要删除将近600万同步行,我不确定是否运行Model.where(:sync_flag=>true).delete_all会是个好主意。每秒有数百次插入,我认为这可能会导致以一种会伤害/阻止插入的方式锁定表(这里需要MySQL专家来纠正)有了上面的序言,我想到了在循环中使用一个带有limit子句的delete来删除所有的记录,直到没有留下,但是有以下内容Model.where(:sync_flag=>true).limit(5000).delete_all它引发了一个异常dele

mysql - 完全奇怪 : deleting a MySQL user allows me to still login as that user with an empty password

在ArchLinux上使用MySQL5.5,当我创建一个带密码的localhost用户并赋予它对所有表的所有权限然后删除该用户时,我仍然可以以该用户身份登录而无需输入密码。重现步骤:#mysql-uroot-hlocalhost-pEnterpassword:mysql>createuser'test'@'localhost'identifiedby'testing123';mysql>grantallon*.*to'test'@'localhost'identifiedby'testing123';mysql>select*frommysql.userwhereuser='test'

mysql - SQL DELETE 从多个表

当我尝试执行这个删除查询时,SQL给我这个错误:“无法删除或更新父行:外键约束失败(carpooling.pedido,CONSTRAINTpedido_ibfk_1FOREIGNKEY(ID_ROTA)引用rota(ID_ROTA))"查询:DELETErota,rota_alerta,pedidoFROMrotaLEFTOUTERJOINpedidoONrota.ID_ROTA=pedido.ID_ROTALEFTOUTERJOINrota_alertaONrota.ID_ROTA=rota_alerta.ID_ROTAWHERErota.ID_UTILIZADOR=26;我正在尝

mysql - 有人可以帮助我理解外键 UPDATE 和 DELETE 与关系名称吗?

目前,我正在研究MySQLInnoDB中的用户数据库。因此,我将使用它来帮助演示。UsersRoles------------------------------userid(bigint)PK>roleid(tinyint)PKemail(varchar)rolename(varchar)username(varchar)password(char)>roleid(tinyint)FKcreated(timestamp)现在,我正在尝试基于roleid在Role和Users之间创建一对多关系。为此,我在考虑OnUPDATECASCADE和OnDELETERestrict。这就是我觉得

mysql - 我不能在 sql delete 中使用别名

我试过执行这个sql语句deletefromreclamorwhereexists(select1fromreclamorjoinclienteconr.cod_cliente=c.cod_clientejoinlocalidadlonc.cod_localidad=l.cod_localidadwherel.descripcion='SanJusto');删除'Sanjusto'镇的客户提出的所有claim但它显示“错误代码:1064。您的SQL语法有错误;请查看与您的MySQL服务器版本对应的手册,了解在'r附近使用的正确语法哪里存在(从reclamor中选择1在第2行加入r.co