This's good article from IBM DeveloperWork: Mining your package cache for problem SQL in DB2 For luw
This article teach you how to look for problem sql. so every DBAer need to know.
Friday, January 18, 2013
创建数据库RESTRICTIVE参数导致的问题记录
2013.1.18因为创建数据库时增加了RESTRICTIVE后导致用户创建并分配权限后使用时报了大量的系统权限错误。
分析:
当创建数据库时使用RESTRICTIVE时会导致系统不对PUBLIC用户分配任何默认权限。这些权限包括所有的系统表、ROUTIN等。因为数据库中的多个操作都会对系统表等进行访问,所以需要根据特定需求对用户进行详细的权限再分配。
对于PUBLIC默认获取的权限可以参加信息中心(Default privileges granted on creating a database)。下面给出列表:
The authorities and privileges that you are granted are listed according to the system catalog views where they are recorded:
分析:
当创建数据库时使用RESTRICTIVE时会导致系统不对PUBLIC用户分配任何默认权限。这些权限包括所有的系统表、ROUTIN等。因为数据库中的多个操作都会对系统表等进行访问,所以需要根据特定需求对用户进行详细的权限再分配。
对于PUBLIC默认获取的权限可以参加信息中心(Default privileges granted on creating a database)。下面给出列表:
Default privileges granted on creating a database
When you create a database, default database level authorities and default object level privileges are granted to you within that database.The authorities and privileges that you are granted are listed according to the system catalog views where they are recorded:
- SYSCAT.DBAUTH
- The database creator is granted the following authorities:
- ACCESSCTRL
- DATAACCESS
- DBADM
- SECADM
- In a non-restrictive database, the special group PUBLIC is granted the following authorities:
- CREATETAB
- BINDADD
- CONNECT
- IMPLICIT_SCHEMA
- SYSCAT.TABAUTH
- In a non-restrictive database, the special group PUBLIC is granted the following privileges:
- SELECT on all SYSCAT and SYSIBM tables
- SELECT and UPDATE on all SYSSTAT tables
- SELECT on the following views in schema SYSIBMADM:
- ALL_*
- USER_*
- ROLE_*
- SESSION_*
- DICTIONARY
- TAB
- SYSCAT.ROUTINEAUTH
- In a non-restrictive database, the special group PUBLIC is granted the following privileges:
- EXECUTE with GRANT on all procedures in schema SQLJ
- EXECUTE with GRANT on all functions and procedures in schema SYSFUN
- EXECUTE with GRANT on all functions and procedures in schema SYSPROC (except audit routines)
- EXECUTE on all table functions in schema SYSIBM
- EXECUTE on all other procedures in schema SYSIBM
- EXECUTE on the following modules in schema SYSIBMADM:
- DBMS_JOB
- DBMS_LOB
- DBMS_OUTPUT
- DBMS_SQL
- DBMS_UTILITY
- SYSCAT.PACKAGEAUTH
- The database creator is granted the following privileges:
- CONTROL on all packages created in the NULLID schema
- BIND with GRANT on all packages created in the NULLID schema
- EXECUTE with GRANT on all packages created in the NULLID schema
- In a non-restrictive database, the special group PUBLIC is granted the following privileges:
- BIND on all packages created in the NULLID schema
- EXECUTE on all packages created in the NULLID schema
- SYSCAT.SCHEMAAUTH
- In a non-restrictive database, the special group PUBLIC is granted the following privileges:
- CREATEIN on schema SQLJ
- CREATEIN on schema NULLID
- SYSCAT.TBSPACEAUTH
- In a non-restrictive database, the special group PUBLIC is granted the USE privilege on table space USERSPACE1.
- SYSCAT.WORKLOADAUTH
- In a non-restrictive database, the special group PUBLIC is granted the USAGE privilege on SYSDEFAULTUSERWORKLOAD.
Sunday, January 13, 2013
bottle模板引用javascript和css的问题
如果在bottle默认的sampleTemple使用javascript或者css引用时会发现引用没有效果。处理办法:
index.py:
from bottle import Bottle, route, run, post, request, static_file, abort, view
# 需要使用 app.get_url
from bottle import default_app
app = Bottle()
default_app.push(app)
# 给所有模板目录传递路径
from bottle import SimpleTemplate
SimpleTemplate.defaults["get_url"] = app.get_url
# 定义静态脚本路径
@route('/static/:path#.+#', name='static')
def static(path):
return static_file(path, root='static')
@route('/')
@route('/hello/<name>')
@view('hello_template')
def hello(name='World'):
return {}
hello_template的引用方式:
<script language="javascript" type="text/javascript" src="{{ get_url('static', path='jquery.js') }}"></script>
参考:
http://stackoverflow.com/questions/10885429/static-files-in-a-bottle-application-cannot-be-found-404
http://stackoverflow.com/questions/9505256/static-files-not-loaded-in-a-bottle-application-when-the-trailing-slash-is-omitt
http://stackoverflow.com/questions/6978603/how-to-load-a-javascript-or-css-file-into-a-bottlepy-template
index.py
- static/
jquery.js
jquery.flox.js
- views/
hello_temple.tpl
index.py:
from bottle import Bottle, route, run, post, request, static_file, abort, view
# 需要使用 app.get_url
from bottle import default_app
app = Bottle()
default_app.push(app)
# 给所有模板目录传递路径
from bottle import SimpleTemplate
SimpleTemplate.defaults["get_url"] = app.get_url
# 定义静态脚本路径
@route('/static/:path#.+#', name='static')
def static(path):
return static_file(path, root='static')
@route('/')
@route('/hello/<name>')
@view('hello_template')
def hello(name='World'):
return {}
hello_template的引用方式:
<script language="javascript" type="text/javascript" src="{{ get_url('static', path='jquery.js') }}"></script>
参考:
http://stackoverflow.com/questions/10885429/static-files-in-a-bottle-application-cannot-be-found-404
http://stackoverflow.com/questions/9505256/static-files-not-loaded-in-a-bottle-application-when-the-trailing-slash-is-omitt
http://stackoverflow.com/questions/6978603/how-to-load-a-javascript-or-css-file-into-a-bottlepy-template
Subscribe to:
Posts (Atom)