小编Rom*_*man的帖子

如何检测Postgres中持有锁的查询?

我想不断跟踪postgres中的相互锁定.

我遇到了Locks Monitoring文章并尝试运行以下查询:

SELECT bl.pid     AS blocked_pid,
     a.usename  AS blocked_user,
     kl.pid     AS blocking_pid,
     ka.usename AS blocking_user,
     a.query    AS blocked_statement
FROM  pg_catalog.pg_locks         bl
 JOIN pg_catalog.pg_stat_activity a  ON a.pid = bl.pid
 JOIN pg_catalog.pg_locks         kl ON kl.transactionid = bl.transactionid AND kl.pid != bl.pid
 JOIN pg_catalog.pg_stat_activity ka ON ka.pid = kl.pid
WHERE NOT bl.granted;
Run Code Online (Sandbox Code Playgroud)

不幸的是,它永远不会返回非空结果集.如果我将给定查询简化为以下形式:

SELECT bl.pid     AS blocked_pid,
     a.usename  AS blocked_user,
     a.query    AS blocked_statement
FROM  pg_catalog.pg_locks         bl
 JOIN pg_catalog.pg_stat_activity a  ON a.pid = bl.pid
WHERE NOT bl.granted;
Run Code Online (Sandbox Code Playgroud)

然后它返回等待获取锁的查询.但我无法改变它,以便它可以返回阻止和阻止查询.

有任何想法吗?

sql postgresql locking

40
推荐指数
8
解决办法
6万
查看次数

如何在servlet抛出运行时异常时在浏览器中显示用户友好的错误页面?

我正在使用JSF开发Web应用程序.我测试了它,因为我能够但不时抛出运行时异常.

那么,每次抛出异常时如何将用户重定向到特殊错误页面(而不是显示完整tomcat日志的500错误)?

jsf jsp facelets custom-error-pages

39
推荐指数
2
解决办法
5万
查看次数

Java Executors:如何设置任务优先级?

是否有可能为Executors执行的任务设置优先级?我在JCIP中发现了一些关于它可能的陈述,但我找不到任何例子,我找不到任何与文档相关的内容.

来自JCIP:

执行策略指定任务执行的"内容,位置,时间和方式",包括:

  • ...
  • 应该以什么顺序执行任务(FIFO,LIFO,优先顺序)?
  • ...

UPD:我意识到我不确切地问我想问什么.我真正想要的是:

如何使用/模拟thread.setPriority()执行程序框架设置线程优先级(即什么)?

java concurrency multithreading executor thread-priority

38
推荐指数
2
解决办法
4万
查看次数

如何验证对象是否具有某些属性?

我想使用期望属性的值或指定的默认值.如何在groovy中实现这一目标?

我们来看看这个例子:

def printName(object) {
   //if object has initialized property 'name' - print 'name', otherwise print ToString
   if (object<some code here>name && object.name) {
      print object.name
   } else {
      print object
   }
}
Run Code Online (Sandbox Code Playgroud)

groovy

37
推荐指数
2
解决办法
3万
查看次数

如何配置事务管理以在Spring中使用2个不同的db?

我有2个数据库(MySql和HSQLDB).我配置了2个数据源和2个EntityManagerFactory bean.我还可以配置2个对应的JpaTransactionManager bean.

但我不知道如何指定应该使用哪些来管理具体服务类的事务.我想@Transactional为此目的使用注释,但实际上我只能指定一个txManagers:

<tx:annotation-driven transaction-manager="manager"/>
Run Code Online (Sandbox Code Playgroud)

这种情况的出路是什么?

java spring jpa transactions multiple-databases

35
推荐指数
4
解决办法
4万
查看次数

在persistence.xml和spring配置文件中配置数据源之间的区别

我已经以两种方式看到(并完成了)数据源配置(下面的代码仅用于演示):

1)配置内部持久性单元,如:

<persistence-unit name="LocalDB" transaction-type="RESOURCE_LOCAL">
    <class>domain.User</class>
    <exclude-unlisted-classes>true</exclude-unlisted-classes>
    <properties>
        <property name="hibernate.connection.driver_class" value="org.hsqldb.jdbcDriver"/>
        <property name="hibernate.connection.url" value="jdbc:hsqldb:hsql://localhost"/>
        <property name="hibernate.hbm2ddl.auto" value="create"/>
        <property name="hibernate.c3p0.min_size" value="5"/>
        ....
        <property name="hibernate.dialect" value="org.hibernate.dialect.HSQLDialect"/>
    </properties>
</persistence-unit>
Run Code Online (Sandbox Code Playgroud)

2)配置spring配置文件(如applicationContext.xml):

<bean id="domainEntityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="persistenceUnitName" value="JiraManager"/>
    <property name="dataSource" ref="domainDataSource"/>
    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
            <property name="generateDdl" value="false"/>
            <property name="showSql" value="false"/>
            <property name="databasePlatform" value="${hibernate.dialect}"/>
        </bean>
    </property>
</bean>

<bean id="domainDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
    <property name="driverClass" value="${db.driver}" />
    <property name="jdbcUrl" value="${datasource.url}" />
    <property name="user" value="${datasource.username}" />
    <property name="password" value="${datasource.password}" />
    <property name="initialPoolSize" value="5"/>
    <property name="minPoolSize" value="5"/>
    .....
</bean> …
Run Code Online (Sandbox Code Playgroud)

java spring persistence jpa

34
推荐指数
1
解决办法
3万
查看次数

如何创建智能聊天机器人?

我知道这仍然是一个悬而未决的问题所以我不希望在这里看到完整的答案.我只是想找到一些方法来解决下一个问题:

我有一个模型(假设是机器人的记忆),不同的单词与模型中的不同对象相关联.使用机器人就像使用DB执行sql-queries一样.语言是一种非常难以形式化的协议.我们不能只写一百万行代码来实现一些真正的语言.但我相信实施一些自学机制绝对是可能的.如何实施?是否可以"从头开始"或"从几个基本单词"实施学习?只是想听听你的想法.

实际上,英语是一种非常严格的语言,它是用于试验AI的最简单的语言之一.许多其他语言允许您更改单词的顺序(例如).在某些情况下,改变顺序可以改变整个意义或只是添加一些语调.我真的没有任何想法如何教这些东西的机器人.

artificial-intelligence chatbot

33
推荐指数
3
解决办法
5万
查看次数

jsession是在由jstl <c:url ..>标记生成的所有URL中发生的

我有一些奇怪的错误:当我第一次在某个浏览器中打开页面时,所有引用都有jsessionid参数(如<a href="/articles?name=art&jsessionid=5as45df4as5df"..>).

当我按F5或以任何其他方式刷新页面时,所有这些东西都消失了,一切正常,直到我关闭浏览器(并且所有选项卡也应该关闭).当我再次打开它时,我看到了这个奇怪的jsessionid参数.

我使用jstl <c:url..>标签来创建所有URL.

我已经读过一段时间了,如果禁用cookie,jsessionid是cookie的替代品,但cookie已经启用,我实际上不使用cookie.

jsp jstl jsessionid

31
推荐指数
4
解决办法
4万
查看次数

如何在Java中用JSON-string查找指定的名称及其值?

假设我们有下一个JSON字符串:

{  
   "name" : "John",
   "age" : "20",
   "address" : "some address",
   "someobject" : {
       "field" : "value"    
   }
}
Run Code Online (Sandbox Code Playgroud)

什么是最简单的(但仍然是正确的,即正则表达式是不可接受的)查找字段age及其值的方法(或确定没有给定名称的字段)?

ps任何开源库都可以.

ps2:拜托,不要发布图书馆的链接 - 这不是一个有用的答案.'给我看代码'(c).

java json gson json-simple

31
推荐指数
3
解决办法
12万
查看次数

当没有接受long的方法时,为什么java将long参数提升为float/double?

这是一个SSCCE,它演示了描述(恕我直言,怪异)的行为:

public class Test {

   public static void print(int param) {
       System.out.println("int");
   }

   public static void print(float param) {
       System.out.println("float");
   }

   public static void print(Long param) { //<--Wrapper type
       System.out.println("Long");
   }
   public static void main(String[] args) {
       long param = 100L;
       print(param);  // output == float
   }
} 
Run Code Online (Sandbox Code Playgroud)

为什么java会这样做?

java overloading type-conversion

31
推荐指数
4
解决办法
3092
查看次数