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代码以查询数据库相同的方式操作 ...
随机推荐
- win7 python2.7安装PIL库
一.前言 遇到客户给了一个需求,需要拼接多个图片,上网找到一个解决方式,不过是需要安装PIL的,相信安装过这个库的应该都遇到很多问题,接下来说说怎么解决. 我的环境是: 操作系统:win10 64bi ...
- 31-字符串转为 url 格式的两种不同情况
将此字符串转为 url 格式的: # 如果是转化对象用:data=urllib.parse.urlencode(values) # 如果是转化字符串:s=urllib.parse.quote(s)
- 不同包之间的继承extends
情景如下: 两个类:ExtendsSuper(父类).ExtendsSub(子类) 两个包:父类ExtendsSuper位于包packSuper路径下,子类ExtendsSub位于包packSub路径 ...
- jquery破坏链
- Path Creation and Path Painting
[Path Creation and Path Painting] Path creation and path painting are separate tasks. First you crea ...
- 20155318 2016-2017-2 《Java程序设计》第九学习总结
20155318 2016-2017-2 <Java程序设计>第九学习总结 教材学习内容总结 学习目标 了解JDBC架构 掌握JDBC架构 掌握反射与ClassLoader 了解自定义泛型 ...
- Codeforces758D Ability To Convert 2017-01-20 10:29 231人阅读 评论(0) 收藏
D. Ability To Convert time limit per test 1 second memory limit per test 256 megabytes input standar ...
- Hook ptrace 调试加入了ptrace函数的程序
Hook ptrace 调试加入了ptrace函数的程序 #import <substrate.h> #if !defined(PT_DENY_ATTACH)#define PT_DENY ...
- Oracle 程序中超好用的日志记录TYPE,可以直接Copy使用
创建类型名称:LOGGER_FACTORY Type 说明: CREATE OR REPLACE TYPE "LOGGER_FACTORY" AS OBJECT( v_progra ...
- Linux Socket - 内核非阻塞功能
select 函数 int select(int maxfdp,fd_set *readfds,fd_set *writefds,fd_set *errorfds,struct timeval*tim ...