C#-WebForm-LinQ(一)-LinQ:语言集成查询(Language Integrated Query)-增删改查、属性扩展
LinQ-语言集成查询(Language Integrated Query)
高集成化的数据库访问技术
LINQ 2 SQL 实际是将数据库的表映射成程序中的类
会把数据库的表名原封不动的变成类名
数据库的列名原封不动的变成字段名/属性名
所有的操作都是通过Linq自动生成的一个上下文对象来进行操作的
Linq的名字+"DataContext"
一个数据库对应一个Linq
去除数据访问类的简便开发方式:
不需要新建数据库访问类,直接用< using(DataClassesContext con = new DataClassContext()){} >进行数据库访问
一、后台绑定数据 数据查询 con.Users; 或 con.Users.ToList();
public partial class Default3 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
using (DataClassesDataContext con = new DataClassesDataContext())
{
Repeater1.DataSource = con.Users.ToList();
Repeater1.DataBind();
}
}
}
}
二、删除代码 数据删除 con.Users.DeleteOnSubmit(u); 参数是要删除的完整数据
满足条件 r => r.username == Request["uname"] r是循环遍历数据的每一条数据
FirstOnDefault() 返回第一个或没有时返回默认值null
public partial class Delete : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
using (DataClassesDataContext con = new DataClassesDataContext())
{
//通过提交过来的用户名查找整条用户信息
Users u = con.Users.Where(r => r.username == Request["uname"]).FirstOrDefault();
//整条信息进行删除
con.Users.DeleteOnSubmit(u);
con.SubmitChanges();
//跳回主页面
Response.Redirect("Default3.aspx");
}
}
} }
三、添加数据
con.Users.InsertOnSubmit(u); con.SubmitChanges();
public partial class Insert : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
Button1.Click += Button1_Click;
} void Button1_Click(object sender, EventArgs e)
{
//要添加的数据
Users u = new Users();
u.username = TextBox1.Text;
u.password = TextBox2.Text;
u.nickname = TextBox3.Text;
u.sex = Convert.ToBoolean(TextBox4.Text);
u.birthday = Convert.ToDateTime(TextBox5.Text);
u.nation = TextBox6.Text;
u.@class = TextBox7.Text; //打开数据库进行操作:添加数据
using(DataClassesDataContext con=new DataClassesDataContext ())
{
con.Users.InsertOnSubmit(u);
con.SubmitChanges();
Response.Redirect("Default3.aspx");
}
} }
四、修改数据 查询出数据然后进行修改
public partial class Update : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
//要修改的数据
using (DataClassesDataContext con = new DataClassesDataContext())
{
Users u = con.Users.Where(r => r.username == Request["uname"]).FirstOrDefault();
if (u != null)
{
TextBox1.Text = u.username;
TextBox2.Text = u.password;
TextBox3.Text = u.nickname;
TextBox4.Text = u.sex.ToString();
TextBox5.Text = u.birthday.ToString();
TextBox6.Text = u.nation;
TextBox7.Text = u.@class;
}
else
Response.Redirect("Default3.aspx?tt=33");
}
} Button1.Click += Button1_Click;
} void Button1_Click(object sender, EventArgs e)
{
//修改后的数据
using (DataClassesDataContext con = new DataClassesDataContext())
{
Users u = con.Users.Where(r => r.username == TextBox1.Text).FirstOrDefault();
u.username = TextBox1.Text;
u.password = TextBox2.Text;
u.nickname = TextBox3.Text;
u.sex = Convert.ToBoolean(TextBox4.Text);
u.birthday = Convert.ToDateTime(TextBox5.Text);
u.nation = TextBox6.Text;
u.@class = TextBox7.Text;
//进行修改
con.SubmitChanges();
Response.Redirect("Default3.aspx");
}
} }
=============================================
基础知识:如何新建LinQ to SQL 类
一、新建

二、点击“服务器资源管理器”

三、点击“连接到数据库”

四、选择

五、将需要的表拖拽至界面,系统自动生成实体类

=============================================
高级版操作-去除数据库访问类:
一、展示页面代码:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default3.aspx.cs" Inherits="Default3" %> <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<style>
* {
padding: 0px;
margin: 0px;
}
</style>
</head>
<body>
<form id="form1" runat="server">
<div>
用户名:<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
昵称:<asp:TextBox ID="TextBox2" runat="server"></asp:TextBox>
出生年份:<asp:TextBox ID="TextBox3" runat="server"></asp:TextBox>
民族:<asp:TextBox ID="TextBox4" runat="server"></asp:TextBox>
班级:<asp:TextBox ID="TextBox5" runat="server"></asp:TextBox>
<asp:Button ID="Button1" runat="server" Text="查询" />
<br />
<table style="width: 100%; text-align: center;">
<tr style="background-color: navy; color: white;">
<td>编号</td>
<td>用户名</td>
<td>密码</td>
<td>昵称</td>
<td>性别</td>
<td>生日</td>
<td>民族</td>
<td>班级</td>
<td>操作</td>
</tr>
<asp:Repeater ID="Repeater1" runat="server">
<ItemTemplate>
<tr>
<td><%#Eval("ids") %></td>
<td><%#Eval("username") %></td>
<td><%#Eval("password") %></td>
<td><%#Eval("nickname") %></td>
<td><%#Eval("sex") %></td>
<td><%#Eval("birthday") %></td>
<td><%#Eval("nation") %></td>
<td><%#Eval("class") %></td>
<td>
<a href="Update.aspx?uname=<%#Eval("username") %>">修改</a>
<a href="Delete.aspx?uname=<%#Eval("username") %>">修改</a>
</td>
</tr>
</ItemTemplate>
</asp:Repeater>
</table>
<a href="Insert.aspx">添加</a>
</div>
</form>
</body>
</html>
展示页面代码
二、后台数据绑定
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls; public partial class Default3 : System.Web.UI.Page
{
DataClassesDataContext con = new DataClassesDataContext();
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
using (con)
{
Repeater1.DataSource = con.Users.ToList();
Repeater1.DataBind();
}
}
} }
后台数据绑定
三、using(){}增删改查(同上)
=============================================
低阶版操作-新建数据库访问类:
一、展示页面代码:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<style>
* {
padding: 0px;
margin: 0px;
}
</style>
</head>
<body>
<form id="form1" runat="server">
<div>
用户名:<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
昵称:<asp:TextBox ID="TextBox2" runat="server"></asp:TextBox>
出生年份:<asp:TextBox ID="TextBox3" runat="server"></asp:TextBox>
民族:<asp:TextBox ID="TextBox4" runat="server"></asp:TextBox>
班级:<asp:TextBox ID="TextBox5" runat="server"></asp:TextBox>
<asp:Button ID="Button1" runat="server" Text="查询" />
<br />
<asp:Repeater ID="Repeater1" runat="server">
<HeaderTemplate>
<table style="width: 100%; text-align: center;">
<tr style="background-color: navy; color: white;">
<td>编号</td>
<td>用户名</td>
<td>密码</td>
<td>昵称</td>
<td>性别</td>
<td>生日</td>
<td>民族</td>
<td>班级</td>
<td>操作</td>
</tr>
</HeaderTemplate>
<ItemTemplate>
<tr>
<td><%#Eval("ids") %></td>
<td><%#Eval("username") %></td>
<td><%#Eval("password") %></td>
<td><%#Eval("nickname") %></td>
<td><%#Eval("sex") %></td>
<td><%#Eval("birthday") %></td>
<td><%#Eval("nation") %></td>
<td><%#Eval("class") %></td>
<td>
<a href="Update.aspx?uname=<%#Eval("username") %>">修改</a>
<a href="Delete.aspx?uname=<%#Eval("username") %>">修改</a>
</td>
</tr>
</ItemTemplate>
<FooterTemplate>
</table>
</FooterTemplate>
</asp:Repeater>
<a href="Insert.aspx">添加</a>
</div>
</form>
</body>
</html>
展示界面代码
二、新建 LinQ to SQL 类

三、新建数据访问类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web; /// <summary>
/// DataClassesData 的摘要说明
/// </summary>
public class DataClassesData
{
DataClassesDataContext con = null;
public DataClassesData()
{
con = new DataClassesDataContext();
}
//查询
public List<Users> Select()
{
return con.Users.ToList();
} //添加
public void Insert(Users u)
{
con.Users.InsertOnSubmit(u);
con.SubmitChanges();
} //删除
public void Delete(string uname)
{
Users u = con.Users.Where(r => r.username == uname).FirstOrDefault();
if (u != null)
{
con.Users.DeleteOnSubmit(u);
con.SubmitChanges();
}
} }
数据访问类:增、删、查

==================================================
属性扩展:
新建一个类 → partial → 删除其结构函数 → 进行属性扩展
C#-WebForm-LinQ(一)-LinQ:语言集成查询(Language Integrated Query)-增删改查、属性扩展的更多相关文章
- C#3.0新增功能09 LINQ 基础01 语言集成查询
连载目录 [已更新最新开发文章,点击查看详细] 语言集成查询 (LINQ) 是一系列直接将查询功能集成到 C# 语言的技术统称. 数据查询历来都表示为简单的字符串,没有编译时类型检查或 Inte ...
- Hibernate修改操作 删除操作 查询操作 增加操作 增删改查 Hibernate增删查改语句
我用的数据库是MySQL,实体类叫User public class User { private Integer uid; private String username; private Stri ...
- 5月11日 python学习总结 子查询、pymysql模块增删改查、防止sql注入问题
一.子查询 子查询:把一个查询语句用括号括起来,当做另外一条查询语句的条件去用,称为子查询 select emp.name from emp inner join dep on emp.dep_id ...
- C语言,单链表操作(增删改查)(version 0.1)
这天要面试,提前把链表操作重新写了一遍.备份一下,以备不时之需. 希望有人能看到这篇代码,并指正. // File Name : list.h #include "stdafx.h" ...
- 使用C语言封装数组,动态实现增删改查
myArray.h : #pragma once //包含的时候只包含一次 #include <stdio.h> #include <stdlib.h> #include &l ...
- c语言实现双链表的基本操作—增删改查
//初始化 Node*InitList() { Node*head=(Node*)malloc(sizeof(Node)); if(NULL==head) { printf("内存分配失败! ...
- C# - LINQ 语言集成查询
LINQ(Language Integrated Query) LINQ语言集成查询是一组用于C#语言的扩展.它允许编写C#代码对数据集进行查询,比如查询内存中的对象或查询远程数据库的表.利用linq ...
- “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法
“标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法.大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了IEnumerable<T> 接口或 IQueryable& ...
- LINQ(语言集成查询)
LINQ,语言集成查询(Language Integrated Query)是一组用于c#和Visual Basic语言的扩展.它允许编写C#或者Visual Basic代码以查询数据库相同的方式操作 ...
随机推荐
- 基于 Web 的远程 Terminal 模拟器安装使用详解
http://lzw.me/a/shellinabox.html 一.Shellinabox 简介 Shellinabox 是一个基于 web 的终端模拟器,采用 C 语言编写,使用 Ajax 与后端 ...
- MVC知识记录
1.完整深入分析 MVC请求机制:http://blog.jobbole.com/85033/ 2.MVC入门:http://www.aizhengli.com/givecase-aspnet-5-m ...
- loadrunner12--学习中遇到疑问及解释
1.analysis里面,平均事务响应时间,平均事务响应时间+运行vuser,两个图的数据有区别是什么原因? 答: 请仔细查看以下两张图,其实两张图的数据是没有区别的. 之所以我们认为他们二者的数据有 ...
- [Jmeter]如何才能通过ant运行jmeter
在开始运行build.xml之前,还有一步必须要做,那就是将JMeter所在目录下extras子目录里的ant-JMeter-1.1.1.jar复制到Ant所在目录lib子目录之下,这样Ant运行时才 ...
- 百度地图 Javascript API 笔记
因为最近的一个项目用到,所以自己整理了一下遇到的一些坑 自己写了一个类库来二次封装用于调起常用的功能:https://github.com/iRuxu/iBMap 快速文档链接 Javascript ...
- HDU 5117 Fluorescent (数学+状压DP)
题意:有 n 个灯,初始状态都是关闭,有m个开关,每个开关都控制若干个.问在m个开关按下与否的2^m的情况中,求每种情况下亮灯数量的立方和. 析:首先,如果直接做的话,时间复杂度无法接受,所以要对其进 ...
- thinkphp5 swoole 执行异步任务
目录结构: 服务器端: <?php /* *author:hdj */ namespace app\Console; use think\console\Command; use think\c ...
- dojoConfig包的配置(7/26号夜)
主页代码: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> ...
- Swift:使用CAShapeLayer打造一个ProgresssBar
ProgressBar是一个很小却在很多地方都会用到的东西.也许是网络连接,也许APP本身有很多东西需要加载的.默认的只有一个旋转的菊花,对于打造一款个性的APP这显然是不够的.这里就使用CAShap ...
- BTrace追踪Hadoop部署
Hadoop集成BTrace 1.BTrace 1.1BTrace部署 1.下载BTrace工具包,官网地址:https://kenai.com/projects/btrace/downloads/d ...