删除该sql筛选出的数据 select * FROM t_project_management_user WHERE t_project_management_user.id NOT IN ( SELECT MIN(id) FROM t_project_management_user tpmu GROUP BY tpmu.overhaul_id );
时间: 2024-02-04 11:02:13 浏览: 78
你可以使用以下 SQL 语句删除该筛选出的数据:
```
DELETE FROM t_project_management_user
WHERE t_project_management_user.id NOT IN (
SELECT MIN(id)
FROM t_project_management_user tpmu
GROUP BY tpmu.overhaul_id
);
```
注意,在执行这个 SQL 语句之前,请先备份你的数据以避免不必要的损失。
相关问题
--#建立存储过程,把数据导入到相应的表中 --execute add_data '面向对象系统分析与设计实验信计201','面向对象系统分析与设计实验信计201','101001' create proc add_data @course_id varchar(200),@table_name varchar(200),@teacher_id varchar(200) as if exists(select * from syscursors where cursor_name='prj_Cursor') deallocate prj_Cursor declare @str_sql varchar(1024); declare @num int; SELECT @num=count(NAME)-3 FROM SYSCOLUMNS WHERE ID=OBJECT_ID(@table_name); set @str_sql=CONCAT('insert into tb_Course(course_id,course_name,num_of_project,table_name,teacher_id)values(', '''', @course_id, ''',', '''', left(@course_id,len(@course_id)-3), ''',', cast(@num as varchar), ',''', @table_name, ''',''', @teacher_id, ''')'); print @str_sql EXEC(@str_sql)--课程信息插入到tb_Course DECLARE prj_Cursor SCROLL CURSOR for SELECT NAME FROM sys.columns WHERE [object_id]=OBJECT_ID(@table_name) order by column_id; OPEN prj_Cursor declare @prj varchar(128) FETCH ABSOLUTE 4 FROM prj_Cursor into @prj while (@@fetch_status=0) begin--把实验项目加入到tb_Project表 print(@prj) set @str_sql='insert into tb_Project(project_id,project_name,course_id,project_open) values('''+ right(@course_id,3)+@prj+''','+ ''''+@prj+''','''+@course_id+''','+'0'+')' print @str_sql EXEC(@str_sql)--项目信息插入到tb_Project FETCH next FROM prj_Cursor into @prj end set @str_sql=CONCAT('insert into tb_User(user_name,user_password,full_name) select ', 'SNO', ',substring(sys.fn_sqlvarbasetostr(HASHBYTES(''MD5'',','SNO)),3,32),Sname', ' from ', @table_name, ' where SNO not in(select user_name from tb_User)' ); --如果字段的类型是nvarchar的,md5加密前需要强制转化一下类型CAST([SNO] as varchar(50)) print @str_sql EXEC(@str_sql)--学生账号插入到tb_User set @str_sql='insert into tb_SC(SNO,course_id) select SNO,''' +@course_id+ ''' from '+@table_name print @str_sql EXEC(@str_sql)--选课信息插入到tb_SC go 怎么分段写入SQL
在 SQL Server 中,可以使用 GO 命令将 SQL 脚本分段执行。GO 命令用于将脚本中的多个批次分隔开来,每个批次之间用 GO 分隔符分隔。例如,你可以将存储过程的创建脚本和执行脚本分别放在两个批次中,然后用 GO 分隔符分隔开来,如下所示:
```
-- 创建存储过程
CREATE PROCEDURE add_data
@course_id varchar(200),
@table_name varchar(200),
@teacher_id varchar(200)
AS
BEGIN
-- 存储过程代码
END
GO
-- 执行存储过程
EXEC add_data '面向对象系统分析与设计实验信计201','面向对象系统分析与设计实验信计201','101001'
GO
```
注意,GO 命令不能作为 T-SQL 语句的一部分,它只是 SQL Server Management Studio 和 sqlcmd 工具中的一个批处理命令。在使用 GO 命令时,要确保每个批次的语法都是正确的,否则会导致执行失败。
SQL 错误 [1093] [HY000]: You can't specify target table 't_project_management_user' for update in FROM 这个错的解决
这个错误是因为 MySQL 不允许在 UPDATE 或 DELETE 语句中直接使用被更新或删除的表,可以通过子查询的方式避免这个问题。
举个例子,如果你的 SQL 语句是这样的:
```sql
UPDATE t_project_management_user SET status = 0 WHERE id IN (SELECT user_id FROM t_project_management WHERE project_id = 1);
```
可以改写成这样:
```sql
UPDATE t_project_management_user SET status = 0 WHERE id IN (SELECT user_id FROM (SELECT user_id FROM t_project_management WHERE project_id = 1) AS temp);
```
通过将内部的 SELECT 语句嵌套在另一个 SELECT 语句中,就可以绕过这个限制了。
阅读全文