LINQ,语言集成查询(Language Integrated Query)

是一组用于c#和Visual Basic语言的扩展。它允许编写C#或者Visual Basic代码以查询数据库相同的方式操作内存数据。

一、创建 LINQ

在项目下创建 linq to SQL 类,

将相应的数据库表拖入即可

二、LINQ 的属性拓展

对 LINQ  进行属性扩展时 ,一定要在外部新建类文件进行扩展

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web; /// <summary>
/// Users 的摘要说明
/// </summary>
public partial class Users
{
public string SexStr
{
get
{
return Convert.ToBoolean(_Sex) ? "男" : "女";
}
} public string BirStr
{
get
{
return Convert.ToDateTime(_Birthday).ToString("yyyy年MM月dd日");
} //DateTime? 型,带问号,最好转换一下
} public string Nationn
{
get
{
return Nation1.NationName;
}
} //从另一个表中抓取返回值
}

属性扩展

 -- 有主外键关系的扩展,可直接抓取

三、查询全部,数据展示

1、创建 linq 数据库文件的 数据库上下文上下文对象

UsersDataClassesDataContext  con = new  UsersDataClassesDataContext( );

-- UsersDataClassesDataContext  创建linq 数据库是创建的类

2、通过上下文对象获取数据,绑定数据

list<Users> = con.Users .ToList ();

-- con.Users   通过上下文对象获取 Users 中的全部对象

-- 通过 con 获取的对象是 linq 类型,  .Tolist() 转换成集合

       if (!IsPostBack)
{
using (UsersDataClassesDataContext con=new UsersDataClassesDataContext() )
{ Repeater1.DataSource =con.Users .ToList (); Repeater1.DataBind (); } }

绑定所有数据--加载绑定

-- using 编写一个作用域,括号内创建一个上下文对象

-- 创建的对象只在花括号里使用,走完花括号就不存在了

--using 这个方法,每次在数据库开启时都是全新的对象

这个对象用完后会自动消失,不消耗内存。

四、添加

  //提交
void Button1_Click(object sender, EventArgs e)
{
Users u = new Users(); u.Username = TextBox1.Text;
u.Password = p1.Text;
u.Nickname = TextBox2.Text;
u.Sex = RadioButtonList1.Items[].Selected;
u.Birthday = Convert.ToDateTime(Text_Bir.Text);
u.Nation = Dr4.SelectedValue; using (UsersDataClassesDataContext con = new UsersDataClassesDataContext ())
{
con.Users.InsertOnSubmit(u); //u 要添加的数据对象
con.SubmitChanges();
} Response.Redirect("zhanshi.aspx");
}

添加数据 -- 提交按钮后台代码

con.Users.InsertOnSubmit(u);     

( 上下文对象 . 表 . 方法 )         -- 准备添加,

con.SubmitChanges();

-- 提交所有数据

五、删除

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls; public partial class delete : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
string id = Request["i"]; using (UsersDataClassesDataContext con = new UsersDataClassesDataContext())
{
//根据主键值查询出对应的这个对象
Users us = con.Users.Where(r => r.Ids.ToString() == id).FirstOrDefault(); if (us != null)
{
con.Users.DeleteOnSubmit(us);
con.SubmitChanges(); } Response.Redirect("zhanshi.aspx");
} }
}

删除-- 删除页后台代码

Users us = con.Users.Where( r => r.Ids.ToString() == id ).FirstOrDefault();     // lambda 表达式

         -- FirstOrDefault()  : 根据前面查询的,取第一条,如果没有返回 null

-- r   :表示任何一行

--  =>   :固定格式

con.Users.DeleteOnSubmit(us);

con.SubmitChanges();

六、修改

    //提交按钮
void Button1_Click(object sender, EventArgs e)
{
string st = Request["i"]; using (UsersDataClassesDataContext con = new UsersDataClassesDataContext())
{ Users u = con.Users.Where(r => r.Ids.ToString() == st).FirstOrDefault(); if (u != null)
{
if (p1.Text.Length > )
u.Password = p1.Text; u.Nickname = TextBox2.Text;
u.Sex = RadioButtonList1.Items[].Selected;
u.Birthday = Convert.ToDateTime(Text_Bir.Text);
u.Nation = Dr4.SelectedValue; con.SubmitChanges(); Response.Write("<script>alert('修改成功!')</script>");
Response.Redirect("zhanshi.aspx"); } } }

修改 -- 修改按钮后台代码

-- con.SubmitChanges();

各修改数据准备过程就是准备修改过程,不用再用上下文对象来准备。直接一把提交

LINQ 【增、删、改、查】数据绑定的更多相关文章

  1. 好用的SQL TVP~~独家赠送[增-删-改-查]的例子

    以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化.  本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...

  2. iOS FMDB的使用(增,删,改,查,sqlite存取图片)

    iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...

  3. iOS sqlite3 的基本使用(增 删 改 查)

    iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...

  4. django ajax增 删 改 查

    具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...

  5. ADO.NET 增 删 改 查

    ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...

  6. MVC EF 增 删 改 查

    using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...

  7. python基础中的四大天王-增-删-改-查

    列表-list-[] 输入内存储存容器 发生改变通常直接变化,让我们看看下面列子 增---默认在最后添加 #append()--括号中可以是数字,可以是字符串,可以是元祖,可以是集合,可以是字典 #l ...

  8. 简单的php数据库操作类代码(增,删,改,查)

    这几天准备重新学习,梳理一下知识体系,同时按照功能模块划分做一些东西.所以.mysql的操作成为第一个要点.我写了一个简单的mysql操作类,实现数据的简单的增删改查功能. 数据库操纵基本流程为: 1 ...

  9. MongoDB增 删 改 查

    增 增加单篇文档 > db.stu.insert({sn:'001', name:'lisi'}) WriteResult({ "nInserted" : 1 }) > ...

  10. Go语言之进阶篇mysql增 删 改 查

    一.mysql操作基本语法 1.创建名称nulige的数据库 CREATE DATABASE nulige DEFAULT CHARSET utf8 COLLATE utf8_general_ci; ...

随机推荐

  1. Hibernate 基础入门

    概述: JDBC:将java和数据库连接的驱动程序加载到项目中,在代码里面,注册驱动,创建链接,创建satement对象,发送并执行sql之类,关闭连接. hibernate :数据持久化一个框架,对 ...

  2. HTML学习总结(作业五)

    1:HTML简介 超文本标记语言,标准通用标记语言下的一个应用.是 网页制作必备的编程语言“超文本”就是指页面内可以包含图片.链接,甚至音乐.程序等非文字元素.超文本标记语言的结构包括“头”部分(英语 ...

  3. MySQL导入SQL语句报错 : MySQL server has gone away (已解决)

    MySQL server has gone away 解决的方法其实很简单,我相信也有很多人遇到了这个问题.比如DZ论坛,安装好服务器,但是清空缓存等操作数据库的动作,运行时间稍长就会出现 MySQL ...

  4. 3 week work—Position

    源代码部分: (1)httm部分: <!DOCTYPE html> <html lang="en"> <head> <meta chars ...

  5. linux配置防火墙和重启防火墙

    1.在linux系统里面找到并打开编辑配置防火墙的文件,执行命令: vi /etc/sysconfig/iptables. 2.在上面打开的文件里面加入一下语句: -A INPUT -m state ...

  6. Linux 查看IP

    UBuntu 系统下 按Ctrl+Alt+T 唤出终端 在终端输入: ifconfig 命令 点击回车 就可以看到自己电脑在局域网的IP地址了 图中第二行 inet 地址:192.168.1.101 ...

  7. 腾讯大数据之TDW计算引擎解析——Shuffle

    转自 https://www.csdn.net/article/2014-05-19/2819831-TDW-Shuffle/1 摘要:腾讯分布式数据仓库基于开源软件Hadoop和Hive进行构建,T ...

  8. Java 字符串类型常用方法

    常用方法 获取字符串长度 public int length() 字符串Unicode操作 这部分用的不多,不是很清楚,先记载在这. //获取指定索引处的元素对应的unciode编码 public i ...

  9. Shell-13--while和until

  10. 学生成绩管理系统(C++指针、链表、文件及面向对象的运用)

    学生成绩管理系统 功能页面显示:    实现源码: #include<iostream> #include<fstream> #include<cstring> # ...