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. MYSQL错误:You can't specify target table for update in FROM clause

    这句话意思是:不能先select再更新(修改)同一个表. 可以再外嵌套多一层,这个问题只有mysql有,mssql和oracle都没有. # 出错delete from Person where Id ...

  2. Ubuntu-18.04Python2与Python3自由切换

    一.配置ssh链接 安装openssh-server devops@devops-virtual-machine:~$ sudo apt-get install openssh-server 二.安装 ...

  3. php5.3 延迟静态绑定 static关键字

    //传统模式 --这段代码能很好工作,但大量的重复代码很烦人,不想为每个DomainObject子类都创建这段相同代码吧? /* abstract class DomainObject{} class ...

  4. 利用redis完成自动补全搜索功能(三)

    前面已经完成了分词和自动提示功能,最后把搜索结合在一起,来个完成的案例.当然最好还是用搜索分词解决,这个只是一个临时解决方案. 其实加上搜索很简单,要做的就是3件事 1. 分词的时候,把有用词的id存 ...

  5. linq to sql之like

    contains——like '%提交%' StartsWith—— like '条件%' EndWith——like '%条件'

  6. DB2数据库常用命令数据库学习

    DB2数据库常用命令数据库学习你可以用 get snapshot for locks on XXX 看是那个表锁了,再从相关的操作去查原因吧 db2pd -d 库名 -locks和db2pd -d 库 ...

  7. xtrabackup拷贝redolog前做的细节操作

    原文地址:http://www.innomysql.net/article/25590.html 前言 淘宝3月的数据库内核月报对 xtrabackup的备份原理 做了深入的分析,写的还是很不错.不过 ...

  8. 系统调用方式文件编程-open

    通过Linux系统调用函数编写应用程序,该应用程序实现文件的复制功能 文件描述符--在Linux系统中,所有打开的文件也对应一个数字,这个数字由系统来分配. 1.打开文件--open 头文件:#inc ...

  9. Linux shell脚本的字符串截取

    http://blog.csdn.net/gumanren/article/details/5601544 Linux 的字符串截取很有用.有八种方法. 假设有变量 var=http://www.ha ...

  10. Realtek 8192cu 支持 Android Hotspot 软ap

    http://www.cnblogs.com/bpasser/archive/2011/10/15/2213483.html Android 2.2 开始增加了WiFi Hotspot,可将Andro ...