Linq to SQL 练习
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 练习的更多相关文章
- LINQ to SQL语句(7)之Exists/In/Any/All/Contains
适用场景:用于判断集合中元素,进一步缩小范围. Any 说明:用于判断集合中是否有元素满足某一条件:不延迟.(若条件为空,则集合只要不为空就返回True,否则为False).有2种形式,分别为简单形式 ...
- 年终巨献 史上最全 ——LINQ to SQL语句
LINQ to SQL语句(1)之Where 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句.Where操 ...
- LINQ to SQL语句(20)之存储过程
在我们编写程序中,往往需要一些存储过程,在LINQ to SQL中怎么使用呢?也许比原来的更简单些.下面我们以NORTHWND.MDF数据库中自带的几个存储过程来理解一下. 1.标量返回 在数据库中, ...
- LINQ to SQL语句(19)之ADO.NET与LINQ to SQL
它基于由 ADO.NET 提供程序模型提供的服务.因此,我们可以将 LINQ to SQL 代码与现有的 ADO.Net 应用程序混合在一起,将当前 ADO.NET 解决方案迁移到 LINQ to S ...
- LINQ to SQL语句(18)之运算符转换
运算符转换 1.AsEnumerable:将类型转换为泛型 IEnumerable 使用 AsEnumerable<TSource> 可返回类型化为泛型 IEnumerable 的参数.在 ...
- LINQ to SQL语句(17)之对象加载
对象加载 延迟加载 在查询某对象时,实际上你只查询该对象.不会同时自动获取这个对象.这就是延迟加载. 例如,您可能需要查看客户数据和订单数据.你最初不一定需要检索与每个客户有关的所有订单数据.其优点是 ...
- LINQ to SQL语句(14)之Null语义和DateTime
Null语义 说明:下面第一个例子说明查询ReportsToEmployee为null的雇员.第二个例子使用Nullable<T>.HasValue查询雇员,其结果与第一个例子相同.在第三 ...
- LINQ to SQL语句(10)之Insert
1.简单形式 说明:new一个对象,使用InsertOnSubmit方法将其加入到对应的集合中,使用SubmitChanges()提交到数据库. var newCustomer = new Custo ...
- Linq to SQL 语法查询(链接查询,子查询 & in操作 & join,分组统计等)
Linq to SQL 语法查询(链接查询,子查询 & in操作 & join,分组统计等) 子查询 描述:查询订单数超过5的顾客信息 查询句法: var 子查询 = from c i ...
- LinQ to SQL用法详解
LinQ是指集成化查询语言,通过映射将数据库内的表名变为C#的类名,将列名作为属性名,将表的关系作为类的成员对象.O--M--R O-Object对象(李昌辉)R-Relation关系M-Mappin ...
随机推荐
- 【校招面试 之 C/C++】第4题 拷贝构造函数被调用的3个时机
1.被调用的3个时机: (1)直接初始化或拷贝初始化: (2)将一个对象作为一个实参传递,形参采用非指针或非引用的对象进行接收时(指针即指向了同一块空间,并未实现拷贝:而引用就是实参本身): (3)函 ...
- VS 窗体大小
锁定窗体大小,就是鼠标停在窗口边框的时候,不能拖动来改变它的大小…… 有两种方法: 1.可以把Form的属性 FormborderStyle 后面选择 FixedDialog 2.或者把Form窗体的 ...
- 10-多写一个@Autowired导致程序崩了
再是javaweb实验六中,是让我们改代码,让它跑起来,结果我少注释了一个,导致一直报错,检查许久没有找到,最后通过代码替换逐步查找,才发现问题.
- handler------post传送方式
package com.qianfeng.gp08_day26_hanlder2; import android.os.Bundle; import android.os.Handler; impor ...
- 分享chrome清空缓存开发小技巧
在打开开发者工具的前提下,左键长按刷新页面小图标(左上角,地址栏左侧),可以调出清空缓存下拉选择项.
- 将html转换成image图片png格式
import java.awt.Color; import java.awt.Dimension; import java.awt.Graphics; import java.awt.Graphics ...
- 转载 springboot 配置读取
前言:了解过spring-Boot这个技术的,应该知道Spring-Boot的核心配置文件application.properties,当然也可以通过注解自定义配置文件**.properties的信息 ...
- PS、AI、AE常用快捷键大全
PS,AI,AE最常用的快捷键来了. 注意:Mac用户请自觉把Ctrl换成Command理解就行. 2017 Adobe Photoshop CC 快捷键 2017Adobe Illustrator快 ...
- Netty 零拷贝(三)Netty 对零拷贝的改进
Netty 零拷贝(三)Netty 对零拷贝的改进 Netty 系列目录 (https://www.cnblogs.com/binarylei/p/10117436.html) Netty 的&quo ...
- Python鸭子类型思想
动态语言中经常提到鸭子类型,所谓鸭子类型就是:如果走起路来像鸭子,叫起来也像鸭子,那么它就是鸭子(If it walks like a duck and quacks like a duck, it ...