1. sybase存储过程中怎么调用存储过程
1.begin tran
.....(sql)
if @@error=0
commit
else
rollback
2.exec 另族岁一个存储数轮过程名 参兆毕睁数...
2. sybase数据库中numeric(12)最大数是多少如何计算的
numeric[ (p[ ,s] )]
固定精度和小数位数。 使用最大精度时,有效值的范围为 - 10^38 +1 到 10^38 - 1。 decimal 的 ISO 同义词为 dec 和 dec(p、s)。 numeric 在功能上等价于 decimal。
p(精度)
最多可以存储的十进制数字的总位数,包括小数点左边和右边的位数。 该精度必须是从 1 到最大精度 38 之间的值。 默认精度为 18。
s (小数位数)
小数点右边可以存储的十进制数字的最大位数。 小数位数必须是从 0 到 p 之间的值。 仅在指定精度后才可以指定小数位数。 默认的小数位数为 0;因此,0 <= s <= p。 最大存储大小基于精度而变化。
你这个numeric(12)是最大就是12位整数,也就是12个9.
3. sybase 存储过程
存储过程是存储在服务器端的一类数据库对象,它实质上是一段用SQL语言编写的程序,它在服务器端预先经过编译,并确定出执行计划,因此与同样功能的批处理语句相比,它的执行速度较快。基本语法:Create Procere[owner.]过程名[@参数名 数据类型[=默认值][Output]][,@参数名 数据类型[=默认值][Output]][……]ASBeginSQL语句(块)End存储过程是数据库对象,和表、索引是一个级别的;是SQL语句和控制流语言的集合,存储过程在首次运行时被编译,并驻留在过程高速缓存的内存中,所以存储过程的招待非常快。存储过程可以带参数,可以调用其他过程,返回状态值,返回参数值,并且可以在远程SQL Server执行。可以在远程SQL Server执行对数据库设计有特别重要的意义。SQL Server提供的存储过程称为系统过程。存储过程大大增强了闷氏斗SQL的能力、效率和灵活性,经过编译的存储过程极大地改善SQL语句和批处理的性能。存储过程有很多优点:●存储过程在第一次执行时编译,并存储在过程高速缓存的内存中。编译时系统对其进行优化,以选择最佳的路径来访问数据集中的数据,这种优化考虑了数据集的实际数据结构。因此存储过程大大提高了系统的性能。●存储过程可以跨服务器运行。这一点是通过触发器来实现的,当然,首先存储过程要能登录到该远程服务器。●应用程序也能执行存储过程,从而实现服务器和客户之间的协同作业。●存储过程减少了网络的交通。这是因为存储过程的文本存储在数据库里,调用存储过程时通过网络的只是存储过程的过程名。●利用存储过程可以提供一个附加的安全层。如(该例子取自pubs2数据库):Create proc titleid_proc(@title_id varchar(80))AsBeginSelect @title_id=lower(@title_id) ”%”Select title,title_id,priceForm titlesWhere lower(title_id) like @title_idReturn @@rowcountEnd注意例子中的黑体部分,这实际上是一条赋值语句。该存储过程有返回值。存储过程可以变得非常复杂。我们认为,创建存储过程还是要遵循“最简单就是最好”的原则。建议在创建存储过程时采用缩进风格,否则创建的存储过程三天之后连自己都看不懂。需要对存储过程作些说明:●Create procere 语句不能和其他语句在同一个批命令里。●Create procere 语句不能包括下列语句:useCreate ViewCreate defaultCreate ruleCreate triggerCreate procere不能使用use语句好理解,存核链储过程是针对数据库的,不能在一个数据库里访问另外的数据库。如果在存储过程里访问另外的数据库,则数据库表的参照完整性难于得到保障。从另外几条语句看,在存储过程里一般不能创建新的数据库对象。但可以创建表和索引,以及和表相关联的键,表是临时表,在存储过程结束后不能看见创建的临时表;否则的话每运行一次存储过程就创建一个表,结果可想而知。存储过程里不能创建一个对象,删除它;然后又在同一存储过程里用相同的名字创建新的对象。实际上,SQL Server在存储过程运行时而不是在编蚂磨译时创建对象的。●如果存储过程调用另外的存储过程,则第二个存储过程可以调用在第一个存储过程里创建的对象。●存储过程包含的最多参数为255个,对存储过程里的局部和全局变量没有限制。最后讨论一下系统存储过程。系统存储过程以sp_开头,当然用户创建的存储过程也可以以sp_开头;系统过程保存在sybsystemprocs数据库里。系统过程的使用有权限,如果打入系统过程名但没有出现预期的结果,要么是命令名错,要么是使用者没有该过程的权限。一般可通过系统管理员或数据库所有者对系统过程的execute授权。系统过程繁多,大致有几类:a. 用户标志和授权。这一类的过程主要由于:增加、删除或报告在SQL Server上的登录,增加、删除或报告某数据库的用户、分组或别名等。这类过程有sp_addlogin,sp_adser,sp_helpgroup,sp_dropuser等。b. 远程过程的调用。这类过程用于:增加、删除或报告能存取本SQL Server的远程服务器;增加能从远程服务器上存取本SQL Server的用户名。这类过程有:sp_addremotelogin,sp_addserver,sp_dropserver等。c. 数据定义和数据库对象。这类存储过程用于:连接和定义规则和缺省值,增加、删除或报告主码、外码和公共码;增加、删除或报告用户定义的数据类型。这类存储过程有:sp_bindfault, sp_bindrule, sp_help, sp_helpdb, sp_foreignkey, sp_helptext等。d. 系统管理。这类存储过程用于:增加、删除或报告数据库及转储设备;报告锁;设置的数据库选择及用户正进行的进程;修改及报告配置变量;监控SQL Server的活动。这类过程有:sp_admpdevice,sp_dropdevice, sp_helpdevice等。
4. 怎样传递sybase存储过程中多个output参数
就那现在用的系统举例吧。
NT4+sybase11.5 作数据库服务端,sybase openclient 做辩银客户端昌灶汪
IIS+isapi or dynamo 做 WEB.
服务器基本上不用设置,sybase 较为简单,装完就可用了。用
oracle ,你可就惨了光设参数。就要折腾死人。
用 delphi3开发还要设 ODBC BDE, ODBC中添加一项 DSN ,bde
中会自动显示出来,设置好用耐仔户后存盘,在D3中就可用了.
5. 讲解Sybase存储过程的建立和使用
存储过程的特点
Sybase的存储过程是集中存储在SQL Server中的预先定义且已经编译好的事务 存储租缺过程由SQL语句和流程控制语句组成 它的功能包括:接受参数;调用另一过程;返回一个状态值给调用过程或批处理 指示调用成功或失败;返回若干个参数值给调用过程或批处理 为调用者提供动态结果;在远程SQL Server中运行等
存储过程的性能特点如下:
·存储过程是预编译过的 这就意味着它与普通的SQL语句或批处理的SQL语句不同 当首次运行一个存储过程时 SQL Server的查询处理器对其进行分析 在排除了语法错误之后形成存储在系统中的可执行方案 由于查询处理的大部分工作已经完成 所以存储过程执行速度很快
·存储过程和待处理的数据都放在同一台运行SQL Server的计算机上 使用存储过程查询当地的数据 效率自然很高
·存储过程一般多由Client端通过存储过程的名字进行调用 即跨网传送的只是存储过程的名字及少量的参数(如果有的话) 而不是构成存储过程的许多SQL语句 因此可以减少网络传输量 加快系统响应速度
·存储过程还有着如同C语言子函数那样的被调用和返回值弊搭辩的方便特性
所以 存储过程大大增强了SQL语言的功能 效率和灵活性 掌握和应用好存储过程 对进一步发挥Sybase数据库系统的强大功能有着重要的意义
存储过程的语法规则
建立存储过程的语法规则为:
CREATEPROCere[owner ]procerename[;number] [[(]@parameter_namedatatype[=default][OUTput] [ @parameter_namedatatype[=default][OUTput]] [)]] [WITHREPILE] ASSQL_statements
使用存储过程的语法规则为:
[EXECute][@return status=] [[[server ]database ]owner ]procerename[;number] [[@parameter_name=]value|[@parameter_name=]@varialbe[OUTput] [ [@parameter_name=]value|[@parameter_name=]@variable[OUTput] ]] [WITHREPILE]
[page]下面简要介绍这两个命令的常用选项以及建立和使用存储过程的要点 关于选项的更为详细的说明请参考有关手册
·[[[server ]database ]owner ]procere_name:存储过程的名字
·@parameter_name datatype[=default][OUTput]:形式参数(形参)的名称 类型 df ault是赋予的缺省值(可选) OUTput指定本参数为输出参数(可选) 形参是存储过程中的自变量 可以有多个 名字必须以@打头 最长 个字符
·SQL_statements:定义存储过程功能的SQL语句
·@return_status:接受存储过程返回状态值的变量
·[@parameter_name=]value:实际参数(实参) @parameter_name为实参的名称(可选) 如果某个实参以@parameter_name=value提供 那么随后的实参也都要采用这一形式提供
·[@parameter_name=]@varialbe[OUTput]:将变量@varialbe中的值作为实参传递给形参@parameter_name(可选) 如果变量@varialbe是用来接受返回的参数值 则选项OUTput不可缺少
存储过程的建立和使用 我们将通过几个例子进行枝配介绍
假设有一个用下述语句生成的技能工资表RS LS GZ JiNeng:
create table RS_LS_GZ_JiNeng /*技能工资表*/
(GeRen_id char( ) /*个人代码 */
RiQi *** alldatetime /*执行日期 */
YuanYin_id char( ) null /*变动原因代码 */
JinE *** allmoney) /*技能工资金额 */
该表存储着某单位员工多年来技能工资的历史档案
例 如果要查询全体员工的技能工资变动历史 则可先建立一个存储过程p RsGz JiNeg All:
createprocerep_RsGz_JiNeng_Allas select* fromRS_LS_GZ_JiNeng orderbyGeRenid RiQi
然后用批处理语句调用存储过程p_RsGz_JiNeng_All进行查询:
execute p_RsGz_JiNeng_All
本例只显示查询到的数据 无输入 输出参量 是最简单的一个存储过程
例 如果要查询某人技能工资的变动历史 可建立另一个存储过程p_RsGz_JiNeng:
createprocerep_RsGz_JiNeng@c_GeRenIdchar( ) as select*fromRS_LS_GZ_JiNeng whereGeRen_id=@c_GeRenId orderbyRiQi
之后用批处理语句调用存储过程p_Rs_Gz_JiNeng进行查询:
declare @GeRenId char( )
select @GeRenId= /*设要查询员工的个人代码为 */
execute p_RsGz_JeNeng @c_GeRenId=@GeRenId
存储过程p_RsGz_JiNeng中定义了一个形参@c_GeRenId 是字符型变量 在调用该过程的批处理中 既可以用具体的值也可以用变量作为实参 用变量作实参(如本例)时 必须用del are语句加以说明 值得注意的是 在批处理的调用过程语句中 @c_GeRenId=@GeRenId中的@ c_GeRenId是存储过程p_RsGz_JiNeng中的形参名 不是批处理中的变量 所以不能将它列入d eclare语句的变量单中
例 如果要计算当月工资 就必须从工资历史中查出员工距离当前最近的一次技能工资变动的结果:
createprocerep_RsGz_JiNeng_Slt (@c_GeRenIdchar( ) @ *** _JinE *** allmoneyoutput) as select@ *** _JinE=JinE fromRS_LS_GZ_JiNeng whereRiQi=(selectmax(RiQi) fromRS_LS_GZ_JiNeng
where GeRenid=@c GeRenId)/*找出历史记录中距离当前最近的日期*/
调用存储过程p_RsGz_JiNeng_Slt进行查询:
declare@GeRenIdchar( ) @JinE *** allmoney select@GeRenid= /*设要查询员工的个人代码为 */ select@JinE= executep_RsGz_JiNeng_slt@c_GeRenId=@GeRenId @ *** _JinE=@JinEoutput
这里 变量 @JinE用来存储过程形参@ *** _JinE传回的金额 在调用过程语句中 @ *** _JiE = @JinE output中的output不可省略 否则 变量@JinE将得不到形参传回的数值而始终为零(等于初值)
例 查到了个人代码为 员工的技能工资就显示其历史纪录 查不到则显示一条出错信息
createprocerep_RsGz_JiNeng_Rtn @c_GeRenIdchar( ) as declare@ErrCode *** allint select@ErrCode= ifexists(select*fromRS LS GZ JiNeng whereGeRenid=@c GeRenId) begin select* fromRS_LS_GZ_JiNeng whrerGeRen_id=@c_GeRenId orderbyRiQi return@ErrCodE end eslE begin select@ErrCode= return@ErrCodE end
调用存储过程p_RsGz_JiNeng_Rtn:
declare@GeRenIdchar( ) @RtnCode *** allint select@GeRenId= select@RtnCode= execute@RtnCode=p_RsGz_JiNeng_Rtn@c_GeRenId=@GeRenId if@RtnCode= print Nothisone!
存储过程p_RsGz_JiNeng_Rtn向调用者返回一个存储在变量@ErrCode里的值 这个值被称为状态值 它向调用者反映存储过程执行的成败状态 在本例中 如果查不到指定员工技能工资的任何记录时 就认为 查无此人 返回出错状态值 否则 返回成功状态值
调用过程的批处理语句使用变量@RtnCode存储返回的状态值 一旦检出存储过程p_RsG_ JiNeng_Rtn返回了错误标志(@RtnCode= ) 就显示一条信息 No this one! [page]
小结
上述四个例子简要介绍了存储过程常用的几种形式 从中我们已经可以领略到它的编程特色以及使用上的灵活性和方便性
lishixin/Article/program/Oracle/201311/17494
6. JDBC调用Sybase存储过程,结果集总是无法返回,该怎么处理
JDBC调用Sybase存储过程,结果集总是无法返回!
java代码部分如下:
String sproc = "{ call zhouxiaobotest2(?,?,?,?)} ";
CommonDAO = null;
try {
= new CommonDAO(jndi);
Connection connect = .getConn();
//得到总数
rowNum = PageDiv.getCount(countSql.toString(), );
//设置分页信息
pageBean.setPageInfo(rowNum, pageSize);
// 获取CallableStatement语句:
CallableStatement mStatement = connect.prepareCall(sproc,
ResultSet.TYPE_SCROLL_INSENSITIVE,
ResultSet.CONCUR_READ_ONLY);
// 传入输入参数和注册输出参数
mStatement.setString(1,sql.toString());
mStatement.setInt(2, 10);
mStatement.setInt(3, 10);
mStatement.setInt(4, 5000);
// 执行存储过程
ResultSet rs = null;
mStatement.execute();
rs = mStatement.getResultSet();
catch (Exception ex) {
ex.printStackTrace();
logger.warn(sql.toString());
} finally {
.destroy();
= null;
sproc = null;
}
存储过程如下:
create procere zhouxiaobotest @qry varchar(16384),@ipage int, @num int,@maxpages int
as
/*@qry SQL语句, @ipage 页数, @num 每页记录条数, @maxpages 最大查薯昌询页数 */
begin
declare @execsql varchar(16384)
set @execsql = " select USER_NAME from TBL_USER "
execute (@execsql)
end
create procere zhouxiaobotest2 @qry varchar(16384),@ipage int, @num int,@maxpages int
as
/*@qry SQL语句, @ipage 页数, @num 每页记录条数, @maxpages 最大查询页橡手液数 */
begin
select USER_NAME from TBL_USER
end
现在我的问题是调用存梁物储过程zhouxiaobotest,mStatement.execute()始终是false;而调用zhouxiaobotest2 mStatement.execute()就是true,能得到结果集。我想知道如何修改程序使我能够调用zhouxiaobotest取得结果集(之前调试程序运行没有抛出任何异常,而且控制台运行存储过程也都正确)
7. C# Sybase 中文参数出错
使用陆升1、AseParameter param = new AseParameter("name"早锋老, AseDbType.VarChar);导致基没中文无法全部保存,这是因为不指定varchar长度时,默认好像是1个字节吧。
你尝试自己修改commandbuilder生成语句时数据类型的默认长度吧。
8. Sybase数据库的基本原理: (1)、列方式的存储,可以减少IO 那个IO是什么
列存储——有别于传统的关系型数据库,Sybase IQ是按照数据表中的列来存储与访问数据的。基于列来读取数据,即使在数据不断膨胀的情况下,你也只须读出你想要了解的数据,避免了重复的全面扫描,显着提供查询速度,进而提升了性能指数P;同时,由于同一列中的所有数据域有相同的数据类型,因此,每一列都可以以更优化的效率和检索进行压缩,从而降低了占用的资源T。
数据压缩——正是由于数据按列存储,相邻的字段值具有相同的数据类型,所以压缩更容易,通常能得到大于50%的压缩。在海量数据下,随着数据的大幅压缩,所占用的空间等资源成本会显着减少。因此,更大的压缩比,加上大页面,使得Sybase IQ在获得优良查询性能的同时,减少了对存储空间的需求,因此占用的资源T也大大降低了。
丰富的索引——传统的关系型数据库引擎只能一对一地解决问题,在数据爆炸的今天,如此“大海捞针”似的查询会令反应速度非常迟缓。而Sybase IQ针对数据仓库应用有多种不同的索引技术,并且这些技术中的每一个都与数据仓库的查询问题相吻合,从而显着减少给定查询或更新的工作量,加快查询速度,自然带动性能P的提升。
Multiplex可扩展能力——Sybase IQ的Multiplex组件增加了在单一的Sybase IQ环境中支持多个SMP机器节点的功能,显着地减轻了进程与内存负担。因此,在信息飞速增长的商业社会,它允许数据仓库从基础开始扩展,从很小的规模扩展到非常巨大的规模,拥有卓越的可扩展能力,避免了数据爆炸带来的更新和不便。
总之,正是凭借以上引领未来的核心科技,Sybase IQ 在保证数据压缩的目标下,能够同时提高查询性能。因此,不论以S/T(即数据库压缩比)、P/T,还是从整体SPoT公式来看,Sybase IQ 都拥有更高的绿色数据指标,是“绿色数据库”的完美体现。
信息飞速膨胀的时代呼唤有效利用资源的绿色科技。绿色数据库Sybase IQ是对传统商业智能软件的挑战,引领了未来关系型数据库的发展方向,其低成本、高效能的绿色效应必将促进企业健康持久成长,营造和谐持续发展的绿色信息环境。
9. SYBASE数据库优化中各参数分别表示什么如何修改
sp_configure "max memory",800000 ///共享内存1.6G
Sybase 能够用到的最大物理内存,单位2k,通常配置成昌高祥主机物理内存的70%~80%
sp_configure “number of user connections”,180 ///180个用户连接数
通常根据实际并发呼叫来配,一般配置80~200
sp_configure “lock scheme”, allpages ///使用缺省:页锁
但有些并发操作多的表需使用行锁,如cc_telebill表等
sp_configure “number of locks”,50000 /锁的数目5万
可以根据实际应用,一般10000~50000
sp_configure “max online engines”,2 ///cpu个数为2
单cpu使用缺省值,多cpu(4~8个)配成n-1个
number of engines at startup
sp_configure “number of worker processes”,2 //启用的工作进程数
单cpu使用缺省值,多cpu(4~8个)配成n-1个
sp_configure “number of open indexes ”,1000 ///打开的索引个数
sp_configure “number of open objects ”,1000 ///打开的事务个数
sp_configure "user log cache size",4096
日志缓存通念携常配成2048或4096
sp_configure "procere cache size",50000 /// 100M
存储过程缓存(运行存储过程),单位2k,通常根据需要配置50~200M
sp_cacheconfig "default data cache","1.2G"
设置数据缓存1.2G(所有cache值累加不能超过max memory)
sp_cacheconfig "default data cache", "cache_partition=2"
数据缓存分区(减耐搏少锁竞争)
重启sybase服务令所有参数生效
10. sybase数据库中存储过程参数中能不能同时是输入参数也是输出参数,
可以的,可在参数后加output来实现
如:@par
varchar(20)
output
default
值可以这样
@test
integer
=
10
default
值只有在不提供该参数值时才有效。