Sybase数据库与sql server有什么区别?
展开全部
你好,目前目前大型的数据库都采用oracle,中小型的用sqlServer,建议用sqlserver或者mysql。 \x0d\x0asybase与sqlsrver的内在区别就是:\x0d\x0a1.Sybase没有用户自定义函数。 \x0d\x0a\x0d\x0a2.判断fetch成功的全局变量是@@SQLstatus,而不是@@fetch_status。 \x0d\x0a\x0d\x0a3.没有set,赋值与查询通用select。 \x0d\x0a\x0d\x0a4.没有top,返回N行要使用set rowcount N / set rowcount 0 \x0d\x0a\x0d\x0a5.raiserror 22009 " "--> raiserror( ' ',16,1) \x0d\x0a\x0d\x0a6.游标一定要在过程中使用,不能单独在查询中使用。 \x0d\x0a\x0d\x0a7.销毁游标要加cursor关键字.如:deallocate cursor cur_tmp \x0d\x0a\x0d\x0a8.没有bigint类型。 \x0d\x0a\x0d\x0a9.create table #t(id numeric(12,0) identity not null),不支持int型,且不能设置起始值和步进值。 \x0d\x0a\x0d\x0a10.不能alter一个存储过程,要先drop掉再create。 \x0d\x0a\x0d\x0a11.没有len函数,使用char_length或datalength等效。 \x0d\x0a\x0d\x0a12.通过sysindexes中的doampg列可返回某表的行数,rowcnt(doampg) 。 \x0d\x0a\x0d\x0a13.convert函数没有120格式(yyyy-mm-dd hh:mm:ss),需要使用select convert(char(4),datepart(year,getdate()))+ '- '+right( '0 '+convert(varchar(2),datepart(month,getdate())),2)+ '- '+right( '0 '+convert(varchar(2),datepart(day,getdate())),2)+ ' '+convert(char(10),getdate(),8) \x0d\x0a\x0d\x0a14.charindex不能从被查找字符串中按指定位置查找某字符串。 \x0d\x0a\x0d\x0a15.不能使用rtrim函数将数值型转为字符型。 \x0d\x0a\x0d\x0a16.没有cast函数,数值型到字符型转移使用select convert(varchar(10),123) \x0d\x0a\x0d\x0a17.没有replace函数。 \x0d\x0a\x0d\x0a18.没有left函数,只有right函数。 \x0d\x0a\x0d\x0a19.不支持在字段上加[]。 \x0d\x0a\x0d\x0a20.select语句中不支持变量累加,例如:select @SQL=@SQL+colname from tablename \x0d\x0a\x0d\x0a21.在过程及视图中系统会自动将select * 变为select 列1,列2... \x0d\x0a\x0d\x0a22.varchar最大支持16384个字节(SQLServer中是8000) 。 \x0d\x0a\x0d\x0a23.Sybase不支持表变量。 \x0d\x0a\x0d\x0a24.Sybase不支持instead of触发器。 \x0d\x0a\x0d\x0a25.Sybase没有调度(注:定时执行某个操作) 。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询