SQLServer教程,sqlserver教程第三版清华出版社pd

在cmd中,怎么连接和执行sqlserver

1、打开CMD命令界面。

为通化等地区用户提供了全套网页设计制作服务,及通化网站建设行业解决方案。主营业务为成都网站制作、网站建设、外贸网站建设、通化网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

2、先我们可以运行 osql  ?/   ,这样就把所有可以通过CMD命令行操作sqlserver的命令显示出来。

3、写语句是请注意大小写。要按照下图中的写法写,不然会不识别。

4、然后我们知道connect 服务器是-S,登陆ID是-U,密码是-P ,运行 osql -S 【数据库服务器】 -U 【登陆用户名】 -P 【登陆密码】。

5、出现 1 表示连接成功,这时候你可以输入sql语句来进行操作了。

6、请记住在2时输入GO,执行Sql语句。

7、然后就可以开始使用SQL命令操作SqlServer数据库了。

怎样安装SQLserver2008个人版,本人是大学生,主要就是用SQLserver在自己电脑上做做实验,跪求详细教程

【系统要求】

--Windows Installer4.5

--.Net Framework3.5

--Windows Server2003 SP2以上系统

如果系统不符合要求,会出现下图的提示。

如果需要安装可以点击确定自动进行安装,也可以点击取消后自己手动进行安装。

----------------------

可以点击图片看大图

----------------------

【开始安装】

1,放入SQL Server 2008的安装光盘(这里用的是180天的评估版),自动运行就会启动,也可以双击光盘中的setup.exe开始安装程序。

2,安装程序按功能进行了分类,在左边选择“安装”,然后在右边的“全新的SQL Server独立安装或向现有安装添加功能”选项开始安装。

3,安装程序进行系统必备项的检测

4,选择版本,这里选企业评估版,如果您有序列号,也可以在这里输入。

5,许可条款

6,安装支持文件

7,第二次检测系统需求(与前面检测的内容不同)

8,与以往的SQL Server版本不同的是,SQL Server 2008默认没有选中任何安装选项,需要用户自己选择安装的内容。安装内容又分为: --实例功能:每个SQL Server 实例独有的部分 --共享功能:此计算机上所有SQL Server实例共享一份的功能

9,实例配置,选择默认实例还是命名实例,如果是命名实例要提供实例名。下面给出了实例ID和安装位置

10,这里详细的给出了各个成分在硬盘上的位置和占用的空间

11,配置各个服务使用的账户

12,数据库引擎配置,这里分为三部分 账户配置: SQL Server 的身份验证模式及SA的密码,不同的是SQL Server 2008不再默认把本地管理员组作为SQL Server的系统管理员,而是需要我们手动指定Windows账户作为SysAdmin服务器角色的成员。

数据目录: 与以往版本不同,这次SQL Server 2008分别设置了系统、临时和用户数据库的默认目录,使管理更灵活。

FileStream: 通过将 varbinary(max) 二进制大型对象 (BLOB) 数据以文件形式存储在文件系统上,FILESTREAM 使 SQL Server 数据库引擎和 NTFS 文件系统成为了一个整体。Transact-SQL 语句可以插入、更新、查询、搜索和备份 FILESTREAM 数据。通过 Win32 文件系统接口可以流式方式访问数据。

13,错误和使用情况报告,个人建议全选

14,第三次进行系统检测,这次是根据你的选项进行检测

15,这里是一个配置的汇总,要开始拷贝文件了

16,下面进入最耗时的文件拷贝和配置过程

17,安装完成

【安装感受】从安装程序看,感觉SQL Server 2008的设计更灵活、更精确,安装速度在我的笔记本上装的虚拟机(分配了768M内存)中比较流畅,感觉比2005要好。

sqlserver怎么创建存储过程

1、可视化创建

a.登录SQL Server

b.打开数据库==》要创建存储过程的数据库==》可编程性==》存储过程

c.选中“存储过程”右击 ,在系出现的对话框中选择“新建存储过程”

d.在右侧出现的对话框中填写具体存储过程内容完成后执行即可

2、代码创建

a.全手写代码

一、定义变量

--简单赋值 

declare @a int

set @a=5 

print @a 

--使用select语句赋值 

declare @user1 nvarchar(50) 

select @user1='张三'

print @user1 

declare @user2 nvarchar(50) 

select @user2 = Name from ST_User where ID=1 

print @user2 

--使用update语句赋值 

declare @user3 nvarchar(50) 

update ST_User set @user3 = Name where ID=1 

print @user3

二、表、临时表、表变量

--创建临时表1 

create table #DU_User1 

[ID] [int]  NOT NULL, 

[Oid] [int] NOT NULL, 

[Login] [nvarchar](50) NOT NULL, 

[Rtx] [nvarchar](4) NOT NULL, 

[Name] [nvarchar](5) NOT NULL, 

[Password] [nvarchar](max) NULL, 

[State] [nvarchar](8) NOT NULL

); 

--向临时表1插入一条记录 

insert into #DU_User1 (ID,Oid,[Login],Rtx,Name,[Password],State) values (100,2,'LS','0000','临时','321','特殊'); 

--从ST_User查询数据,填充至新生成的临时表 

select * into #DU_User2 from ST_User where ID8 

--查询并联合两临时表 

select * from #DU_User2 where ID3 union select * from #DU_User1 

--删除两临时表 

drop table #DU_User1 

drop table #DU_User2

--创建临时表 

CREATE TABLE #t 

[ID] [int] NOT NULL, 

[Oid] [int] NOT NULL, 

[Login] [nvarchar](50) NOT NULL, 

[Rtx] [nvarchar](4) NOT NULL, 

[Name] [nvarchar](5) NOT NULL, 

[Password] [nvarchar](max) NULL, 

[State] [nvarchar](8) NOT NULL, 

--将查询结果集(多条数据)插入临时表 

insert into #t select * from ST_User 

--不能这样插入 

--select * into #t from dbo.ST_User 

--添加一列,为int型自增长子段 

alter table #t add [myid] int NOT NULL IDENTITY(1,1) 

--添加一列,默认填充全球唯一标识 

alter table #t add [myid1] uniqueidentifier NOT NULL default(newid()) 

select * from #t 

drop table #t

--给查询结果集增加自增长列 

--无主键时: 

select IDENTITY(int,1,1)as ID, Name,[Login],[Password] into #t from ST_User 

select * from #t 

--有主键时: 

select (select SUM(1) from ST_User where ID= a.ID) as myID,* from ST_User a order by myID

--定义表变量 

declare @t table

id int not null, 

msg nvarchar(50) null

insert into @t values(1,'1') 

insert into @t values(2,'2') 

select * from @t

三、循环

--while循环计算1到100的和 

declare @a int

declare @sum int

set @a=1 

set @sum=0 

while @a=100 

begin

set @sum+=@a 

set @a+=1 

end

print @sum

四、条件语句

--if,else条件分支 

if(1+1=2) 

begin

print '对'

end

else

begin

print '错'

end

--when then条件分支 

declare @today int

declare @week nvarchar(3) 

set @today=3 

set @week=case

when @today=1 then '星期一'

when @today=2 then '星期二'

when @today=3 then '星期三'

when @today=4 then '星期四'

when @today=5 then '星期五'

when @today=6 then '星期六'

when @today=7 then '星期日'

else '值错误'

end

print @week

五、游标

declare @ID int

declare @Oid int

declare @Login varchar(50) 

--定义一个游标 

declare user_cur cursor for select ID,Oid,[Login] from ST_User 

--打开游标 

open user_cur 

while @@fetch_status=0 

begin

--读取游标 

fetch next from user_cur into @ID,@Oid,@Login 

print @ID 

--print @Login 

end

close user_cur 

--摧毁游标 

deallocate user_cur

六、触发器

触发器中的临时表:

Inserted 

存放进行insert和update 操作后的数据 

Deleted 

存放进行delete 和update操作前的数据

--创建触发器 

Create trigger User_OnUpdate  

On ST_User  

for Update 

As 

declare @msg nvarchar(50) 

--@msg记录修改情况 

select @msg = N'姓名从“' + Deleted.Name + N'”修改为“' + Inserted.Name + '”' from Inserted,Deleted 

--插入日志表 

insert into [LOG](MSG)values(@msg) 

--删除触发器 

drop trigger User_OnUpdate

七、存储过程

--创建带output参数的存储过程 

CREATE PROCEDURE PR_Sum 

@a int, 

@b int, 

@sum int output

AS

BEGIN

set @sum=@a+@b 

END

--创建Return返回值存储过程 

CREATE PROCEDURE PR_Sum2 

@a int, 

@b int

AS

BEGIN

Return @a+@b 

END

--执行存储过程获取output型返回值 

declare @mysum int

execute PR_Sum 1,2,@mysum output

print @mysum 

--执行存储过程获取Return型返回值 

declare @mysum2 int

execute @mysum2= PR_Sum2 1,2 

print @mysum2

八、自定义函数

函数的分类:

1)标量值函数

2)表值函数

a:内联表值函数

b:多语句表值函数

3)系统函数

--新建标量值函数 

create function FUNC_Sum1 

@a int, 

@b int

returns int

as

begin

return @a+@b 

end

--新建内联表值函数 

create function FUNC_UserTab_1 

@myId int

returns table

as

return (select * from ST_User where ID@myId) 

--新建多语句表值函数 

create function FUNC_UserTab_2 

@myId int

returns @t table

[ID] [int] NOT NULL, 

[Oid] [int] NOT NULL, 

[Login] [nvarchar](50) NOT NULL, 

[Rtx] [nvarchar](4) NOT NULL, 

[Name] [nvarchar](5) NOT NULL, 

[Password] [nvarchar](max) NULL, 

[State] [nvarchar](8) NOT NULL

as

begin

insert into @t select * from ST_User where ID@myId 

return

end

--调用表值函数 

select * from dbo.FUNC_UserTab_1(15) 

--调用标量值函数 

declare @s int

set @s=dbo.FUNC_Sum1(100,50) 

print @s 

--删除标量值函数 

drop function FUNC_Sum1

谈谈自定义函数与存储过程的区别:

一、自定义函数:

1. 可以返回表变量

2. 限制颇多,包括

不能使用output参数;

不能用临时表;

函数内部的操作不能影响到外部环境;

不能通过select返回结果集;

不能update,delete,数据库表;

3. 必须return 一个标量值或表变量

自定义函数一般用在复用度高,功能简单单一,争对性强的地方。

二、存储过程

1. 不能返回表变量

2. 限制少,可以执行对数据库表的操作,可以返回数据集

3. 可以return一个标量值,也可以省略return

 存储过程一般用在实现复杂的功能,数据操纵方面。


网站名称:SQLServer教程,sqlserver教程第三版清华出版社pd
网页网址:http://scyanting.com/article/dsecehh.html