public partial class Form1 : Form
    {
        private MydbInfoDataContext context = new MydbInfoDataContext();
        public Form1()
        {
            InitializeComponent();
        }
        //查询所有
        private void butOK_Click(object sender, EventArgs e)
        {
            // var var = from p in context.Info select p;
            var var = context.Info;
            dataGridView1.DataSource = var;
        }
        //等值查询
        private void butDengzhi_Click(object sender, EventArgs e)
        {
            //var var=from p in context.Info where p.Name=="胡军"select p;
            var var = context.Info.Where(p => p.Name == "胡军");
            dataGridView1.DataSource = var;
        }
        //不等值查询
        private void butBudengzhi_Click(object sender, EventArgs e)
        {
            //var var = from p in context.Info where p.Code != "p001" select p;
            var var = context.Info.Where(p => p.Code != "p002");
            dataGridView1.DataSource = var;
 
        }
        //多条件查询
        private void butDuotiaojian_Click(object sender, EventArgs e)
        {
            //var var = from p in context.Info where p.Sex == true && p.Nation == "n003" select p;
            var var = context.Info.Where(p => p.Sex == true ).Where(p=>p.Nation=="n003");
            dataGridView1.DataSource = var;
        }
        //数据添加
        private void butADD_Click(object sender, EventArgs e)
        {
            Info data = new Info();
            data.Code = txtcode.Text;
            data.Name = txtname.Text;
            data.Sex = Convert.ToBoolean (txtsex.Text);
            data.Nation = txtnation.Text;
            data.Birthday = Convert.ToDateTime(txtbirthday.Text);
 
            context.Info.InsertOnSubmit(data);
 
            context.SubmitChanges();
 
        }
        //数据在界面显示
        private void Form1_Load(object sender, EventArgs e)
        {
            List<Info> list = context.Info.ToList();
            dataGridView1.DataSource = list;
        }
        //删除数据
        private void butdelete_Click(object sender, EventArgs e)
        {
            var var = context.Info.Where(p => p.Code == txtcode.Text);
            
            if(var.Count()>0)
            {
                Info data = var.First();
 
                context.Info.DeleteOnSubmit(data);
 
                context.SubmitChanges();
            }
        }
        //
        private void txtcode_TextChanged(object sender, EventArgs e)
        {
 
        }
        //修改数据
        private void butUpdata_Click(object sender, EventArgs e)
        {
            var var = context.Info.Where (p => p.Code == txtcode.Text);
 
            if(var.Count()>0)
            {
                Info data = var.First();
                data.Code = txtcode.Text;
                data.Name = txtname.Text;
                data.Sex =Convert.ToBoolean( txtsex.Text);
                data.Nation = txtnation.Text;
                data.Birthday =Convert.ToDateTime (txtbirthday.Text);
            }
            context.SubmitChanges();
        }
        //模糊查询
        private void butMohu_Click(object sender, EventArgs e)
        {
            //var var = from p in context.Info where p.Name.Contains("环") select p;
           // var var = context.Info.Where(p => p.Name.StartsWith("环"));
           // var var = context.Info.Where(p => p.Name.EndsWith("妹"));
            var var =context.Info.Where(p=>p.Name.Substring(0,1)=="环");
            dataGridView1.DataSource = var;
        }
        //集合操作 
        private void butJihecaozuo_Click(object sender, EventArgs e)
        {
            var var1 = context.Info.Where(p => p.Sex == true);
            var var2 = context.Info.Where(p => p.Nation == "n003");
 
            //相交部位
            //var var = var1.Intersect(var2);
            //var var = var1.Union(var2);
            var var = var2.Except(var1);
            dataGridView1.DataSource = var;
        }
        //统计函数  个数 总和 平均值 最大 最小
        private void butTongji_Click(object sender, EventArgs e)
        {
            var var = context.Info.Where(p => p.Birthday.Value.Month > 5);
            //显示月份在五月份的有2个
            txtcode.Text = var.Count().ToString();
            //显示当前日期月份减去查询人物生日月份的值
            txtname.Text = var.Sum(p => DateTime.Now.Month - p.Birthday.Value.Month).ToString();
            //当前日期月份减去查询日期月份的平均值
            txtsex.Text = var.Average(p => DateTime.Now.Month - p.Birthday.Value.Month).ToString();
            //当前日期月份减去查询日期月份的最大值
            txtnation.Text = var.Max(p => DateTime.Now.Month - p.Birthday.Value.Month).ToString();
            //当前日期月份减去查询日期月份的最小值
            txtbirthday.Text = var.Min(p => DateTime.Now.Month - p.Birthday.Value.Month).ToString();
 
        }
        //转换操作
        private void butZhuanHuan_Click(object sender, EventArgs e)
        {
            //转换成集合 
            var var = context.Info.Where(p => p.Birthday.Value.Month > 5);
            List<Info> list = var.ToList();
            //转换成数组
            //var var = context.Info.Where(p => p.Birthday.Value.Month > 5);
            //Info[] list = var.ToArray(); 
            //转换成对象
            //var var = context.Info.Where(p => p.Birthday.Value.Month > 5);
            //Info data = var.First();
            dataGridView1.DataSource = var;
           
 
        }
        //分页查询
        private void butFenYe_Click(object sender, EventArgs e)
        {
            //跳过1条分成2页 显示2条
            var var = context.Info.Skip(1 * 1).Take(2);
            dataGridView1.DataSource = var;
        }
 
    }

ORM增删改查询例题的更多相关文章

  1. Django框架(三)-- orm增删改查、Django生命周期

    一.orm介绍 1.什么是orm ORM即Object Relational Mapping,全称对象关系映射. 2.使用orm的优缺点 优点: 不用写SQL语句 开发效率高 缺点: SQL的效率低 ...

  2. Django框架(三)—— orm增删改查、Django生命周期

    目录 orm增删改查.Django生命周期 一.orm介绍 二.orm增删改字段 三.Django生命周期 orm增删改查.Django生命周期 一.orm介绍 1.什么是orm ORM即Object ...

  3. ORM增删改查并发性能测试2

    前言 上一篇<ORM增删改查并发性能测试>出现了点小失误,有的输出SQL日志的代码没有禁用,数据库连接字符串可能有问题.统一环境,统一代码后,重新写一篇. 这次重点是并发性能测试,真不是为 ...

  4. django ORM 增删改查 模糊查询 字段类型 及参数等

    ORM 相关 #sql中的表 #创建表: CREATE TABLE employee( id INT PRIMARY KEY auto_increment , name VARCHAR (), gen ...

  5. 饮冰三年-人工智能-Python-24 Django ORM增删改查

    一:首先使用默认的sqlite3创建表 1:现在在models.py中添加表模型 from django.db import models # Create your models here. cla ...

  6. $Django orm增删改字段、建表 ,单表增删改查,Django请求生命周期

    1 orm介绍  ORM是什么   ORM 是 python编程语言后端web框架 Django的核心思想,“Object Relational Mapping”,即对象-关系映射,简称ORM.  一 ...

  7. day054 组件 CBV FBV 装饰器 ORM增删改查

    组件: ​ 把一小段HTML 放在一个HTML中 nav.html ​ 使用: ​ {% include ‘nav.html ’ %} 一. FBV 和CBV 1.FBV(function base ...

  8. ORM增删改查

    目录 orm django 连接mysql顺序 1 settings配置文件中 2 项目文件夹下的init文件中写上下面内容, 补充 3 models文件中创建一个类(类名就是表名) 4.执行数据库同 ...

  9. ORM增删改查并发性能测试

    这两天在对一些ORM进行性能测试(涉及SqlSugar.FreeSql.Fast.Framework.Dapper.LiteSql),测试用的是Winform程序,别人第一眼看到我的程序,说,你这测试 ...

随机推荐

  1. Python 第二篇:python字符串、列表和字典的基本操作方法

    本文基于python 3.5.1 python常见的数据类型有字串.列表.元组.字典等,本文将详细介绍每一种数据类型的操作方法. 一:str字串的操作方法: 1.capitalize()-->  ...

  2. C语言中给数组赋随机值

    srand和rand两个函数配合可以产生伪随机数序列.rand函数在产生随机数前,需要系统提供的生成伪随机数序列的种子,rand根据这个种子的值产生一系列随机数.如果系统提供的种子没有变化,每次调用r ...

  3. Jquery学习笔记:操作form表单元素之二(复选框和单选框)

    在上面文章的基础上,我们介绍如何操作表单元素中的 复选框和单选框. 一.复选框 <label> <input type="checkbox" id="i ...

  4. YT工作日志-0911

    上午 在导师的帮助下,帮我从svn上下载了项目.但是因为项目太大(不算jar包有730M),很多模块不是我工作中涉及的,但是运行的时候会报错,所以导师还帮我找了很多错误.把那些不需要的东西注释了.就这 ...

  5. 泛虚拟化技术(以Xen为例)

    一.概述    最主要的特点是:修改Guest OS的内核代码.通过修改内核,使Guest OS明白自己是运行在R-1,不要直接去运行特权指令,如果要运行就去Hypercall(主动VMM陷入).   ...

  6. JS中setTimeout()的使用方法具体解释

    1. SetTimeOut()              1.1 SetTimeOut()语法样例              1.2 用SetTimeOut()运行Function           ...

  7. 11181 - Probability|Given

    N friends go to the local super market together. The probability of their buying something from them ...

  8. HDU 4882 ZCC Loves Codefires(贪心)

     ZCC Loves Codefires Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/O ...

  9. 平衡树 - 红黑树(JQuery+Js+Canvas版本的,帮助大家理解)

    红黑树 1.红黑树介绍 年写的一篇论文中获得的.它是复杂的,但它的操作有着良好的最坏情况运行时间,并且在实践中是高效的:它可以在O(log n)时间内做查找,插入和删除,这里的n是树中元素的数目. 2 ...

  10. delphiXE调用Objective-c库

    http://stackoverflow.com/questions/16515218/xe4-firemonkey-ios-static-library-pascal-conversion-from ...