WebService总结(2017/11/12)

一、概述

平台:VS2015

语言:C#

技术:ELINQ

数据库:ORACLE

成果:一个能实现对数据库中的表进行增删改查功能的接口

接口返回的结果:JSON格式的结果集


二、流程

1.添加网站,新建一个web服务。


2.添加引用:System.Data.OracleClient;通过Nuget安装ELinq包和Newtonsoft.Json包;


3.配置数据库连接信息。在Web.config文件中添加连接字符串:





4.先添加实体类,在其中添加命名空间:using Nlite.Data;并映射数据库中的表,原则上实体类名要和表名一致或遵循一定规律。例如casetype类(映射Oracle数据库中的s_casetype表):

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using NLite.Data;

///

/// casetype的摘要说明

///

[Table("s_casetype")]

public class casetype

{

///

///案件类型代码

///

[Id]

publicstring typeid { get; set; }

///

///父类的代码

///

publicstring pid { get; set; }

///

///案件类型名称

///

publicstring typename { get; set; }

///

///说明

///

publicstring remark { get; set; }

///

///树类型,0是事件,1是部件

///

publicstring treetype { get; set; }

///

///区级TYPEID

///

publicstring qtypeid { get; set; }

}

其次,添加一个展示指定输出信息的类。例如caseinfo类:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

///

/// CaseInfo的摘要说明,用于输出的类

///

public class CaseInfo

{

///

///案件代码

///

publicstring typeid { get; set; }

///

///父类的案件代码

///

publicstring pid { get; set; }

///

///案件类型名称

///

publicstring typename { get; set; }

///

///案件说明

///

publicstring remark { get; set; }

///

///树类型,0是事件,1是部件

///

publicstring treetype { get; set; }

///

///区级TYPEID

///

publicstring qtypeid { get; set; }

}

接着添加了HeadData类,返回操作成功与否的信息;

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

///

/// HeadData的摘要说明

///返回操作是否成功的提示信息

///

public class HeadData

{

///

///一个返回值,0表示成功

///

publicint Code { get; set; }

///

///错误的信息

///

privatestring mMsg = "";

///

///错误信息

///

publicstring Msg { get { return mMsg; } set { mMsg = value; } }

privateDateTime mServerTime = DateTime.Now;

///

///返回服务器时间

///

publicDateTime ServerTime { get { return mServerTime; } set { mServerTime = value; }}

///

///返回结果的数量

///

publicint Count { get; set; }

///

///业务逻辑处理结果

///

publicbool Result { get; set; }

}

public enum codetype

{

///

///执行成功

///

CODE_OK = 0,

///

///执行失败

///

CODE_ERROR = 1

}

再添加Returntype类,以JSON格式返回结果集。

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using Newtonsoft.Json;

using Newtonsoft.Json.Converters;

using Newtonsoft.Json.Serialization;

///

/// returntype的摘要说明

///

public class returntype

{

publicstatic void Json(HttpResponse Resp, HeadData head, object data)

{

if (string.IsNullOrEmpty(Resp.ContentType)) //为啥要判断一下?

{

Resp.ContentType = "text/json";

}

object objData = new//输出的内容详情

{

Code = head.Code,

Errmsg = head.Msg,

ServerTime = head.ServerTime,

Result = head.Result,

Count = head.Count,

Data = data

};

//设置时间格式

IsoDateTimeConverter timeFormat = new IsoDateTimeConverter(); //实例化一个标准数据时间格式的对象

timeFormat.DateTimeFormat = "yyyy-MM-dd HH:mm:ss";//指定输出的时间格式

IList converts = new List(); //初始化实例,表示可按照索引单独访问的一组对象,转换对象为JSON,没懂?

converts.Add(timeFormat);//添加时间格式,没懂?

//设置输出语句

Resp.Write(JsonConvert.SerializeObject(objData, Newtonsoft.Json.Formatting.None,

new JsonSerializerSettings()

{

ReferenceLoopHandling = ReferenceLoopHandling.Ignore,

ContractResolver = new CamelCasePropertyNamesContractResolver(),

Converters =converts

}));//将字符串写如HTTP响应输出流,JsonConvert类提供.NET和JSON类型转换的方法:SerializeObject方法(具体连载对象,默认格式,初始化一个JSON连载设置)

}

}


5.再添加SsisDbContext类,在这个类中连接数据库(创建DbConfiguration对象、设置SQL语句输出日志、注册实体到数据表的映射关系),然后创建DbSet对象(表示用于执行插入、读取、更新和删除操作的类型化实体集,对实体集的所有增删改查操作会立即同步到数据库对应的表中)。


5.1映射关系总结:

一对一:第一种是一对一主键关联,要求两个主键必须完全一致;第二种是一对一外键关联(未懂)。例子,一个球队对应一个地址。

一对多:例如,从球队角度来说,一个球队拥有多个球员

多对一:例如,从球员角度来说,多个球员属于一个球队

多对多:如学生与选修课之间的关系,一个学生可以选择多门选修课,每门选修课又可以被多名学生选择。一般是采用中间表的方式处理,转化为两个一对多。

代码示例:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using NLite;

using NLite.Data;

///

/// SsisDbContext的摘要说明

///

public class SsisDbContext:DbContext

{

conststring CONNECTIONNAME = "Northwind";

staticNLite.Data.DbConfiguration dbConfig = NLite.Data.DbConfiguration.Configure(CONNECTIONNAME)

.SetSqlLogger(() => new SqlLog(Console.Out))

.AddClass()

.AddClass(m =>

{

m.OneToOne(e => e.CaseType).ThisKey(e =>e.TYPEID).OtherKey(e => e.TYPEID);

})

.AddClass(m =>

{

m.ManyToOne(e => e.CaseTypeList).ThisKey(e =>e.TYPEID).OtherKey(e => e.TYPEID);

});//设置SQL语句输出日志,注册实体到数据表的映射关系,从caseinfo的角度来说,caseinfomodel与casetypemodel是一对一的关系

publicSsisDbContext():base(dbConfig)//根据DbConfiguration创建DbContext的对象

{

//

// TODO:在此处添加构造函数逻辑

//ELinq

}

publicreadonly IDbSet CaseInformation;//表示用于执行插入、读取、更新和删除操作的类型化实体集,对实体集中所有的增删改查操作会立即同步到数据库对应的表中

publicreadonly IDbSet CASEINFO;

publicreadonly IDbSet CASETYPE;

}


6.主体代码编写(实现增删改查)

在using( SsisDbContext db = new SsisDbContext()) {}中写基于ELINQ技术的增删改查的语句。


6.1查询:

varquery= db.caseinformation.where(condition1 ).select(c=> new OutClass{ ….}).ToList();

其中where语句中写筛选条件,select语句将序列中的每个元素投影到新表中,tolist语句将表转换为集合


6.2插入-insert:

vara =newcasetype

{

typeid = typeidval,

pid = pidval,

typename =typenameval,

remark = remarkval,

treetype =treetypeval,

qtypeid =qtypeidval

};

db.CaseInformation.Insert(a);//插入语句


6.3更新修改-update(会返回一个INT型的值):

intcount =

db.CaseInformation.Update(new{ typename = typenameval }, (p => p.typeid ==typeidval && p.pid == pidval && p.treetype ==treetypeval));//执行更新,并返回进行更新的记录数。


6.4删除-delete(返回一个INT型的值)

intcount =

db.CaseInformation.Delete(p => p.typeid == typeidval && p.pid ==

pidval && p.treetype == treetypeval);//执行删除操作,并返回删除记录的数量


6.5多表联合查询

先搞明白表与表之间的映射关系,是一对一,还是多对一,或者一对多;

然后使用include语句立即加载针对特定关系检索的对象;

接着输出指定查询信息。

varvlist = db.CASEINFO.Include(e => e.CaseType).Where(c

=> c.DOCID == docid).Select(c =>newCaseDetail()

{

DOCID = c.DOCID,

typename =c.CaseType.TYPENAME

}).ToList();//通过docid查询对应的案件记录,并将序列中的每个元素投射到新表中


7.注意事项

1)一定要如下设置异常信息捕捉,以便于查看BUG原因!!!

catch(Exceptionex)//异常信息

{

hd.Msg = ex.ToString();//数据库自带的异常信息

returntype.Json(resp, hd,null);//返回JSON格式结果集

}

2)入参在表中是什么类型,就设置为对应类型,不要擅自改动!!!


8.在IIS上发布出来

1)添加网站

2)设置权限

3)添加默认文档

4)选择网站对应的应用程序池,右键-高级设置:,接着设置“启用32位应用程序”为true,点击确定

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,718评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,683评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,207评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,755评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,862评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,050评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,136评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,882评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,330评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,651评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,789评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,477评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,135评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,864评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,099评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,598评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,697评论 2 351

推荐阅读更多精彩内容