Insert/Update/Delete 操作
插入(Insert)
1.簡單形式
說明: new 一個對象, 使用InsertOnSubmit 方法將其加入到對應的集合中, 使用
SubmitChanges()提交到資料庫。
NorthWindDataContext db = new NorthWindDataContext();
var newCustomer = new Customer
{
CustomerID = "MCSFT",
CompanyName = "Microsoft",
ContactName = "John Doe",
ContactTitle = "Sales Manager",
Address = "1 Microsoft Way",
City = "Redmond",
Region = "WA",
PostalCode = "98052",
Country = "USA",
Phone = "(425) 555-1234",
Fax = null
};
db.Customers.InsertOnSubmit(newCustomer);
db.SubmitChanges();
語句描述:使用InsertOnSubmit 方法將新客戶添加到Customers 表對象。調用SubmitChanges
將此新Customer 儲存到資料庫。
2.一對多關聯性
說明:Category 與Product 是一對多的關係,提交Category(一端)的資料時,LINQ to SQL 會
自動將Product(多端)的資料一起提交。
var newCategory = new Category
{
CategoryName = "Widgets",
Description = "Widgets are the ……"
};
varnewProduct = newProduct
{
ProductName = "Blue Widget",
UnitPrice = 34.56M,
Category = newCategory
};
db.Categories.InsertOnSubmit(newCategory);
db.SubmitChanges();
語句描述:使用InsertOnSubmit 方法將新類別添加到Categories 表中,並將新Product 對象
添加到與此新Category 有外鍵關係的Products 表中。調用SubmitChanges 將這些新對象及其
關係儲存到資料庫。
3.多對多關係
說明:在多對多關係中,我們需要依次提交。
var newEmployee = new Employee
{
FirstName = "Kira",
LastName = "Smith"
};
var newTerritory = new Territory
{
TerritoryID = "12345",
TerritoryDescription = "Anytown",
Region = db.Regions.First()
};
var newEmployeeTerritory = new EmployeeTerritory
{
Employee = newEmployee,
Territory = newTerritory
};
db.Employees.InsertOnSubmit(newEmployee);
db.Territories.InsertOnSubmit(newTerritory);
db.EmployeeTerritories.InsertOnSubmit(newEmployeeTerritory);
db.SubmitChanges();
語句描述:使用InsertOnSubmit 方法將新僱員添加到Employees 表中,將新Territory 添加
到Territories 表中,並將新EmployeeTerritory 對象添加到與此新Employee 對象和新Territory
對象有外鍵關係的EmployeeTerritories 表中。調用SubmitChanges 將這些新對象及其關係保
持到資料庫。
4.使用動態CUD重寫(Override using Dynamic CUD)
說明:CUD 就是Create、Update 、Delete 的縮寫。下面的例子就是建立一個ID(主鍵)為32
的Region,不考慮資料庫中有沒有ID 為32的資料,如果有則替換原來的資料,沒有則插入。
Region nwRegion = new Region()
{
RegionID = 32,
RegionDescription = "Rainy"
};
db.Regions.InsertOnSubmit(nwRegion);
db.SubmitChanges();
語句描述:使用DataContext 提供的分部方法InsertRegion 插入一個地區。對SubmitChange s
的調用調用InsertRegion 重寫,後者使用動態CUD 運行Linq To SQL 產生的預設SQL 查詢。
更新(Update)
說明:更新操作,先擷取對象,進行修改操作之後,直接調用SubmitChanges()方法即可提
交。注意,這裡是在同一個DataContext 中,對於不同的DataContex 看下面的講解。
1.簡單形式
Customer cust =
db.Customers.First(c => c.CustomerID == "ALFKI");
cust.ContactTitle = "Vice President";
db.SubmitChanges();
語句描述:使用SubmitChanges 將對檢索到的一個Customer 對象做出的更新保持回資料庫。
2.多項更改
var q = from p in db.Products
where p.CategoryID == 1
select p;
foreach(var p in q)
{
p.UnitPrice += 1.00M;
}
db.SubmitChanges();
語句描述:使用SubmitChanges 將對檢索到的進行的更新保持回資料庫。
刪除(Delete)
1.簡單形式
說明:調用DeleteOnSubmit 方法即可。
OrderDetailorder Detail =
db.OrderDetails.First
(c => c.OrderID == 10255 && c.ProductID == 36);
db.OrderDetails.DeleteOnSubmit(orderDetail);
db.SubmitChanges();
語句描述:使用DeleteOnSubmit 方法從OrderDetail 表中刪除OrderDetail 對象。調用
SubmitChanges 將此刪除保持到資料庫。
2.一對多關聯性
說明:Order 與OrderDetail 是一對多關聯性,首先DeleteOnSubmit 其OrderDetail(多端),其次
DeleteOnSubmit 其Order(一端)。因為一端是主鍵。
var orderDetails =
from o in db.OrderDetails
where o.Order.CustomerID == "WARTH"&&
o.Order.EmployeeID == 3
select o;
var order =
(from o in db.Orders
where o.CustomerID == "WARTH"&& o.EmployeeID == 3
selecto).First();
foreach(OrderDetail od in orderDetails)
{
db.OrderDetails.DeleteOnSubmit(od);
}
db.Orders.DeleteOnSubmit(order);
db.SubmitChanges();
語句描述語句描述:使用DeleteOnSubmit 方法從Order 和Order Details 表中刪除Order 和
Order Detail 對象。首先從Order Details 刪除,然後從Orders 刪除。調用SubmitChanges 將
此刪除保持到資料庫。
3.推理刪除(Inferred Delete)
說明:Order 與OrderDetail 是一對多關聯性,在上面的例子,我們全部刪除CustomerID 為
WARTH 和EmployeeID 為3 的資料,那麼我們不須全部刪除呢?例如Order 的OrderID 為
10248的OrderDetail 有很多,但是我們只要刪除ProductID 為11的OrderDetail。這時就用
Remove 方法。
Order order = db.Orders.First(x => x.OrderID == 10248);
OrderDetail od =
order.OrderDetails.First(d => d.ProductID == 11);
order.OrderDetails.Remove(od);
db.SubmitChanges();
語句描述語句描述:這個例子說明在實體物件的引用實體將該對象從其EntitySet 中移除時,
推理刪除如何導致在該對象上發生實際的刪除操作。僅當實體的關聯映射將DeleteOnNull
設定為true 且CanBeNull 為false 時,才會發生推理刪除行為。