跪求数据库存储过程详解!!

小弟最近在学习sqlserver数据库,存储过程不怎么搞的明白,求详细教程,书上说的不太清楚,比较笼统,看的不太明白,可以的话希望找个师傅,好好学习数据库
还有希望各位不要直接在复制粘贴,这样我也会,希望加点自己的见解内容

首先你要懂的sql语句,如果不懂,请先把这个学好再来学存储过程。
大部分存储过程的主要结构:
参数:即sql语句的条件,如select * from text where id=@id. @id就是参数。你在调用这个存储过程时就要传过来的数据。
复杂的存储过程结构:
触发器,游标.....这些就比较复杂点,通常是用来处理复杂的数据时使用。
触发器:简单点说就是一组存储过程一起执行。对了就过去,错了就返回。
其它的就要看你要怎么调用了,好好学吧追问

sql已经基本弄懂,简单的查询建表之类的也会,但是存储过程不怎么搞得懂

追答

给你个标准的写法:
Create PROCEDURE [dbo].[SP_Cource]
@ClassId int ---这儿为参数,即你要传过来的值
AS
BEGIN
SET NOCOUNT ON;
select * from test Where ClassId=@ClassId; ---这儿是你要写的sql语句,跟普通查询一样,只是它的值用参数代替
END

温馨提示:答案为网友推荐,仅供参考
第1个回答  2012-06-12
use student
/*1.创建一个存储过程my_proc,查询“学生表”中所有计算机系女生的学号、姓名、性别、年龄和所在院系。*/
create procedure my_proc
as
select 学号,姓名,性别,年龄,所在院系 from 学生表 where 性别='女'and 所在院系='计算机'
return

/*(2)执行存储过程*/
exec my_proc

/*3.修改存储过程,使其能够查询计算机系女生的所有基本信息*/
alter procedure my_proc
as
select * from 学生表 where 性别='女'and 所在院系='计算机'
return

exec my_proc
drop procedure my_proc

/*1 .带输入参数的存储过程
(1)创建一个存储过程my_procsex,使其能够查询“学生表”中男学生或女学生的学号、姓名、性别、年龄和所在院系
(2)执行存储过程*/
USE STUDENT
create procedure my_procsex
@sex char(2),
@sex2 char(2)
as
select 学号,姓名,性别,年龄,所在院系 from 学生表
where 性别=@sex or 性别=@sex2
return
drop procedure my_procsex
exec my_procsex @sex='男',@sex2='女'

/*创建一个存储过程my_procage,使其能够根据学生姓名,查询学生年龄。
(考虑当学生不存在时给出提示信息)*/
create procedure my_procage
@name char(20)
as
if not exists(
select 年龄 from 学生表 where 姓名=@name)
print '没有找到该学生信息'

return

exec my_procage @name='a'
drop procedure my_procage

/*1)创建一个存储过程my_procstatus,使其能够根据学生姓名,查询学生的选课信息。
(如果没有输入学生姓名,返回状态码55;如果输入的学生姓名不存在,则返回状态码-155)*/

drop procedure my_procstatus

create procedure my_procstatus
@name varchar(10)
as
if @name=''
return 55
select 成绩表.学号,课程号 from 成绩表,学生表 where
成绩表.学号=学生表.学号 and 学生表.姓名=@name
if not exists(
select 成绩表.学号,课程号 from 成绩表,学生表 where
成绩表.学号=学生表.学号 and 学生表.姓名=@name
)
return -155
select 成绩表.学号,课程号 from 成绩表,学生表 where
成绩表.学号=学生表.学号 and 学生表.姓名=@name

return

declare @status int
exec @status=my_procstatus @name=''
if @status=-155
print'没有找到'
if @status=55
print'没有输入名字'

/*在存储过程中使用临时表,不指定题目,请理解全局临时表与局部临时表的区别*/
create procedure my_procsave
as
select 姓名 from (select * from 学生表 where 所在院系='计算机')#A
where #A.性别='女'
return

exec my_procsave

drop procedure my_procsave
create procedure my_procsave
as
select 姓名 from (select * from 学生表 where 所在院系='计算机')##A
where ##A.性别='女'
return

exec my_procsave
第2个回答  2011-03-03
1、先学会基本的SQL语句写法,select insert delete update 。
2、学会一些函数的使用,如:select substr(A,1,1) from 表。
3、学习存储过程的简单编写,实现一些小功能,比如:统计一个库中的表的字符串用逗号隔开等等,期间学习写显性、隐性游标的编写还有循环语句、判断语句的使用。
4、学习其他知识,如:编写函数、包、索引、序列、触发器等等。
5、学习语句优化,数据备份恢复,大型数据库开发设计等等。
6、考个ocp、oca证。
第3个回答  2011-03-03
1、由A->B,(B,C)->A可得关系模式R的候选键为AC或BC,不难看出AC下最高为1Nf,当为BC时,最高为3Nf
2、一个一个试,(A,B) 有A->B,AB->E,此外不能推出C跟D,所以不是候选键;(C,D)有,CD->A,A->B,,AB->E所以是候选键; (A,D) 有A->B,AB->E,此外推不出C,所以不是候选键;(B,C)有BC->D,CD->A,A->B,AB->E,所以是候选键; (B,D)都推不出ACE所以不是;所以只有(C,D)跟 (B,C)
最高可达到3NF,由于是非主属性不传递依赖于主属性。。。

参考资料:百度一下

第4个回答  2021-02-04

没想到数据库存储数据的原理竟还能这样理解,这也太简单了吧!