一步一步学Linq to sql(五):存储过程

简介: 普通存储过程 create proc sp_singleresultset as set nocount on select * from customers 首先在查询分析器运行下面的代码来创建一个存储过程sp_singleresultset。

普通存储过程

create proc sp_singleresultset
as
set nocount on
select * from customers  

首先在查询分析器运行下面的代码来创建一个存储过程sp_singleresultset。然后打开IDE的服务器资源管理器,我们从存储过程中找到刚才创建的存储过程,然后拖动到设计视图。在方法面板中可以看到已经创建了一个sp_singleresultset的方法,如下图:

打开GuestBook.designer.cs,可以找到如下代码

		[global::System.Data.Linq.Mapping.FunctionAttribute(Name="dbo.sp_singleresultset")]
		public ISingleResult<sp_singleresultsetResult> sp_singleresultset()
		{
			IExecuteResult result = this.ExecuteMethodCall(this, ((MethodInfo)(MethodInfo.GetCurrentMethod())));
			return ((ISingleResult<sp_singleresultsetResult>)(result.ReturnValue));
		}

  然后调用

            GuestBookDataContext Book=new GuestBookDataContext();
            var GetResult = (from c in Book.sp_singleresultset()
                            where c.CustomerID.StartsWith("A")
                            select c).ToList();

结果如下

带参数和返回值的存储过程

首先还是在查询分析器中执行如下SQL

create proc [dbo].[sp_withreturnvalue]
@customerid nchar(5)
as
set nocount on
if exists (select 1 from customers where customerid = @customerid)
return 101
else
return 100

还是在IDE服务资源管理器中将存储过程拖进dbml文件中,然后在代码中进行调用

            string str = Book.sp_withreturnvalue("").ToString();
            str = str + Book.sp_withreturnvalue("ALFKI");

结果如下

使用存储过程新增数据 

在查询分析器中执行如下SQL

create proc sendmessage
@username varchar(50),
@message varchar(500)
as
insert into tbGuestBook
(id,username,posttime,[message],IsRequired,reply)
values
(newid(),@username,getdate(),@message,0,'')

然后,打开留言簿dbml,把存储过程从服务器资源管理器拖拽到设计视图上。右键点击tbGuestBook实体类,选择配置行为。如下图,为插入操作选择刚才创建的存储过程方法,并进行参数匹配:

这是添加之前, 可以参看 Linq To SQL(三):增删查改 http://www.cnblogs.com/aehyok/archive/2013/04/12/3017545.html

        public ActionResult SaveBook(tbGuestBook tb)
        {
            tbGuestBook gb = null;
            if (tb.ID.ToString() != "00000000-0000-0000-0000-000000000000")
            {
                gb = ctx.tbGuestBook.Single(b => b.ID == new Guid(tb.ID.ToString()));
                gb.PostTime = DateTime.Now;
                gb.UserName = tb.UserName;
                gb.Message = tb.Message;
                ctx.SubmitChanges();
                return Index();
            }
            else
            {
                tb.ID = Guid.NewGuid();
                tb.IsRequired = false;
                tb.PostTime = DateTime.Now;
                ctx.tbGuestBook.InsertOnSubmit(tb);
                ctx.SubmitChanges();
            }
                return Index();
        }

  看else下面tb实体类,还需要给ID,PostTime,IsRequired赋值,这样才能添加操作。

现在可以修改代码,将else代码改为

                ctx.tbGuestBook.InsertOnSubmit(tb);
                ctx.SubmitChanges();

  

tb实体只需要两个参数即可添加到数据库中。

 

目录
相关文章
|
15小时前
|
存储 SQL 数据库
SQL Server 临时存储过程及示例
SQL Server 临时存储过程及示例
12 3
|
5月前
|
存储 SQL 数据库
数据库sql语句-----游标和存储过程
数据库sql语句-----游标和存储过程
47 1
|
2天前
|
存储 SQL 数据库
使用SQL创建视图和存储过程
使用SQL创建视图和存储过程
9 0
|
2月前
|
存储 SQL 安全
【数据库高手的秘密武器:深度解析SQL视图与存储过程的魅力——封装复杂逻辑,实现代码高复用性的终极指南】
【8月更文挑战第31天】本文通过具体代码示例介绍 SQL 视图与存储过程的创建及应用优势。视图作为虚拟表,可简化复杂查询并提升代码可维护性;存储过程则预编译 SQL 语句,支持复杂逻辑与事务处理,增强代码复用性和安全性。通过创建视图 `high_earners` 和存储过程 `get_employee_details` 及 `update_salary` 的实例,展示了二者在实际项目中的强大功能。
30 1
|
2月前
|
JSON 数据格式 Java
化繁为简的魔法:Struts 2 与 JSON 联手打造超流畅数据交换体验,让应用飞起来!
【8月更文挑战第31天】在现代 Web 开发中,JSON 成为数据交换的主流格式,以其轻量、易读和易解析的特点受到青睐。Struts 2 内置对 JSON 的支持,结合 Jackson 库可便捷实现数据传输。本文通过具体示例展示了如何在 Struts 2 中进行 JSON 数据的序列化与反序列化,并结合 AJAX 技术提升 Web 应用的响应速度和用户体验。
84 0
|
2月前
|
存储 SQL 数据库
如何使用 SQL Server 创建存储过程?
【8月更文挑战第31天】
80 0
|
4月前
|
存储 SQL 数据库
SQL 语言:存储过程和触发器
SQL 语言:存储过程和触发器
62 6
|
4月前
|
存储 SQL Oracle
oracle 存储过程导出sql语句 导出为文件
oracle 存储过程导出sql语句 导出为文件
166 0
|
5月前
|
存储 SQL
SQL Server 存储过程 触发器 事务处理
SQL Server 存储过程 触发器 事务处理
|
存储 SQL
sql_存储过程、函数、分支、循环
sql_存储过程、函数、分支、循环
129 0