AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / user-820

Andomar's questions

Martin Hope
Andomar
Asked: 2015-04-17 12:42:42 +0800 CST

Postgres 9.4 升级后的性能提升

  • 5

昨晚将我们的数据库从 9.3.5 升级到 9.4.1 后,服务器出现了高 CPU 峰值。升级是使用 pg_dump 完成的。于是把数据库转成SQL再导入9.4。

在 CPU 峰值期间,日志中有很多这样的消息:

process X still waiting for ExclusiveLock on extension of relation Y of database Z 
after 1036.234 ms

和:

process X acquired ExclusiveLock on extension of relation Y of database Z
after 2788.050 ms

看起来可疑的是,有时在完全相同的毫秒内有多个“获取”消息用于完全相同的关系号。

为什么 Postgres 会在同一毫秒内将表增长两次?它可能是具有高填充因子的索引吗?

欢迎任何有关如何解决此问题的建议。

PS 我也在Postgres 邮件列表上问过这个问题,如果不妥请告诉我。

postgresql locking
  • 2 个回答
  • 2759 Views
Martin Hope
Andomar
Asked: 2014-12-20 06:50:35 +0800 CST

监控 Postgres 查询解析器

  • 6

据我了解,当您向 Postgres 发送查询时,例如:

SELECT id FROM table1 WHERE name = $1;

Postgres 将创建一个查询计划。该计划将在同一会话中为同一查询缓存。但是如果你创建一个函数:

CREATE OR REPLACE FUNCTION get_table1 (parname text) RETURNS bigint
LANGUAGE plpgsql AS 
$$BEGIN
  RETURN (SELECT id FROM table1 where name = parname);
END$$;

查询计划将被缓存用于所有未来的会话。

我想通过检查查询分析器被调用的频率来验证这个理论。有没有办法检查 Postgres 解析查询的次数?

如果可能的话,我想监控每秒#parses 和 min/max/avg 解析持续时间之类的东西。

postgresql postgresql-9.1
  • 1 个回答
  • 2554 Views
Martin Hope
Andomar
Asked: 2014-09-17 06:20:50 +0800 CST

last_value() 窗口函数究竟做了什么?

  • 6

在测试我对 SQL 的回答时——从每组的第一行和最后一行获取数据,我注意到了一些奇怪的事情。first_value和窗口函数的last_value行为似乎不同。

正如预期的那样,从 的最小值的行中first_value(col1) over (order by col2)找到 的值。但似乎找到了当前行的值。 似乎与它正在操作的组或分区无关。col1col2last_value(col1) over (order by col2)last_value

对于以下查询:

id  Session ID  bal
0   00000002    100
1   00000002    120
2   00000002    140
3   00000001    900
4   00000001    800
5   00000001    500

表达方式:

last_value(bal) over (partition by [Session ID] order by id) as lv

返回不同于以下内容的内容:

first_value(bal) over (partition by [Session ID] order by id DESC) as fv_desc

这是结果(注意lv一组内的变化值):

lv       fv_desc
500      500
800      500
900      500
140      140
120      140
100      140

SQL Fiddle 的示例,带有一些额外的列。 反转order by或省略partition by似乎不会影响last_value()返回的内容。

如果我正确阅读了MSDN 页面,它表明last_value()应该与 的相反first_value(),这与我在测试期间观察到的不同。

做last_value()它应该做的事吗?为什么last_value()允许你指定一个partitionand/ororder by子句,而它似乎也不使用呢?

sql-server window-functions
  • 1 个回答
  • 3923 Views
Martin Hope
Andomar
Asked: 2014-08-03 08:59:47 +0800 CST

为什么新用户可以从任何表中进行选择?

  • 3

当我在 Postgres 中创建用户时,

create user test with password 'test';

用户最终能够连接到实例中的每个数据库。用户还可以从任何表中进行选择:

# psql -h localhost testdb test
Password for user test: *****
psql (8.4.20, server 9.1.13)
WARNING: psql version 8.4, server version 9.1.
         Some psql features might not work.
Type "help" for help.

testdb=> select * from testtable;
 id
------------
      1
(1 row)

\l数据库列表显示testdb有空Access privileges。那么为什么一个新创建的用户可以连接到那个数据库呢?

新创建的“test”用户还可以从表中选择数据。为什么他可以在没有特权的情况grant下这样做?select

我想创建一个只能连接到一个数据库并且只能从某些视图中读取的用户。如何防止用户直接从表中读取?

postgresql postgresql-9.1
  • 2 个回答
  • 5325 Views
Martin Hope
Andomar
Asked: 2013-07-03 10:51:32 +0800 CST

默认跟踪已启用但未激活

  • 9

当我查询默认跟踪的配置时,它显示已启用:

exec sp_configure 'default trace enabled';
-->
name                    minimum  maximum  config_value  run_value
default trace enabled         0        1             1          1

但是当我查询sys.traces路径时,它返回一个空行集:

select * from sys.traces;

什么可以解释没有启用的跟踪?

sql-server sql-server-2008-r2
  • 2 个回答
  • 4557 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目

    • 12 个回答
  • Marko Smith

    如何让sqlplus的输出出现在一行中?

    • 3 个回答
  • Marko Smith

    选择具有最大日期或最晚日期的日期

    • 3 个回答
  • Marko Smith

    如何列出 PostgreSQL 中的所有模式?

    • 4 个回答
  • Marko Smith

    列出指定表的所有列

    • 5 个回答
  • Marko Smith

    如何在不修改我自己的 tnsnames.ora 的情况下使用 sqlplus 连接到位于另一台主机上的 Oracle 数据库

    • 4 个回答
  • Marko Smith

    你如何mysqldump特定的表?

    • 4 个回答
  • Marko Smith

    使用 psql 列出数据库权限

    • 10 个回答
  • Marko Smith

    如何从 PostgreSQL 中的选择查询中将值插入表中?

    • 4 个回答
  • Marko Smith

    如何使用 psql 列出所有数据库和表?

    • 7 个回答
  • Martin Hope
    Jin 连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目 2014-12-02 02:54:58 +0800 CST
  • Martin Hope
    Stéphane 如何列出 PostgreSQL 中的所有模式? 2013-04-16 11:19:16 +0800 CST
  • Martin Hope
    Mike Walsh 为什么事务日志不断增长或空间不足? 2012-12-05 18:11:22 +0800 CST
  • Martin Hope
    Stephane Rolland 列出指定表的所有列 2012-08-14 04:44:44 +0800 CST
  • Martin Hope
    haxney MySQL 能否合理地对数十亿行执行查询? 2012-07-03 11:36:13 +0800 CST
  • Martin Hope
    qazwsx 如何监控大型 .sql 文件的导入进度? 2012-05-03 08:54:41 +0800 CST
  • Martin Hope
    markdorison 你如何mysqldump特定的表? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 对 SQL 查询进行计时? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas 如何从 PostgreSQL 中的选择查询中将值插入表中? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 列出所有数据库和表? 2011-02-18 00:45:49 +0800 CST

热门标签

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve