Sybase 常用sql语句

本文提供了一系列常用的SQL语句,包括数据库管理、用户管理、存储过程、数据查询与分析等方面的操作指南。

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

常用sql语句

1. 查看数据库的版本
select @@version

2. 查看数据库所在机器操作系统参数
exec master..xp_msver

3. 查看数据库启动的参数
sp_configure

4. 查看数据库启动时间
select convert(varchar(30),login_time,120) from master..sysprocesses where spid=1
查看数据库服务器名和实例名
print 'Server Name...............:' + convert(varchar(30),@@SERVERNAME)
print 'Instance..................:' + convert(varchar(30),@@SERVICENAME)

5. 查看所有数据库名称及大小
sp_helpdb
重命名数据库用的SQL
sp_renamedb 'old_dbname', 'new_dbname'

6. 查看所有数据库用户登录信息
sp_helplogins
查看所有数据库用户所属的角色信息
sp_helpsrvrolemember
修复迁移服务器时孤立用户时,可以用的fix_orphan_user脚本或者LoneUser过程
更改某个数据对象的用户属主
sp_changeobjectowner [@objectname =] 'object', [@newowner =] 'owner'
注意:更改对象名的任一部分都可能破坏脚本和存储过程。
把一台服务器上的数据库用户登录信息备份出来可以用add_login_to_aserver脚本
查看某数据库下,对象级用户权限
sp_helprotect

7. 查看链接服务器
sp_helplinkedsrvlogin
查看远端数据库用户登录信息
sp_helpremotelogin

8.查看某数据库下某个数据对象的大小
sp_spaceused @objname
还可以用sp_toptables过程看最大的N(默认为50)个表
查看某数据库下某个数据对象的索引信息
sp_helpindex @objname
还可以用SP_NChelpindex过程查看更详细的索引情况
SP_NChelpindex @objname
clustered索引是把记录按物理顺序排列的,索引占的空间比较少。
对键值DML操作十分频繁的表我建议用非clustered索引和约束,fillfactor参数都用默认值。
查看某数据库下某个数据对象的的约束信息
sp_helpconstraint @objname

9.查看数据库里所有的存储过程和函数
use @database_name
sp_stored_procedures
查看存储过程和函数的源代码
sp_helptext '@procedure_name'
查看包含某个字符串@str的数据对象名称
select distinct object_name(id) from syscomments where text like '%@str%'
创建加密的存储过程或函数在AS前面加WITH ENCRYPTION参数
解密加密过的存储过程和函数可以用sp_decrypt过程

10.查看数据库里用户和进程的信息
sp_who
查看SQL Server数据库里的活动用户和进程的信息
sp_who 'active'
查看SQL Server数据库里的锁的情况
sp_lock
进程号1--50是SQL Server系统内部用的,进程号大于50的才是用户的连接进程.
spid是进程编号,dbid是数据库编号,objid是数据对象编号
查看进程正在执行的SQL语句
dbcc inputbuffer ()
推荐大家用经过改进后的sp_who3过程可以直接看到进程运行的SQL语句
sp_who3
检查死锁用sp_who_lock过程
sp_who_lock

11.查看和收缩数据库日志文件的方法
查看所有数据库日志文件大小
dbcc sqlperf(logspace)
如果某些日志文件较大,收缩简单恢复模式数据库日志,收缩后@database_name_log的大小单位为M
backup log @database_name with no_log
dbcc shrinkfile (@database_name_log, 5)

12.分析SQL Server SQL 语句的方法:
set statistics time {on | off}
set statistics io {on | off}
图形方式显示查询执行计划
在查询分析器->查询->显示估计的评估计划(D)-Ctrl-L 或者点击工具栏里的图形
文本方式显示查询执行计划
set showplan_all {on | off}
set showplan_text { on | off }
set statistics profile { on | off }

13.出现不一致错误时,NT事件查看器里出3624号错误,修复数据库的方法
先注释掉应用程序里引用的出现不一致性错误的表,然后在备份或其它机器上先恢复然后做修复操作
alter database [@error_database_name] set single_user
修复出现不一致错误的表
dbcc checktable('@error_table_name',repair_allow_data_loss)
或者可惜选择修复出现不一致错误的小型数据库名
dbcc checkdb('@error_database_name',repair_allow_data_loss)
alter database [@error_database_name] set multi_user
CHECKDB 有3个参数:
repair_allow_data_loss 包括对行和页进行分配和取消分配以改正分配错误、结构行或页的错误,以及删除已损坏的文本对象,这些修复可能会导致一些数据丢失。
修复操作可以在用户事务下完成以允许用户回滚所做的更改。
如果回滚修复,则数据库仍会含有错误,应该从备份进行恢复。
如果由于所提供修复等级的缘故遗漏某个错误的修复,则将遗漏任何取决于该修复的修复。
修复完成后,请备份数据库。
repai*_**st 进行小的、不耗时的修复操作,如修复非聚集索引中的附加键。
这些修复可以很快完成,并且不会有丢失数据的危险。
repair_rebuild 执行由 repai*_**st 完成的所有修复,包括需要较长时间的修复(如重建索引)。
执行这些修复时不会有丢失数据的危险。


添加、删除、修改使用db.Execute(Sql)命令执行操作
╔--------------------╗
☆ 数据记录筛选 ☆
╚--------------------╝
注意:单双引号的用法可能有误(没有测式)

Sql = "Select Distinct 字段名 From 数据表"
Distinct函数,查询数据库存表内不重复的记录

Sql = "Select Count(*) From 数据表 where 字段名1>#18:0:0# and 字段名1< #19:00# "
count函数,查询数库表内有多少条记录,“字段名1”是指同一字段
例:
set rs=conn.execute("select count(id) as idnum from news")
response.write rs("idnum")

sql="select * from 数据表 where 字段名 between 值1 and 值2"
Sql="select * from 数据表 where 字段名 between #2003-8-10# and #2003-8-12#"
在日期类数值为2003-8-10 19:55:08 的字段里查找2003-8-10至2003-8-12的所有记录,而不管是几点几分。

select * from tb_name where datetime between #2003-8-10# and #2003-8-12#
字段里面的数据格式为:2003-8-10 19:55:08,通过sql查出2003-8-10至2003-8-12的所有纪录,而不管是几点几分。

Sql="select * from 数据表 where 字段名=字段值 order by 字段名 [desc]"

Sql="select * from 数据表 where 字段名 like '%字段值%' order by 字段名 [desc]"
模糊查询

Sql="select top 10 * from 数据表 where 字段名 order by 字段名 [desc]"
查找数据库中前10记录

Sql="select top n * form 数据表 order by newid()"
随机取出数据库中的若干条记录的方法
top n,n就是要取出的记录数

Sql="select * from 数据表 where 字段名 in ('值1','值2','值3')"

╔--------------------╗
☆ 添加数据记录 ☆
╚--------------------╝
sql="insert into 数据表 (字段1,字段2,字段3 …) valuess (值1,值2,值3 …)"

sql="insert into 数据表 valuess (值1,值2,值3 …)"
不指定具体字段名表示将按照数据表中字段的顺序,依次添加

sql="insert into 目标数据表 select * from 源数据表"
把源数据表的记录添加到目标数据表

╔--------------------╗
☆ 更新数据记录 ☆
╚--------------------╝
Sql="update 数据表 set 字段名=字段值 where 条件表达式"

Sql="update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式"

Sql="update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n "
没有条件则更新整个数据表中的指定字段值

╔--------------------╗
☆ 删除数据记录 ☆
╚--------------------╝
Sql="delete from 数据表 where 条件表达式"

Sql="delete from 数据表"
没有条件将删除数据表中所有记录)

╔--------------------------╗
☆ 数据记录统计函数 ☆
╚--------------------------╝
AVG(字段名) 得出一个表格栏平均值
COUNT(*|字段名) 对数据行数的统计或对某一栏有值的数据行数统计
MAX(字段名) 取得一个表格栏最大的值
MIN(字段名) 取得一个表格栏最小的值
SUM(字段名) 把数据栏的值相加

引用以上函数的方法:
sql="select sum(字段名) as 别名 from 数据表 where 条件表达式"
set rs=conn.excute(sql)
用 rs("别名") 获取统的计值,其它函数运用同上。

╔-----------------------------╗
☆ 数据表的建立和删除 ☆
╚-----------------------------╝
CREATE TABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度) …… )
例:CREATE TABLE tab01(name varchar(50),datetime default now())
DROP TABLE 数据表名称 (永久性删除一个数据表)

╔--------------------------╗
☆ 记录集对象的方法 ☆
╚--------------------------╝
rs.movenext 将记录指针从当前的位置向下移一行
rs.moveprevious 将记录指针从当前的位置向上移一行
rs.movefirst 将记录指针移到数据表第一行
rs.movelast 将记录指针移到数据表最后一行
rs.absoluteposition=N 将记录指针移到数据表第N行
rs.absolutepage=N 将记录指针移到第N页的第一行
rs.pagesize=N 设置每页为N条记录
rs.pagecount 根据 pagesize 的设置返回总页数
rs.recordcount 返回记录总数
rs.bof 返回记录指针是否超出数据表首端,true表示是,false为否
rs.eof 返回记录指针是否超出数据表末端,true表示是,false为否
rs.delete 删除当前记录,但记录指针不会向下移动
rs.addnew 添加记录到数据表末端
rs.update 更新数据表记录

14.查询数据库死进程
select * from master..syslogshold

<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、付费专栏及课程。

余额充值