首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    从trc查找死锁的问题

    *** 2013-09-29 01:03:47.762 *** SERVICE NAME:(SYS$USERS) 2013-09-29 01:03:47.744 *** SESSION ID:(997.178) 2013-09-29 01:03:47.744 DEADLOCK DETECTED ( ORA-00060 ) [Transaction Deadlock] The following deadlock is not an ORACLE error. It is a deadlock due to user error in the design of an application or from issuing incorrect ad-hoc SQL. The following information may aid in determining the deadlock: Deadlock graph:                        ---------Blocker(s)--------  ---------Waiter(s)--------- Resource Name          process session holds waits  process session holds waits TX-005d002f-000046dd       113     997     X            182     786           X TX-004d0026-00009b4e       182     786     X            113     997           X session 997: DID 0001-0071-00000006 session 786: DID 0001-00B6-0000064E session 786: DID 0001-00B6-0000064E session 997: DID 0001-0071-00000006 Rows waited on: Session 786: obj - rowid = 0002D33A - AAAtM6AAdAAAJ9BABO   (dictionary objn - 185146, file - 29, block - 40769, slot - 78) Session 997: obj - rowid = 000527D6 - AABSfWAAdAACmKAAAe   (dictionary objn - 337878, file - 29, block - 680576, slot - 30) Information on the OTHER waiting sessions: Session 786:   pid=182 serial=10783 audsid=64898626 user: 96/GALT   O/S info: user: batch, term: , ospid: 23674, machine: v490c1-app             program: sqlplus@v490c1-app (TNS V1-V3)   application name: SQL*Plus, hash value=3669949024   Current SQL Statement:   DELETE FROM ANA A WHERE EXISTS (SELECT 1 FROM (SELECT LOCATOR_ID FROM (SELECT T.LOCATOR_ID,ROWNUM RN FROM TEMP T ) WHERE RN > :B2 AND RN <= :B1 ) B WHERE A.LOCATOR_ID = B.LOCATOR_ID) End of information on OTHER waiting sessions. Current SQL statement for this session: update ana_seg set    SEGMENT_ID = :1, SEAT_STATUS = :2, SEGMENT_CLASS = :3, SEGMENT_SHARE_CLASS = :4, SEG_SEAT_NO = :5, SEG_CREATION_NUM= :6, SEG_CREATION_TIME = :7 where locator_id = :8 and SEG_ORDER_ID = :9

    02

    MySQL数据库:第八章:连接查询

    理解:查询语句中涉及到的字段来自于多张表,将这种查询称为多表连接查询 语法:select 查询列表 from 表名1,表名2; 引入案例: select name,boyname from beauty,boys; select name,boyname from beauty,boys where boyfriend_id = boys.id; 笛卡尔乘积: 现象:表1和表2连接,结果为两表的完全连接结果,数据不正确 表1m行,表2 n行,结果为:m*n 行 产生原因:没有有效的连接条件 解决办法:添加两个表的连接条件 ★ 找到两个表的关联关系。两个表的关联列的意思肯定是一样,但名称不一定一样!一般通过主外键列进行关联。 连接查询的分类 ★: sql92语法: 内连接 等值连接 非等值连接 自连接 外连接(支持的不太好,mysql压根不支持) sql99语法: 内连接 等值连接 非等值连接 自连接 外连接 左外连接 右外连接 全外连接(mysql不支持)

    03

    《数据库索引设计优化》读书笔记(五)

    分析: A为父表,B为子表,两个表做主外键关联查询,只有主键和外键上有索引,并且A表的主键索引和B表的外键索引为聚簇索引。 以A作为外层表做嵌套循环连接计算响应时间: 第1步:通过聚簇索引AK访问A表 索引 AK TR = 1 TS = 10000000 LTR 1 * 10ms + 10000000 * 0.01ms = 100s 第2步:通过聚簇索引AK访问B表 索引 AK TR = 10000000 * 1% = 100000 TS = 100000 * 5 = 500000 LTR 100000 * 10ms + 100000 * 5 * 0.01ms = 1005s 第3步:提取数据 50000000 * 1% * 0.001% * 0.1ms = 0.5ms 所以以A作为外层表做嵌套循环连接响应时间约为1105(100 + 1005)秒 以B作为外层表做嵌套循环连接计算响应时间: 第1步:通过聚簇索引AK访问B表 索引 AK TR = 1 TS = 50000000 LTR 1 * 10ms + 50000000 * 0.01ms = 500s 第2步:通过聚簇索引AK访问A表 索引 AK TR = 50000000 * 0.001% = 500 TS = 500 LTR 500 * 10ms + 500 * 0.01ms = 5s 第3步:提取数据 50000000 * 1% * 0.001% * 0.1ms = 0.5ms 所以以B作为外层表做嵌套循环连接响应时间约为505(500 + 5)秒 8.2 在不添加冗余字段的前提下,为该连接设计最佳索引并评估响应时间。 分析: 因为B1 > :B1的FF很小,仅为0.001%,所以可以建立以B1为前缀的宽索引(B1,AK,B2) 以B作为外层表做嵌套循环连接计算响应时间: 第1步:通过索引B1访问B表,因为B1是宽索引,所以无需回表访问 索引 B1 TR = 1 TS = 50000000 * 0.001% = 500 LTR 1 * 10ms + 500 * 0.01ms = 15ms 第2步:通过聚簇索引AK访问A表 索引 AK TR = 500 TS = 500 LTR 500 * 10ms + 500 * 0.01ms = 5005ms 第3步:提取数据 50000000 * 1% * 0.001% * 0.1ms = 0.5ms 所以使用B1上的宽索引(B1,AK,B2),以B作为外层表做嵌套循环连接响应时间约为5((15+5005+0.5)/1000)秒。

    02

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券