返回顶部
首页 > 资讯 > 精选 >sql中如何查看delete的数据
  • 783
分享到

sql中如何查看delete的数据

2023-06-06 02:06:02 783人浏览 泡泡鱼
摘要

这篇文章主要介绍sql中如何查看delete的数据,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!测试数据,在进行删除delete的时候有索引和没有索引的对象的统计信息,会话的统计信息,会话的等待事件dele

这篇文章主要介绍sql中如何查看delete的数据,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

测试数据,在进行删除delete的时候有索引和没有索引的对象的统计信息,会话的统计信息,会话的等待事件

delete test_a
删除耗费491秒
select c.sid,b.NAME,a.VALUE from v$sesstat a ,v$statname b ,(select SID from v$mystat where rownum<=1) c
   where a.SID=c.sid and a.STATISTIC#=b.STATISTIC# and (b.NAME like 'physical%' or b.name like '%read%' or B.NAME like   '%undo%' or b.name like '%redo%') and a.VALUE<>0 ;
 
       SID NAME                                                                  VALUE
---------- ---------------------------------------------------------------- ----------
       318 session logical reads                                               4202712 ---实际行数400W
       318 physical read total IO requests                                        1142
       318 physical read total multi block requests                               1117
       318 physical read total bytes                                         145031168
       318 physical reads                                                        17704 --表块的数量
       318 physical reads cache                                                  17704
       318 physical read IO requests                                              1142
       318 physical read bytes                                               145031168 ---delete这里会物理读取实际的大小140M,而后面的等待事件说明在这里小号了43秒
       318 redo synch writes                                                         1
       318 physical reads cache prefetch                                         16562
       318 redo entries                                                        4017828
       318 redo size                                                        1141494072 --任然的REDO生成了1G,和INSERT差不多
       318 redo buffer allocation retries                                           49
       318 redo log space requests                                                  49
       318 redo log space wait time                                                296
       318 redo ordering marks                                                   73945
       318 redo subscn max counts                                                74118
       318 undo change vector size                                           589435236 --undo生成了580M,比INSERT更多
       318 no work - consistent read gets                                        17906
       318 IMU undo allocation size                                              63992


  select *
          from v$session_event a
        where a.SID = 318
      order by TIME_WAITED desc;
 
       SID EVENT                             TIME_WAITED_MICRO
---------- ---------------------------------------------------
       318 SQL*Net message from client               206690838
       318 db file scattered read                     43843361 --43秒
       318 log file switch completion                  2952901
       318 db file sequential read                      188312
       318 log buffer space                              28325
       318 SQL*Net message to client                        89
 
 
SQL> select * from v$sess_time_model where sid=318 order by  value desc;
 
       SID    STAT_ID STAT_NAME                                                             VALUE
---------- ---------- ---------------------------------------------------------------- ----------
       318 3649082374 DB time                                                           491842941
       318 2821698184 sql execute elapsed time                                          491750449
       318 2748282437 DB CPU                                                            436421084 --等待比INSERT相比增加了
       318 1431595225 parse time elapsed                                                   405367
       318  372226525 hard parse elapsed time                                              396096
       318 1990024365 connection management call elapsed time                               28152
       318 1311180441 PL/SQL compilation elapsed time                                        3400
       318 2643905994 PL/SQL execution elapsed time                                           646
       318 1159091985 repeated bind elapsed time                                              319


会话315
delete test_b;

耗时1100多秒
SQL> select c.sid,b.NAME,a.VALUE from v$sesstat a ,v$statname b ,(select SID from v$mystat where rownum<=1) c
  2     where a.SID=c.sid and a.STATISTIC#=b.STATISTIC# and (b.NAME like 'physical%' or b.name like '%read%' or B.NAME like   '%undo%' or b.name like '%redo%') and a.VALUE<>0 ;
 
       SID NAME                                                                  VALUE
---------- ---------------------------------------------------------------- ----------
       315 session logical reads                                              16309976   --逻辑读是实际行数的4倍,包含表本生的读取,还有索引读取
       315 physical read total IO requests                                        9501
       315 physical read total multi block requests                               1101
       315 physical read total bytes                                         211697664
       315 physical reads                                                        25842 --物理块 索引+表
       315 physical reads cache                                                  25842
       315 physical read IO requests                                              9501
       315 physical read bytes                                               211697664 --- 这里基本是表144M+72m索引的大小
       315 redo synch writes                                                         1
       315 physical reads cache prefetch                                         16341
       315 redo entries                                                        8036150
       315 redo size                                                        1959456476 ---2G
       315 redo buffer allocation retries                                           85
       315 redo log space requests                                                  87
       315 redo log space wait time                                                595
       315 redo ordering marks                                                  116447
       315 redo subscn max counts                                               125117
       315 undo change vector size                                           922274632 --900M
       315 no work - consistent read gets                                        18761
      
 SQL>  select *
  2            from v$session_event a
  3          where a.SID = 315
  4        order by TIME_WAITED desc;
 
       SID EVENT                          TIME_WAITED_MICRO
---------- ------------------------------------------------ ---------------------------------------------
       315 SQL*Net message from client            317688133
       315 db file sequential read                131743590  ---131秒(索引的读取)
       315 db file scattered read                  34265605  --34秒
       315 log file switch completion               6006692
       315 events in waitclass Other                  58204
       315 SQL*Net message to client                     65
 
SQL> select * from v$sess_time_model where sid=315 order by  value desc;
 
       SID    STAT_ID STAT_NAME                                                             VALUE
---------- ---------- ---------------------------------------------------------------- ----------
       315 3649082374 DB time                                                          1068676495
       315 2821698184 sql execute elapsed time                                         1068593627
       315 2748282437 DB CPU                                                            886348292
       315 1431595225 parse time elapsed                                                   129178
       315  372226525 hard parse elapsed time                                              112666
       315 1311180441 PL/SQL compilation elapsed time                                       25308
       315 1990024365 connection management call elapsed time                               21365
       315 2643905994 PL/SQL execution elapsed time                                          3872
       315 1159091985 repeated bind elapsed time                                              518
      
实际上对比INSERT,DELETE语句实际上多在对表和索引的读取环节,LOG生成量差不多,UNDO delete更多,
但是基本上多一个索引时间会*2,所以对于大量的数据删除,和平凡的INSERT不适合建立索引,
但是如果只是DELETE TABLE WHERE ID=1这样的操作比较多,那么索引可以提高读取表的速度,这样可以不使用
全表扫描而使用索引扫描,要快很多。所以还是要区别对待。

以上是“sql中如何查看delete的数据”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

--结束END--

本文标题: sql中如何查看delete的数据

本文链接: https://lsjlt.com/news/245732.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • sql中如何查看delete的数据
    这篇文章主要介绍sql中如何查看delete的数据,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!测试数据,在进行删除delete的时候有索引和没有索引的对象的统计信息,会话的统计信息,会话的等待事件dele...
    99+
    2023-06-06
  • SQL如何查看数据库中的表
    在SQL中,可以使用以下命令来查看数据库中的表: SHOW TABLES; 或者 SELECT table_name F...
    99+
    2024-03-07
    SQL 数据库
  • sql数据库如何查看表数据
    要查看SQL数据库中的表数据,您可以使用SELECT语句。以下是一个简单的示例: SELECT * FROM table_n...
    99+
    2024-05-06
    sql
  • 数据库中如何查看当前的活动SQL
    这篇文章主要为大家展示了“数据库中如何查看当前的活动SQL”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“数据库中如何查看当前的活动SQL”这篇文章吧。 ...
    99+
    2024-04-02
  • sql如何查看表中字段数据类型
    要查看表中字段数据类型,可以使用SQL的DESCRIBE或者SHOW命令。例如,可以使用以下命令查看表中所有字段的数据类型: DES...
    99+
    2024-04-09
    sql
  • SQL Server如何查看表的数据内容
    SQL Server数据库管理工具查询表数据需要输入sql语句。 打开SQL Server 2008; 在左侧的对象资源器选中需要查询的mssql数据库,点击菜单栏”新建查询”;    3、在新打开的窗口输入查询语句,点击执行。  来源...
    99+
    2023-09-03
    数据库 sql mysql
  • sql数据库如何查看表内容
    要查看表的内容,可以使用SELECT语句查询表中的数据。以下是一个基本的SELECT语句的示例:```sqlSELECT *...
    99+
    2023-10-08
    sql数据库
  • 如何查看redis中的数据
    如何查看 redis 中的数据 Redis 是一款键值数据库,存储的数据以键值对的形式存在。要查看 Redis 中的数据,有多种方法: 1. 使用 Redis 客户端 Redis 命令行...
    99+
    2024-06-12
    python redis 键值对
  • 如何查看sql数据库的存储位置
    要查看SQL数据库的存储位置,可以执行以下步骤:1. 打开SQL Server Management Studio(SSMS)或其他...
    99+
    2023-09-22
    sql数据库
  • sql怎么查看数据库中的表
    要查看数据库中的表,您可以使用 SQL 查询来检索数据库中的表信息。以下是常见的两种方法: 使用 SHOW TABLES; 查询:...
    99+
    2024-03-02
    sql 数据库
  • sql数据库如何查看字段类型
    在SQL数据库中,可以使用DESCRIBE或者SHOW命令来查看表中的字段类型。 例如,可以使用以下命令来查看名为"tab...
    99+
    2024-04-02
  • java中如何查看数据的类型
    在Java中,可以通过使用getClass()方法或instanceof关键字来查看数据的类型。 使用getClass()方法: ...
    99+
    2024-03-04
    java
  • db2如何查看数据库中的表
    您可以使用以下命令来查看数据库中的表: 使用命令行界面连接到数据库: db2 connect to your_database_...
    99+
    2024-04-02
  • redis如何查看数据
    查看redis数据的方法主要取决于数据类型:字符串类型:get、strlen列表类型:lrange、lindex、llen哈希类型:hget、hgetall、hlen集合类型:smemb...
    99+
    2024-04-20
    redis 键值对
  • hbase中如何查看表数据量
    要查看HBase表的数据量,可以使用HBase Shell或HBase API来执行计数操作。以下是几种方法: 使用HBase S...
    99+
    2024-04-02
  • 如何查看oracle的数据库
    要查看Oracle数据库,可以使用SQL*Plus或SQL Developer等工具。以下是在这两个工具中查看Oracle数据库的步...
    99+
    2023-08-22
    oracle
  • 如何查看redis里的数据
    要查看Redis中的数据,可以使用以下几种方法: 使用Redis命令行客户端工具:可以通过在终端中输入redis-cli命令来启...
    99+
    2024-04-09
    redis
  • 怎么查看sql数据字典
    SQL数据字典是一种用来描述数据库结构、表、列以及其它相关信息的元数据集合。通常,数据库管理系统会存储这些信息,并提供一些内置的系统...
    99+
    2024-04-09
    sql
  • 如何查看oracle数据库
    要查看Oracle数据库,可以使用以下方法之一:1. 使用SQL*Plus命令行工具:SQL*Plus是Oracle提供的一个基本的...
    99+
    2023-08-30
    oracle
  • linux如何查看mongodb数据
    要查看MongoDB数据,您可以使用MongoDB提供的命令行工具或者图形界面管理工具。使用命令行工具:1. 打开终端或命令提示符窗...
    99+
    2023-09-04
    mongodb linux
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作