`

Sybase数据库常用SQL

    博客分类:
  • DB
阅读更多
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 更新数据表记录
分享到:
评论

相关推荐

    Sybase数据库常用维护操作

    ### Sybase数据库常用维护操作详解 #### 一、概述 Sybase数据库系统因其高效稳定而被广泛应用于多种业务场景之中,但在实际应用过程中难免会遇到各种问题,如数据库死锁、进程阻塞、查询计划不优、IO性能瓶颈等。...

    Sybase数据库安装配置

    ### Sybase数据库安装配置知识点详解 #### 一、Sybase数据库安装步骤 ##### 1. 启动安装程序 - **第一步**: 双击Sybase 12.5.4的安装文件,如图3.1.1所示,启动安装向导。 - **第二步**: 在安装向导的第一个界面上...

    (Only)SYBASE数据库常用操作_20090919,一部非常好的操作文档资料。

    根据提供的文档信息,我们可以总结出一系列关于SYBASE数据库的常用操作知识。这些操作涵盖了数据库结构的生成、数据导入导出、视图与存储过程管理、时间格式转换等多个方面。 ### 1. 数据库结构生成 - **命令**: `...

    基于Sybase web.sql的网络数据库解决方案.pdf

    基于Sybase web.sql的网络数据库解决方案 本文讨论的是基于Sybase web.sql的网络数据库解决方案。随着社会对信息需求的增长,对网络数据库技术的需求也在增加。网络数据库技术是网络技术和数据库技术的融台,它的...

    sybase数据库命令指南

    《Sybase数据库命令指南》是Sybase公司针对其Adaptive Server Enterprise 12.5.1版本提供的详尽命令参考手册。Sybase数据库系统作为一款高性能的企业级数据库管理系统,在金融、电信、航空等行业有着广泛的应用。...

    Sybase数据库培训教材.doc

    - 提供了关于系统表、磁盘分配信息、系统过程权限以及常用SQL命令的详细列表,为用户提供实用参考资料。 通过以上内容,我们可以全面了解Sybase数据库的基础知识、核心技术和日常维护操作,为深入学习和应用Sybase...

    sybase数据库的基本语法

    Sybase数据库是一种关系型数据库管理系统,由Sybase公司开发,其基础语法在Transact-SQL(T-SQL)环境下执行,与SQL Server的语法非常接近。Sybase数据库的基本语法主要包含数据查询、数据操作、表及数据库的管理等...

    Sybase数据库的备份与恢复

    ### Sybase数据库的备份与恢复 #### 一、引言 Sybase数据库系统是由美国Sybase公司开发的一款高性能的关系型数据库管理系统(RDBMS),它适用于UNIX或Windows平台上的客户机/服务器架构,并广泛应用于各类企业的...

    sybase数据库基础

    以上内容涵盖了Sybase数据库的基础知识、常用操作以及关键概念和技术细节,旨在帮助学习者全面理解和掌握Sybase数据库系统的各个方面。通过本课程的学习,可以掌握Sybase数据库的基础知识、数据库的备份与恢复以及...

    sybase 数据库函数大全

    《Sybase数据库函数大全:深入解析与应用实例》 在数据库管理领域,Sybase作为一个功能强大的企业级数据库管理系统,提供了丰富的内置函数,极大地提升了数据处理的效率和灵活性。本文将围绕Sybase系统函数进行深入...

    Sybase数据库维护快速参考手册

    ### Sybase数据库维护快速参考手册知识点详述 #### 基本概念篇 **1.1 什么是Sybase Adaptive Server Enterprise (ASE)?** Sybase Adaptive Server Enterprise (ASE) 是Sybase公司开发的一款高性能的关系型数据库...

    Sybase数据库的存储过程性能优化.pdf

    总的来说,Sybase数据库的存储过程性能优化需要从多个方面考虑,包括但不限于:避免或优化游标使用,利用CASE语句等新特性,以及综合运用各种SQL语句优化策略。通过这些方法,开发者可以显著提高存储过程的执行效率...

    sybase数据库维护快速参考手册

    isql是一款用于与Sybase数据库交互的命令行工具,主要用于执行SQL命令。使用方法包括: 1. **打开命令行界面**。 2. **输入isql命令**:连接到数据库。 3. **执行SQL语句**:查询、更新等操作。 4. **退出isql**:...

    sybase数据库维护快速手册

    ### Sybase数据库维护知识点概述 #### 一、基本概念篇 **1.1 Sybase Adaptive Server Enterprise (ASE)** Sybase Adaptive Server Enterprise (ASE),即Sybase企业版服务器,是Sybase公司提供的一款高性能的关系型...

    sybase命令大全

    Sybase是一种关系型数据库管理系统,尤其在金融和电信领域广泛应用。...熟练掌握这些命令将大大提高Sybase数据库管理员的工作效率和数据库的健康状况。记得在执行任何更改之前备份数据,以防止不可预料的后果。

    Sybase数据库备份与恢复[参照].pdf

    - `isql`:这是一个交互式SQL查询工具,用于连接到Sybase数据库并执行SQL命令。 - `sp_helpdb`:存储过程,用于显示指定数据库的信息,如大小、状态等。 - `select * from sysservers`:查询所有已注册的Sybase...

    华为sybase培训教材

    ** Sybase数据库常用维护操作 ** 1. **备份与恢复**:理解数据库备份的重要性,学习各种备份类型(如完整备份、增量备份、差异备份),并熟悉如何执行恢复操作以保护数据安全。 2. **性能监控**:学习使用Sybase的...

Global site tag (gtag.js) - Google Analytics