การใช้งาน Entity Framework กับ MySQL Database (LINQ to Entities - MySQL Database) |
การใช้งาน Entity Framework กับ MySQL Database (LINQ to Entities - MySQL Database) ความสามารถของ Entity Framework ได้พัฒนาให้มากกว่าที่จะรองรับเฉพาะ Database ของ SQL Server เท่านั้น ซึ่งเราสามารถใช้งานกับมันได้ในหลาย ๆ Database และในหัวข้อนี้เราจะมาเรียนรู้วิธีการ Config และติดตั้งรายการ Driver ต่าง ๆ เพื่อให้สามารถใช้ MySQL Database กับ Entity Framework ได้ ซึ่งในการใช้งานจะรองรับตั้งแต่ Entity Framework 5 ขึ้นไป และอาจจะต้องมำการติดตั้งพวก Driver ต่าง ๆ ที่เกี่ยวข้องด้วย
Table : customer
CREATE TABLE IF NOT EXISTS `customer` (
`CUSTOMER_ID` varchar(4) NOT NULL,
`NAME` varchar(50) NOT NULL,
`EMAIL` varchar(50) NOT NULL,
`COUNTRY_CODE` varchar(2) NOT NULL,
`BUDGET` decimal(18,2) NOT NULL,
`USED` decimal(18,2) NOT NULL,
PRIMARY KEY (`CUSTOMER_ID`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
--
-- Dumping data for table `customer`
--
INSERT INTO `customer` (`CUSTOMER_ID`, `NAME`, `EMAIL`, `COUNTRY_CODE`, `BUDGET`, `USED`) VALUES
('C001', 'Win Weerachai', '[email protected]', 'TH', 1000000.00, 600000.00),
('C002', 'John Smith', '[email protected]', 'UK', 2000000.00, 800000.00),
('C003', 'Jame Born', '[email protected]', 'US', 3000000.00, 600000.00),
('C004', 'Chalee Angel', '[email protected]', 'US', 4000000.00, 100000.00);
data:image/s3,"s3://crabby-images/e7fc5/e7fc5de0ab753de9e9300b55b1541a8e9f7f87d2" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
Table : country
CREATE TABLE IF NOT EXISTS `country` (
`COUNTRY_CODE` varchar(2) NOT NULL,
`COUNTRY_NAME` varchar(50) NOT NULL,
PRIMARY KEY (`COUNTRY_CODE`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
--
-- Dumping data for table `country`
--
INSERT INTO `country` (`COUNTRY_CODE`, `COUNTRY_NAME`) VALUES
('TH', 'Thailand '),
('UK', 'United Kingdom'),
('US', 'United States');
data:image/s3,"s3://crabby-images/d8945/d89451d39816c291ace7eb039c781d383263c24f" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
Table : audit
CREATE TABLE IF NOT EXISTS `audit` (
`AUDIT_ID` int(4) NOT NULL,
`CUSTOMER_ID` varchar(4) NOT NULL,
`LOG_DATE` date NOT NULL,
`USED` decimal(18,2) NOT NULL,
PRIMARY KEY (`AUDIT_ID`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
--
-- Dumping data for table `audit`
--
INSERT INTO `audit` (`AUDIT_ID`, `CUSTOMER_ID`, `LOG_DATE`, `USED`) VALUES
(1, 'C001', '2015-08-01', 100000.00),
(2, 'C001', '2015-08-05', 200000.00),
(3, 'C001', '2015-08-10', 300000.00),
(4, 'C002', '2015-08-02', 400000.00),
(5, 'C002', '2015-08-07', 100000.00),
(6, 'C002', '2015-08-15', 300000.00),
(7, 'C003', '2015-08-20', 400000.00),
(8, 'C003', '2015-08-25', 200000.00),
(9, 'C004', '2015-07-04', 100000.00);
data:image/s3,"s3://crabby-images/2dad4/2dad4ec7ca30092193aa8c0253b4f869a77b936d" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
เปิดโปรเจคบน Visual Studio
สิ่งที่จำเป็นต้องมี (ให้ดาวน์โหลดมาติดตั้งให้ครบ)- MySQL Connector/Net 6.8.x
- MySQL Server 5.1 or above
- Entity Framework 5 or 6 assemblies
- .NET Framework 4.0 or above
- MySQL for Visual Studio 1.2.3 GA
data:image/s3,"s3://crabby-images/dd791/dd791da4f14b471178d5671ea28b5887c6081ee7" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
เลือก Add รายการ ADO.NET Entity Data Model
data:image/s3,"s3://crabby-images/8bc16/8bc167335a19e72171b096ba3da8257f1afb1ba0" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
EF Designer from Database
data:image/s3,"s3://crabby-images/9876d/9876d3338d70b426d56121c4f1641f2fae8d9e05" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
เลือก New Connection
data:image/s3,"s3://crabby-images/eb01d/eb01dc7751f657a51ff5f4be337da596a582beff" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
เลือก Change
data:image/s3,"s3://crabby-images/045a6/045a61399740f28dd75c7131593a379acad3d52e" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
จะเห็นว่าตอนนี้ยังไม่มีรายการของ MySQL Driver
ให้ทำการติดตั้งรายการ Driver ต่าง ๆ ที่ได้แจ้งไว้ก่อนหน้านี้
data:image/s3,"s3://crabby-images/b7030/b7030fa4669da3f3569f45e510bc36fabf5ccf2e" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
MySQL Connector/Net 6.8.x
data:image/s3,"s3://crabby-images/e6695/e6695b306807bd7bc9d10a64ec5a65a9b3fefd53" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
Entity Framework 5 or 6 assemblies
data:image/s3,"s3://crabby-images/71664/7166432d087427933c503d0e71181227bd078b24" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
MySQL for Visual Studio 1.2.3 GA
data:image/s3,"s3://crabby-images/254e1/254e134629118c76f02c864309e6672437ac9154" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
จากนั้นให้เลือก Add จะเห็นว่ามี Driver ของ MySQL Database
data:image/s3,"s3://crabby-images/f18a5/f18a57084ccb1b70742a05287eae4a8e3ccbb96c" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
กรอกข้อมูลในการเชื่อมต่อกับ MySQL Database
data:image/s3,"s3://crabby-images/a6d1b/a6d1b5ec7d6a95cf6f8301b6910fadc98e39a512" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
เลือกรายการ Table ที่ต้องการเพ่มลงใน Entity Model
data:image/s3,"s3://crabby-images/a3ed8/a3ed80772fdae810429bc2f69c820a10f4345214" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
รายการ Table บน Entity Model
data:image/s3,"s3://crabby-images/3dbe7/3dbe7b9eb7ce0e08cce46fce5c8ec44cd9a5e166" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
ทดสอบสร้าง DataGridView สำหรับการทดสอบเรียกข้อมูล
Code C#
// Create new entities Object
using (var db = new myDatabaseEntities())
{
// Get data from customer
var ds = (from c in db.customer
select c).ToList();
// Assign to DataGridView
if (ds.Count() > 0)
{
this.myDataGridView.DataSource = ds;
}
}
Code VB.Net
' Create new entities Object
Using db = New myDatabaseEntities()
' Get data from customer
Dim ds = (From c In db.customer Select c).ToList()
' Assign to DataGridView
If ds.Count() > 0 Then
Me.myDataGridView.DataSource = ds
End If
End Using
Result
data:image/s3,"s3://crabby-images/ad1e2/ad1e28de8a8b3ea7c2cb1d80cc9b89dd2f175b0f" alt="Entity Framework MySQL Database Entity Framework MySQL Database"
สำหรับวิฌีการใช้งานอื่น ๆ ไม่ได้ต่างกับการใช้ Entity Framework ด้วย SQL Database
|