public class HomeController : Controller
{
//
// GET: /Home/
empentity entity = new empentity();
public ActionResult Index()
{
List<EmpCount> lst = (from m in entity.emp.ToList()
join n in entity.dept.ToList() on m.DEPTNO equals n.DEPTNO
group m by m.DEPTNO into newEmp
select new EmpCount
{
DeptID = newEmp.Key,
DName = entity.dept.Where(p => p.DEPTNO == newEmp.Key).FirstOrDefault().DNAME,
Count = newEmp.Count()
}).ToList(); return View(lst);
}
public ActionResult SelSal()
{
List<emp> lst = (from s in entity.emp.ToList()
select s).ToList();
return View(lst);
}
public ActionResult SelEmpSal()
{
ViewBag.SalgradeId = new SelectList(entity.salgrade.ToList(), "SalgradeId", "GRADE");
return View(entity.emp.ToList());
}
[HttpPost]
public ActionResult SelEmpSal(int SalgradeId)
{
ViewBag.SalgradeId = new SelectList(entity.salgrade.ToList(), "SalgradeId", "GRADE");
Salgrade lst = (from s in entity.salgrade.ToList()
where s.SalgradeId == SalgradeId
select s).FirstOrDefault();
int Max = lst.HISAL;
int Min = lst.LOSAL;
List<emp> lst1 = (from m in entity.emp.ToList()
where m.SAL > Min && m.SAL < Max
select m).ToList();
return View("SelEmpSal", lst1); }
public ActionResult EmpSal1()
{
Salgrade sal = (from s in entity.salgrade.ToList()
where s.GRADE.Contains("二级")
select s).FirstOrDefault();
int Max = sal.HISAL;
int Min = sal.LOSAL;
List<emp> lst = (from i in entity.emp.ToList()
where i.SAL > Min && i.SAL < Max
select i).ToList();
return View(lst);
}
public ActionResult EmpCount()
{
Salgrade sal = (from s in entity.salgrade.ToList()
where s.GRADE.Contains("一级")
select s).FirstOrDefault();
int Max = sal.HISAL;
int Min = sal.LOSAL;
List<EmpCount> count = (from m in entity.emp.ToList()
join n in entity.dept.ToList() on m.DEPTNO equals n.DEPTNO
where m.SAL > Min && m.SAL < Max
group m by m.DEPTNO into newEmp
select new EmpCount
{
DeptID = newEmp.Key,
DName = entity.dept.Where(p => p.DEPTNO == newEmp.Key).FirstOrDefault().DNAME,
Count = newEmp.Count()
}).ToList();
return View(count);
}
public ActionResult EmpSal2()
{
Salgrade sal = (from s in entity.salgrade.ToList()
where s.GRADE == "二级"
select s).FirstOrDefault();
int Max = sal.HISAL;
int Min = sal.LOSAL;
List<emp> lst = (from i in entity.emp.ToList()
where i.SAL > Min && i.SAL < Max
select i).ToList();
return View(lst);
}
public ActionResult EmpCount1()
{
Salgrade sal = (from s in entity.salgrade.ToList()
where s.GRADE == "一级"
select s).FirstOrDefault();
int Max = sal.HISAL;
int Min = sal.LOSAL;
List<EmpCount> lst = (from m in entity.emp.ToList()
join n in entity.dept.ToList() on m.DEPTNO equals n.DEPTNO
where m.SAL>Min&&m.SAL<Max
group m by m.DEPTNO into newEmp
select new EmpCount
{
DeptID = newEmp.Key,
DName = entity.dept.Where(p => p.DEPTNO == newEmp.Key).FirstOrDefault().DNAME,
Count = newEmp.Count()
}).ToList();
return View(lst);
}
public ActionResult EmpLd()
{
List<emp> lst = (from n in entity.emp.ToList()
join m in entity.emp.ToList() on n.EMPNO equals m.MGR
select n).Distinct().ToList();
ViewBag.DEPTNO = new SelectList(entity.dept.ToList(), "DEPTNO", "DNAME");
ViewBag.SalgradeId = new SelectList(entity.salgrade.ToList(), "SalgradeId", "GRADE");
return View(lst);
}
[HttpPost]
public ActionResult EmpLd1(int DEPTNO, int SalgradeId)
{
ViewBag.DEPTNO = new SelectList(entity.dept.ToList(), "DEPTNO", "DNAME");
ViewBag.SalgradeId = new SelectList(entity.salgrade.ToList(), "SalgradeId", "GRADE");
Salgrade sal = entity.salgrade.Find(SalgradeId);
int Max = sal.HISAL;
int Min = sal.LOSAL;
List<emp> lst = (from n in entity.emp.ToList()
join m in entity.emp.ToList() on n.EMPNO equals m.MGR
where n.SAL > Min && n.SAL < Max && n.DEPTNO == DEPTNO
select n).Distinct().ToList();
foreach (emp item in lst)
{
emp s = entity.emp.Find(item.EMPNO);
s.SAL = item.SAL + ;
}
entity.SaveChanges();
return RedirectToAction("EmpLd");
}
public ActionResult EmpLd2()
{
List<emp> ld = (from m in entity.emp.ToList()
join n in entity.emp.ToList() on m.EMPNO equals n.MGR
select m).Distinct().ToList();
ViewBag.DEPTNO = new SelectList(entity.dept.ToList(), "DEPTNO", "DNAME");
ViewBag.SalgradeId = new SelectList(entity.salgrade.ToList(), "SalgradeId", "GRADE");
return View(ld);
}
[HttpPost]
public ActionResult EmpLd3(int DEPTNO, int SalgradeId)
{
ViewBag.DEPTNO = new SelectList(entity.dept.ToList(), "DEPTNO", "DNAME");
ViewBag.SalgradeId = new SelectList(entity.salgrade.ToList(), "SalgradeId", "GRADE");
Salgrade sal = entity.salgrade.Find(SalgradeId);
List<emp> lst = (from n in entity.emp.ToList()
join m in entity.emp.ToList() on n.EMPNO equals m.MGR
where n.SAL > sal.LOSAL && n.SAL < sal.HISAL && n.DEPTNO == DEPTNO
select n).Distinct().ToList();
foreach (emp item in lst)
{
emp s = entity.emp.Find(item.EMPNO);
s.SAL = item.SAL + ;
}
entity.SaveChanges();
return RedirectToAction("EmpLd2");
}
}

Linq to SQL 练习的更多相关文章

  1. LINQ to SQL语句(7)之Exists/In/Any/All/Contains

    适用场景:用于判断集合中元素,进一步缩小范围. Any 说明:用于判断集合中是否有元素满足某一条件:不延迟.(若条件为空,则集合只要不为空就返回True,否则为False).有2种形式,分别为简单形式 ...

  2. 年终巨献 史上最全 ——LINQ to SQL语句

    LINQ to SQL语句(1)之Where 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句.Where操 ...

  3. LINQ to SQL语句(20)之存储过程

    在我们编写程序中,往往需要一些存储过程,在LINQ to SQL中怎么使用呢?也许比原来的更简单些.下面我们以NORTHWND.MDF数据库中自带的几个存储过程来理解一下. 1.标量返回 在数据库中, ...

  4. LINQ to SQL语句(19)之ADO.NET与LINQ to SQL

    它基于由 ADO.NET 提供程序模型提供的服务.因此,我们可以将 LINQ to SQL 代码与现有的 ADO.Net 应用程序混合在一起,将当前 ADO.NET 解决方案迁移到 LINQ to S ...

  5. LINQ to SQL语句(18)之运算符转换

    运算符转换 1.AsEnumerable:将类型转换为泛型 IEnumerable 使用 AsEnumerable<TSource> 可返回类型化为泛型 IEnumerable 的参数.在 ...

  6. LINQ to SQL语句(17)之对象加载

    对象加载 延迟加载 在查询某对象时,实际上你只查询该对象.不会同时自动获取这个对象.这就是延迟加载. 例如,您可能需要查看客户数据和订单数据.你最初不一定需要检索与每个客户有关的所有订单数据.其优点是 ...

  7. LINQ to SQL语句(14)之Null语义和DateTime

    Null语义 说明:下面第一个例子说明查询ReportsToEmployee为null的雇员.第二个例子使用Nullable<T>.HasValue查询雇员,其结果与第一个例子相同.在第三 ...

  8. LINQ to SQL语句(10)之Insert

    1.简单形式 说明:new一个对象,使用InsertOnSubmit方法将其加入到对应的集合中,使用SubmitChanges()提交到数据库. var newCustomer = new Custo ...

  9. Linq to SQL 语法查询(链接查询,子查询 & in操作 & join,分组统计等)

    Linq to SQL 语法查询(链接查询,子查询 & in操作 & join,分组统计等) 子查询 描述:查询订单数超过5的顾客信息 查询句法: var 子查询 = from c i ...

  10. LinQ to SQL用法详解

    LinQ是指集成化查询语言,通过映射将数据库内的表名变为C#的类名,将列名作为属性名,将表的关系作为类的成员对象.O--M--R O-Object对象(李昌辉)R-Relation关系M-Mappin ...

随机推荐

  1. swift - 画图 - 画矩形,虚线,圆和半圆

    import UIKit class JYJYBouncedCouponsViewCellBgView: UIView { //一定要在这里设置 背景色, 不要再draw里面设置, override ...

  2. linux 版本号的查看

    1.# uname -a   (Linux查看版本当前操作系统内核信息)   Linux localhost.localdomain 2.4.20-8 #1 Thu Mar 13 17:54:28 E ...

  3. 【深度好文】多线程之WaitHandle-->派生-》Mutex信号量构造

    bool flag = false; System.Threading.Mutex mutex = new System.Threading.Mutex(true, "Test", ...

  4. Android 获取ROOT权限原理解析

    一. 概述 本文介绍了android中获取root权限的方法以及原理,让大家对android玩家中常说的“越狱”有一个更深层次的认识. 二. Root的介绍 1.       Root 的目的 可以让 ...

  5. JDK和Eclipse的下载路径

    JDK http://www.oracle.com/technetwork/java/javase/downloads/index.html Eclipse http://www.eclipse.or ...

  6. 2018.10.01 NOIP模拟 卡牌游戏(贪心)

    传送门 简单贪心题. 然而考试的时候失了智少讨论了一种情况导致gg. 实际上用到了二分图匹配的思想,L每次找到刚好比当前的牌小一点的出出去,看能匹配几个. 如何处理? 我们先考虑第一种比分策略. 我们 ...

  7. 2018.07.27 bzoj3064: Tyvj 1518 CPU监控(线段树)

    传送门 线段树好题. 维护区间加,区间覆盖,区间最大,区间历史最大. 这个东西在国家集训队2016论文集之<区间最值操作与历史最值问题--杭州学军中学 吉如一>中讲的已经很详细了. 简单来 ...

  8. <a href=“#”>

    在html中看到这样的属性:<a href=“#”>搜了好久,感觉不甚明白,现记之,等遇到了再做补充. # is called an anchor (or hash...). so the ...

  9. C语言printf的格式

    例1 int a = 12345;printf("%6d",a); // 输出6位不够左边补空格printf("%.6d",a); // 输出6位不够左边补0例 ...

  10. faceswap安装说明

    Installing Faceswap Installing Faceswap Prerequisites Hardware Requirements Supported operating syst ...