Sybase 部分SQL语句介绍

本文介绍了一系列Sybase数据库的基本操作案例,包括数据库选择、用户设置、表结构查看、数据查询、表创建、循环累加操作、触发器及视图创建、不同类型的存储过程创建与调用等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


 
--使用该数据库
use testDB
 
--设置该用户为当前用户
setuser 'testuser'
 
--查看表结构
sp_help tableName
 
--查看视图/触发器语句
sp_helptext viewname/triggerName
 
--查看前十行数据
set rowcount 10
select * from tableName
set rowcount 0
 
--创建表
 
create table Mytest
(
  testidint ,
  testname varchar(12),
  testtime  datetime
)
 
 
--循环累加
declare @i int , @sumint,@csum char(10)
 
set @i=1, @sum=0
 
while @i<=1000
   begin
   set@sum = @sum+@i
   set@i=@i+1
if @i>1000
  select@csum= convert(char,@sum)
print @csum
   end
 
 
 
--循环累加
declare @i int , @sumint , @csum char(10)
 
set @i=1, @sum=0
 
lable:if @i<=1000
        begin
          set@sum = @sum+@i
          set@i=@i+1
          if @i>1000
             begin
             set@csum= convert(char,@sum)
             print @csum
             end
          else
             gotolable
        end
 
 
 
--定义常量 并赋值 打印
declare @i1 int , @i2 int
 
set @i1=123,@i2=321
 
print "@i=%1!,@i2=%2!",@i1,@i2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
--创建触发器,向Mytest Insert的时候同时向test2 Insert
create trigger Inserttrigger  onMytest for insert
as
begin
declare
 @tsidint ,
 @tsnamevarchar(10),
 @tstime datetime
begin
  select@tsid=testid,@tsname=testname,@tstime=testtime frominserted
 begin
  insertinto test2 values(@tsid,@tsname,@tstime)
 end
end
end
 
 
 
--创建触发器,从Mytest Delete的时候把delete的数据Insert到test2
create trigger Deletetrigger  onMytest for delete
as
begin
declare
 @tsidint ,
 @tsnamevarchar(10),
 @tstime datetime
begin
  select@tsid=testid,@tsname=testname,@tstime=testtime fromdeleted
 begin
  insertinto test2 values(@tsid,@tsname,@tstime)
 end
end
end
 
 
--创建简单的视图
 
create view testview
as
select M.*,T.* from Mytest M,test2 Twhere M.testid = T.test2id
 
--测试视图
select * from testview
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
--测试表
create table test
(
  testidnumeric(8) Identity primary key--主键 自增
  testname varchar(12)
)
 
go
 
--系统自增1
insert into test values('testname2')
go
 
select * from test
 
--自己手动输入 --Insert的时候列名一定要写上 否则出错
set identity_insert test on
go
insert into test(testid,testname) values(5,'testname3')
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
--不带参数的存储过程
create proc testproc
as
begin
  select* from testview
end
 
 
--带一个参数
create proc testproc2
@tid int
as
begin
select * from Mytest where testid=@tid
end
 
 
--带一个参数
create proc testproc3
@tname varchar(12)
as
begin
select * from Mytest where testname=@tname
end
 
--带两个参数
create proc testproc4
@tid int,
@tname varchar(12)
as
begin
select * from Mytest where testid = @tid and testname=@tname
end
 
 
--执行
exec  testproc4 @tid=4,@tname='test'
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
--返回值为int的存储过程
create proc testReturn
@tname varchar(12) ,
@tid intoutput
as
begin
set @tid = (select testidfrom Mytest where testname=@tname)
return
end
 
 
--返回值为varchar的存储过程
create proc testReturnT
@tid int,
@tname varchar(12)output
as
begin
set @tname = (select testname from Mytestwhere testid=@tid)
return
end
 
 
--可以正确执行
declare @tid int
exec testReturn 'testname', @tidoutput
select @tid
  
 
 
--正确的执行方法
declare @tname varchar(12)
declare @tid int
exec @tid = testReturnT 3,@tname output
select @tid
select @tname
 
--正确执行
declare @tname varchar(12)
exec testReturnT 3,@tname output
select @tname
 
--注意:Sybase存储过程执行之后 返回值的存储过程成功与否的Int值
  
 
--查询 返回单个输出参数值
create proc selectproc
@tid intout
as
begin
select @tid=testid from Mytest where testname='test9'
end
 
--执行
declare @tid int
exec selectproc @tid output
select @tid
 
 
--查询 返回一个结果集
create proc selectall
as
begin
select * from Mytest
end
 
--执行
exec selectall
 
 
--返回错误值
create proc testprocreturn
@tname varchar(12)
as
begin
declare @tid int,@error int
if exists(selecttestid from Mytest where testname=@tname)
   begin
   set@error= (select testid from Mytestwhere testname=@tname)
   return@error
   end
else
   begin
   set@error=-1
   return@error
   end
end
return
 
--执行
declare  @error int
exec @error= testprocreturn  'test9'
select @error

测试连接(ODBC):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Odbc;
using System.Data.OleDb;
 
namespaceSybaseTest
{
    classProgram
    {
        staticvoid Main(string[] args)
        {
            TestConn();
        }
 
        publicstatic voidTestConn()
        {
            objectobj = null;
            OdbcConnection SybaseConn =null;
            OdbcCommand odbccmd =null;
            try
            {
                //连接串
                stringstrconn = "DSN=TEST;SRVR=TEST;DB=BFV752_T_JXC;UID=sa;PWD=;";
 
                SybaseConn =new OdbcConnection(strconn);
 
                SybaseConn.Open();
 
                stringstr = "update BFBHDD.Mytest set testname = 'testupdate' where testid=1";
 
                odbccmd =new OdbcCommand(str, SybaseConn);
 
                obj = odbccmd.ExecuteNonQuery(); 
 
            }
            catch(Exception ex)
            {
                Console.WriteLine(ex.Message);
            }
            finally
            {
                SybaseConn.Close();
            }
            Console.WriteLine(obj);
 
            Console.ReadKey();
        }
    }
}
<think>我们被要求回答关于SybaseSQL中日期加减操作的问题。根据引用内容,我们知道Sybase支持日期类型(如DATE,TIME,DATETIME,TIMESTAMP等),但引用中并没有直接给出日期加减的示例。不过,我们可以根据一般SQL的经验以及Sybase的特点来回答。通常,在Sybase中,我们可以使用`dateadd`函数进行日期加减,使用`datediff`函数计算日期差。在Sybase中,日期加减通常使用`dateadd`函数,语法如下:dateadd(datepart,number,date)其中:-datepart:指定要加减的日期部分(如year,month,day,hour,minute,second等)-number:要加减的数量(正数为加,负数为减)-date:日期值例如,将日期加上1天:dateadd(day,1,date_column)另外,计算两个日期的差值可以使用`datediff`函数:datediff(datepart,startdate,enddate)下面我们给出一些示例:1.将当前日期加上10天:SELECTdateadd(day,10,getdate())2.将指定日期减去1个月:SELECTdateadd(month,-1,'2022-02-22')3.计算两个日期之间相差的天数:SELECTdatediff(day,'2022-01-01','2022-02-01')//返回31注意:Sybase中的`getdate()`函数用于获取当前日期和时间。另外,根据引用[2],Sybase中也有TIMESTAMP类型,但需要注意的是,Sybase中的TIMESTAMP与日期时间加减无关,它是一个用于记录行版本的数据类型(类似于其他数据库的rowversion),所以不要将其用于日期计算。我们还可以使用`convert`函数来转换日期格式,以便进行加减操作后以特定格式输出。示例:将日期加减后转换为特定格式的字符串SELECTconvert(varchar,dateadd(day,5,getdate()),102)--格式102为yyyy.mm.dd关于日期格式的转换,Sybase支持的格式代码与SQLServer类似(因为两者同源),例如:101:mm/dd/yyyy102:yyyy.mm.dd103:dd/mm/yyyy等等。但是,请注意,不同版本的Sybase可能有细微差异,建议查阅具体版本的文档。由于引用中没有直接给出Sybase日期加减的例子,我们根据通用知识给出上述回答。根据要求,我们还需要生成相关问题。注意:引用[4]中提到了Sybase的一些命令,但主要是关于创建数据库和修改系统表,与日期操作无关。引用[1][2][3]主要涉及MySQLSQL的一般知识,所以我们在回答时以Sybase的通用知识为主。下面我们按照要求组织回答。</think>### Sybase SQL 日期加减操作详解 在 Sybase 中,日期加减操作主要通过 `DATEADD()` 函数实现,其标准语法为: ```sql DATEADD(datepart, number, date_expr) ``` - **datepart**:指定要修改的日期部分(如年、月、日等) - **number**:要加减的数值(正数为加,负数为减) - **date_expr**:日期表达式或列名 #### 常用日期部分参数 | datepart | 含义 | 缩写 | |----------|----------|------| | year | 年 | yy | | quarter | 季度 | qq | | month | 月 | mm | | day | 日 | dd | | hour | 小时 | hh | | minute | 分钟 | mi | | second | 秒 | ss | #### 操作示例 1. **基础加减** ```sql -- 当前日期加3天 SELECT DATEADD(dd, 3, GETDATE()) -- 指定日期减2个月 SELECT DATEADD(mm, -2, '2023-05-15') ``` 2. **结合字段计算** ```sql -- 订单表到期日=创建日+30天 SELECT order_id, DATEADD(dd, 30, create_date) AS due_date FROM orders ``` 3. **复合计算** ```sql -- 当前时间加1小时30分钟 SELECT DATEADD(mi, 90, GETDATE()) -- 等价于 SELECT DATEADD(hh, 1, DATEADD(mi, 30, GETDATE())) ``` #### 注意事项 1. **返回值类型**: `DATEADD()` 返回与输入相同的日期类型(如 `datetime`/`smalldatetime`)。 2. **边界处理**: 当加减月份导致无效日期(如1月31日加1个月)时,Sybase 会自动调整为月末最后一天: ```sql SELECT DATEADD(mm, 1, '2023-01-31') -- 返回 2023-02-28 ``` 3. **获取当前日期**: 使用 `GETDATE()` 函数获取系统当前日期时间[^1][^2]。 4. **日期格式化**: 可用 `CONVERT()` 格式化输出: ```sql SELECT CONVERT(VARCHAR, DATEADD(dd, 5, GETDATE()), 102) -- 格式: yyyy.mm.dd ``` > ⚠️ 注意:Sybase 的 `TIMESTAMP` 类型是二进制计数器,**不能**直接用于日期计算[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值