ADO.NET实体数据模型详细介绍
OleDbConnection,OracleConnection 或者SqlConnection这种连接,直接执行sql语句。现在的连接方式执行sql语句有了很大的不同,下面先看看简单的单表的增删改查操作,然后再看多表的关联查询,带参数查询等。
一、ADO.NET Entity对单表的增删改查
有一个表,即在工程中是一个实体user,为了测试方便,所有字段为string型。
1、增加新记录
增加一条记录如下:
[csharp]
using (OracleEntities entities = new OracleEntities())
{
User uer = User.CreateUser("id", "name", "age", "1");
entities.User.AddObject(user);
entities.SaveChanges();
using (OracleEntities entities = new OracleEntities())
{
User uer = User.CreateUser("id", "name", "age", "1");
entities.User.AddObject(user);
entities.SaveChanges();
}
2、删除内容
using (OracleEntities entities = new OracleEntities())
{
User user = entities.User.First<User>(a => a.ID.Equals("id"));
entities.DeleteObject(user);
entities.SaveChanges();
}using (OracleEntities entities = new OracleEntities())
{
User user = entities.User.First<User>(a => a.ID.Equals("id"));entities.DeleteObject(user);
entities.SaveChanges();
}
3、修改内容
using (OracleEntities entities = new OracleEntities())
{
User user = entities.User.First<User>(a => a.User.Equals("id"));
user.Remarks = "修改了内容";
entities.SaveChanges();
}using (OracleEntities entities = new OracleEntities())
{
User user = entities.User.First<User>(a => a.User.Equals("id"));user.Remarks = "修改了内容";
entities.SaveChanges();
}
4、查询内容
(1)实体直接查询
[/code]
using (OracleEntities entities = new OracleEntities())
{
ObjectQuery<User> result = entities.User;//查询所有
foreach (User item in result)
{
}
}
using (OracleEntities entities = new OracleEntities())
{
ObjectQuery<User> result = entities.User;//查询所有
foreach (User item in result)
{
}
}
[/code]
(2)Esql查询
ObjectQuery<DbDataRecord> result = entities.CreateQuery<DbDataRecord>("select value it from OracleEntities.User as it ");
(3)按条件查
var result = entities.User.Where(o => o.id.Equals("id"));
二、关联查询
比如还有个表Other与User外键关联。
进行查询如下:
using (OracleEntities entities = new OracleEntities())
{
string esql = "SELECT b.detail FROM OracleEntities.User as a,OracleEntities.Other as b where a.otherid = b.id and a.id='id'";
ObjectQuery<DbDataRecord> query = entities.CreateQuery<DbDataRecord>(esql);
foreach (DbDataRecord r in query)
{
string ss = r["detail"].ToString();
}
}using (OracleEntities entities = new OracleEntities())
{
string esql = "SELECT b.detail FROM OracleEntities.User as a,OracleEntities.Other as b where a.otherid = b.id and a.id='id'"; www.jb51.netObjectQuery<DbDataRecord> query = entities.CreateQuery<DbDataRecord>(esql);
foreach (DbDataRecord r in query)
{
string ss = r["detail"].ToString();
}
}
当然这些都是最基本的用法,因为使用的Linq和ESql,在后面再Linq和ESql的用法里再详细说明。
您可能感兴趣的文章:
- vs2015 新建ADO.NET 实体数据模型向导,选择MySql数据库连接后点击下一步就闪退
- 《MVC+EF》——用DBFirst创建ADO.NET实体数据模型和对象关系映射
- ADO.NET Entity Framework生成 School 实体数据模型(实体框架快速入门)
- [ADO.NET 实体数据模型][增删该查]
- ADO.NET实体数据模型多表连接查询中的实体键问题
- Visual Studio 2012 [ADO.NET 实体数据模型]丢失没有的解决方法
- 用Ado.Net实体数据模型 向sql数据库添加数据
- ADO.NET Entity Framework定义高级数据模型(实体框架任务)
- ADO.NET Entity Framework 使用实体数据模型工具
- vs2010找不到ado.net 实体数据模型解决办法
- ADO.NET实体数据模型使用探索1
- C#提高知识 ADO.NET实体数据模型 (2)
- Model First:创建实体数据模型(ADO.NET 实体数据模型)
- 使用ADO.NET 实体数据模型实现SQL存储过程调用
- Visual Studio2017中如何让ADO.NET实体数据模型[EntityFramework]支持MariaDB&MySQL数据源
- ADO.NET实体数据模型 在模型中加入外键列【Linq】
- VS2012中没有ADO.NET实体数据模型(无法生成edmx文件)
- VS2010 安装后找不到ADO.NET 实体数据模型
- VS中添加新项 数据选项卡下没有ADO.NET实体数据模型解决方案
- C#提高知识 ADO.NET实体数据模型(1)