`

mssql:t-sql;创建表;给表添加约束;使用变量;事务,索引,视图;存储过程;触发器trigger

 
阅读更多
1 t-sql;
select * from table1;
insert into table1(name,pwd) values('csj','csj');
update table1 set pwd='css' where name='csj';
delete from table1 wherename='csj';
select top 3 * from stu order bystuno desc; --desc降序排列,asc为升序;

定义别名:select name as names from users
输出语句:print 'csj' + @@rowcount
将数值转换成字符串:convert(varchar(5),@@error);
最后插入的标识值:@@identity
 批处理语句:GO是批处理的结束;
条件:in; not in;=;<>;
   exists;not exists
declare @age int
 select @age=stuage from stuinfo where stuname='csj'
select * from stuinfo where stuname=@age

逻辑控制语句:
  1 条件:
    if(@age>90)
语句块
else
语句块

   if(条件)
    begin
语句1
语句2
.......
end
else
 begin
语句1
语句2
.......
end
2循环语句
      while(@age >90)
 begin
语句1
语句2
.......
end
3 case 多分支语句
select stuno, case
when age1=90 then 结果1
when age1=80 then 结果2
end
from stum


数据库文件的组成:
  主数据库文件:*.mdf
  次要数据文件:*.ndf
  日志文件:*.ldf
if(select* from sysdatabase where name=db1
create database db1
drop database db1
2 创建表
 use master --设置当前数据库为master
 if exists (select * from sysobjects where name='table1') --检查要创建的表是否存在,若存在删除;
drop table table1
create table table1
(
user char(7) not null,
pwd char(6) not null
)

droptable table1

给表添加约束
  约束类型:目的是确保表中数据的完整性;
  主健约束:要求主健列唯一且不为空;
  唯一约束:要求列唯一可为空,只有一个空值;
  检查约束:某列取值范围限制,格式限制等;
  默认约束:某列默认值,如男性较多,默认为男;

  添加约束:alter table table1
add constraintpk_name primary key (name) --添加主健约束,名称作为主健;
alter table table1
add constraintpk_nameunique (name) --添加唯一约束,名称不能重复;
alter table table1
add constraint df_address default('地点不详') for saddress --添加默认约束,地点不详;
   alter table table1
add constraint ck_age check (ages between 20 and 60)--添加检查约束,要求年龄在20-60间;
   alter table table1
add constraint fk_stuno foreing key(stuno) references table2(stuno) --添加外健约束,主表table2和从表table1建立关系,通过stuno;

  删除约束: alter table table1
drop constraint pk_name;

4 使用变量
局部变量的名称必须用@作前缀;
全局变量的名称必须用@@作前缀;
  declare @username varchar(8)
set @username='csj'
select * from table1 where username=@username


全局变量的名称必须用@@作前缀;
@@ROWCOUNT受一个SQL语句景响的行数;
@@ERROR最后一个T-SQL错误的错误号;

5 事务,索引,视图;
开始事务:begin transaction
  提交事务:commit transaction
  回滚事务:rollback transaction

begin transaction
declare @errorsum int
语句块
set @errorsum=@errorsum + @@error
   if @errorsum <>0
begin
rollback transaction
end
else
begin
commit transaction
end
---------------------------------------
视图
create view view_name
as
select * from sql语句
 --------------------
  存储过程
exec proc_name 60,'csj'

if exists (select * from sysobjects where
   create proc proc_name
@no int,
@name
as
语句块
  ---------------------------------------------
触发器:是在对表执行插入,更新,删除操作时自动执行的存储过程;
if exists (select name from sysobjects where name='trigger_name')
drop trigger trigger_name

create trigger trigger_name
on table_name
for insert / delete/update
as
语句块
-----------------------------------------------------------------
create trigger trigger_name
on table_name
for insert
as
if(@type='zhiqu')
update bank set currentmoney=currentmoney -@outmoney where cordid=@id
else
update bank set currentmoney=currentmoney +@outmoney where cordid=@id
go
-- 当向这个表插入记录时,有自己动启动触发器;

创建删除触发器;
创建更新触发器;

========================================
游标:
使用游标有四种基本的步骤:声明游标、打开游标、提取数据、关闭游标。
1 声明游标:
DECLARE CustomerCursor CURSOR FOR
SELECT acct_no,name,balance
FROM customer
WHERE province="北京";
2 打开游标
OPEN CustomerCursor;
3 提取数据
当用OPEN语句打开了游标并在数据库中执行了查询后,您不能立即利用在查询结果集中的数据。您必须用FETCH语句来取得数据。一条FETCH语句一次可以将一条记录放入程序员指定的变量中。事实上,FETCH语句是游标使用的核心
4 关闭游标 :CLOSE CustomerCursor

 


原理:游标就是把数据按照指定要求提取出相应的数据集,然后逐条进行数据处理。
1.1游标的概念
游标(Cursor)它使用户可逐行访问由SQL Server返回的结果集。使用游标(cursor)的一个主要的原因就是把集合操作转换成单个记录处理方式。用SQL语言从数据库中检索数据后,结果放在内存的一块区域中,且结果往往是一个含有多个记录的集合。游标机制允许用户在SQL server内逐行地访问这些记录,按照用户自己的意愿来显示和处理这些记录。
1.2 游标的优点
从游标定义可以得到游标的如下优点,这些优点使游标在实际应用中发挥了重要作用:
1)允许程序对由查询语句select返回的行集合中的每一行执行相同或不同的操作,而不是对整个行集合执行同一个操作。
2)提供对基于游标位置的表中的行进行删除和更新的能力。
3)游标实际上作为面向集合的数据库管理系统(RDBMS)和面向行的程序设计之间的桥梁,使这两种处理方式通过游标沟通起来。
1.3 游标的使用
讲了这个多游标的优点,现在我们就亲自来揭开游标的神秘的面纱。
使用游标的顺序: 声名游标、打开游标、读取数据、关闭游标、删除游标。
1.3.1声明游标
最简单游标声明:DECLARE <游标名>CURSOR FOR<SELECT语句>;
其中select语句可以是简单查询,也可以是复杂的接连查询和嵌套查询

1.3.2 打开游标
非常简单,我们就打开刚才我们声明的游标mycursor
OPEN mycursor
1.3.3读取数据
FETCH [ NEXT | PRIOR | FIRST | LAST] FROM { 游标名 | @游标变量名 } [ INTO @变量名 [,…] ]
参数说明:
NEXT 取下一行的数据,并把下一行作为当前行(递增)。由于打开游标后,行指针是指向该游标第1行之前,所以第一次执行FETCH NEXT操作将取得游标集中的第1行数据。NEXT为默认的游标提取选项。
INTO @变量名[,…] 把提取操作的列数据放到局部变量中。
列表中的各个变量从左到右与游标结果集中的相应列相关联。
各变量的数据类型必须与相应的结果列的数据类型匹配或是结果列数据类型所支持的隐性转换。变量的数目必须与游标选择列表中的列的数目一致。
1.3.4关闭游标
CLOSE mycursor
1.3.5删除游标
DEALLOCATE mycursor

本文来源于Woody的鸟窝(Woody's Blog) http://www.smartgz.com, 原文地址:http://www.smartgz.com/blog/Article/976.asp


给出具体的例子:
declare @id nvarchar(20) --定义变量来保存ID号
declare @A float --定义变量来保存值
declare mycursor cursor for select * from tb_c --为所获得的数据集指定游标
open mycursor --打开游标
fetch next from mycursor into @id,@A --开始抓第一条数据
while(@@fetch_status=0) --如果数据集里一直有数据
begin
select tb_b.name,(tb_b.gz + @A) from tb_b where tb_b.id = @id --开始做想做的事(什么更新呀,删除呀)
fetch next from mycursor into @id,@A --跳到下一条数据
end
close mycursor --关闭游标
deallocate mycursor --删除游标

实例:
use database1
declare my_cursor cursor scroll dynamic
/**//*scroll表示可随意移动游标指 针(否则只能向前),dynamic表示可以读写游标(否则游标只读)*/
for
select productname from product

open my_cursor
declare @pname sysname
fetch next from my_cursor into @pname
while(@@fetch_status=0)
begin
print 'Product Name: ' + @pname
fetch next from my_cursor into @pname
end
fetch first from my_cursor into @pname
print @pname
/**//*update product set productname='zzg' where current of my_cursor */
/**//*delete from product where current of my_cursor */
close my_cursor
deallocate my_cursor

分享到:
评论

相关推荐

    Inside Microsoft SQL Server 2005: T-SQL Programming

    3. **存储过程和触发器**:T-SQL是创建存储过程和触发器的主要语言。通过学习如何编写和优化存储过程,你可以提高代码复用性和系统性能。触发器则可以用来实现数据完整性检查和业务逻辑。 4. **用户定义函数**:...

    mssql-jdbc-6.1.0.jre8-API文档-中英对照版.zip

    赠送jar包:mssql-jdbc-6.1.0.jre8.jar; 赠送原API文档:mssql-jdbc-6.1.0.jre8-javadoc.jar; 赠送源代码:mssql-jdbc-6.1.0.jre8-sources.jar; 赠送Maven依赖信息文件:mssql-jdbc-6.1.0.jre8.pom; 包含翻译后...

    mssql-jdbc-8.2.0.jre8-API文档-中文版.zip

    赠送jar包:mssql-jdbc-8.2.0.jre8.jar; 赠送原API文档:mssql-jdbc-8.2.0.jre8-javadoc.jar; 赠送源代码:mssql-jdbc-8.2.0.jre8-sources.jar; 赠送Maven依赖信息文件:mssql-jdbc-8.2.0.jre8.pom; 包含翻译后...

    Microsoft SQL Server 2005技术内幕:T-SQL查询 pdf 中文版 2

    Microsoft SQL Server 2005技术内幕:T-SQL查询 pdf 中文版 第二部分 第一部分地址:http://download.csdn.net/source/2684220

    Microsoft SQL Server 2008技术内幕:T-SQL查询

    T-SQL是SQL Server的主要编程语言,用于创建、修改和管理SQL Server中的数据库对象,如表、视图、存储过程等,同时支持数据查询、更新、删除和事务处理。在SQL Server 2008中,T-SQL得到了进一步的增强和优化,以...

    mssql-jdbc-8.2.0.jre8-API文档-中英对照版.zip

    赠送jar包:mssql-jdbc-8.2.0.jre8.jar; 赠送原API文档:mssql-jdbc-8.2.0.jre8-javadoc.jar; 赠送源代码:mssql-jdbc-8.2.0.jre8-sources.jar; 赠送Maven依赖信息文件:mssql-jdbc-8.2.0.jre8.pom; 包含翻译后...

    mssql-jdbc-6.2.1.jre7-API文档-中文版.zip

    赠送jar包:mssql-jdbc-6.2.1.jre7.jar; 赠送原API文档:mssql-jdbc-6.2.1.jre7-javadoc.jar; 赠送源代码:mssql-jdbc-6.2.1.jre7-sources.jar; 赠送Maven依赖信息文件:mssql-jdbc-6.2.1.jre7.pom; 包含翻译后...

    Microsoft SQL Server 2005技术内幕:T-SQL查询 pdf 中文版 1

    Microsoft SQL Server 2005技术内幕:T-SQL查询 pdf 中文版 1 第一部分 第二部分地址:http://download.csdn.net/source/2684248

    SQLSERVER官方驱动 jtds-1.3.1 mssql-jdbc-7.0.0.jre8 sqljdbc42

    String url = "jdbc:sqlserver://localhost:1433;databaseName=myDatabase"; String username = "myUsername"; String password = "myPassword"; try (Connection conn = DriverManager.getConnection(url, ...

    mssql-jdbc-6.2.1.jre7-API文档-中英对照版.zip

    赠送jar包:mssql-jdbc-6.2.1.jre7.jar; 赠送原API文档:mssql-jdbc-6.2.1.jre7-javadoc.jar; 赠送源代码:mssql-jdbc-6.2.1.jre7-sources.jar; 赠送Maven依赖信息文件:mssql-jdbc-6.2.1.jre7.pom; 包含翻译后...

    Transact-SQL全

    Transact-SQL(T-SQL)是Microsoft SQL Server数据库管理系统中的核心查询语言,它是SQL(结构化查询语言)的一个扩展版本,用于执行各种数据库操作,包括数据查询、数据更新、存储过程的创建与执行、事务控制等。T-...

    Sql Server 数据库视图 索引等

    根据给定的文件信息,我们可以总结出以下几个关键的知识点: ...这些知识点涵盖了SQL Server数据库中的视图、索引、存储过程、事务、触发器以及内置函数等内容,对于理解和应用SQL Server数据库非常有帮助。

    【MSSQLServer】 T-SQL 整理

    在数据库管理领域,Microsoft SQL Server(简称MSSQLServer)是一款广泛使用的数据库管理系统,而T-SQL(Transact-SQL)是其核心的编程语言,用于执行数据查询、更新、插入和删除操作,以及创建和管理数据库对象。...

    MSSQL加密/恢复存储过程、视图、触发器的存储过程

    标题中的“MSSQL加密/恢复存储过程、视图、触发器的存储过程”涉及到的是SQL Server数据库管理系统中的一种安全措施,即对数据库对象(如存储过程、视图和触发器)进行加密和解密的操作。这主要是为了保护敏感数据和...

    mssql-jdbc-10.2.0.jre8.jar jre11,jre17

    java jdbc方式连接mysql的驱动,来自MS官网下载地址。 https://docs.microsoft.com/zh-cn/sql/connect/jdbc/download-microsoft-jdbc-driver-for-sql-server?view=sql-server-ver15

    mssql-jdbc-6.4.0.jre7.jar

    Microsoft SQL Server JDBC 驱动程序 mssql-jdbc-6.4.0.jre7.jar 希望可以帮助到大家。

    sqljdbc_7.4.1.0_enu.tar.gz、mssql-jdbc-7.4.1.jre8.jar 等

    标题中的"sqljdbc_7.4.1.0_enu.tar.gz"是一个包含SQL Server JDBC驱动的压缩包,这是微软官方提供的用于Java应用程序与Microsoft SQL Server数据库之间进行数据交互的驱动程序。"enu"通常代表"English",意味着这是...

    SQL Server_JDBC驱动【mssql-jdbc-6.4.0.jre8.jar】.rar

    SQL Server JDBC驱动还支持一些高级功能,如批处理、存储过程调用、游标、预编译的`PreparedStatement`、JDBC连接池等。这些特性可以帮助优化性能并简化代码。 总之,`mssql-jdbc-6.4.0.jre8.jar`是Java连接SQL ...

    MSSQL存储过程解密工具SQL SERVER

    "MSSQL存储过程解密工具SQL SERVER"就是为了应对这种情况而设计的。 SQL Decryptor是一款专为了解密SQL Server中的加密存储过程、函数等数据库对象而开发的软件。这款工具的主要功能是帮助数据库管理员和开发者恢复...

    mssql-jdbc-8.4.0.jre8.jar

    jdk1.8可使用的jdbc驱动... DriverManager:负责加载各种不同驱动程序(Driver),并根据不同的请求,向调用者返回相应的数据库连接(Connection)。Driver:驱动程序,会将自身加载到DriverManager中去,并处理...

Global site tag (gtag.js) - Google Analytics