Orm Là Gì

     

Trong cách phát triển ứng dụng web hiện nay chắc hẳn các bạn đã quen thuộc với với từ khóa ORM(Object Relational Mapping). Khi nhưng mà thời đại của những framework ứng với các ngôn ngữ sẽ lên ngôi một cách khỏe khoắn mẽ, ORM ngay sát như là việc lựa chọn hoàn hảo và tuyệt vời nhất của những nhà cải cách và phát triển hiện nay.Bạn đang xem: Object relational mapping là gì

ORM giúp chúng ta dễ dàng thao tác làm việc với dữ liệu vớiDatabase hơn, giúp bọn họ dễ code, dễ maintain rộng . . . Ở nội dung bài viết này tôi sẽ ra mắt chung về ORM, đi sâu vào phân tích những điểm ưu điểm, yếu điểm và lúc nào áp dụng chúng trong số dự án thực tế.

Bạn đang xem: Orm là gì

Để mang đến dễ theo dõi từ thời đặc điểm đó của nội dung bài viết tôi xin được dùng ORM nỗ lực cho các từ Object Relational Mapping


*

1. ORM là gì ?

Theo Wikipedia:

Object-relational mapping (ORM, O/RM, và O/R mapping tool) in computer science is a programming technique for converting data between incompatible type systems using object-oriented programming languages. This creates, in effect, a "virtual object database" that can be used from within the programming language. There are both không lấy phí and commercial packages available that perform object-relational mapping, although some programmers opt to lớn construct their own ORM tools.

Hiểu một cách dễ dàng và đơn giản thì

ORM là 1 kỹ thuật lập trình giúp ánh xạ các record tài liệu trong hệ cai quản trị cơ sở dữ liệu sang dạng đối tượng người sử dụng đang định nghĩa trong các class - một khái niệm phổ biến được áp dụng trong tất cả các ngôn ngữ tiến bộ ngày ni như: Java, PHP, Ruby. Chúng ta cũng có thể áp dụng kĩ thật này với bất kể dự án nào chúng ta thích.

*

Theo Martin Fowler gồm hai patterns được áp dụng cho những cách kiến tạo ORM không giống nhau.

Một sốORMnổi tiếng áp dụng Active Record hoàn toàn có thể kể thương hiệu là: Eloquent, CachePHP, JOOQ, TOPLINK


*

*

Một số ORM khét tiếng sử dụng Data Mapper như: Doctrine, Hibernate, SqlAlchemy

2. ORM hoạt động như rứa nào ?

Đặc trưng cơ bản của ORM là gói gọn gàng CSDL trong 1 object. Một phần của object sẽ đựng data, với phần còn lại lo câu hỏi data cách xử lý như làm sao và biến chuyển nó thành database quan hệ.

ORM giải quyết và xử lý vấn đề đồng hóa giữa kiểu dữ liệu trả về không giống nhau. Một bên là các đại lý dữ liệu, ở đó tài liệu được mô tả dưới dạng tập hòa hợp các phiên bản ghi. Một mặt là những đối tượng, ở đó dữ liệu đc hiện thị bên dưới dạng object


*

3. Ưu với nhược điểm ORM

Ví dụ về việc tìm và đào bới kiếm danh sách bạn dạng ghi với đk với sql thuần

book_list = new List();sql = "SELECT * FROM library WHERE tác giả = "Linus"";data = query(sql);while (row = data.next()) book = new Book(); book.setAuthor(row.get("author"); book_list.add(book);Với ORM, nó sẽ đơn giản như sau

book_list = BookTable.query(author="Linus");Từ ví dụ dễ dàng trên chúng ta dễ dàng nhận thấy các ưu điểm sau khi áp dụng ORM

Ưu điểm

Rất nhiều thứ được triển khai "tự động", liên quan tới việc xử lí dữ liệu, trong lấy một ví dụ trên chúng ta không cần suy nghĩ việc dùng vòng nhằm convert data từ bỏ mysql ra, Chỉ nên biết đầu vào là keyword đầu ra trả lại 1 danh sách các quyển sách gồm author=LinusViệc thực hiện ORM có tác dụng bạn bắt buộc phải viết code theo mô hình MVC, khiến code của doanh nghiệp dễ sửa đổi, gia hạn hơn.Bạn không cần phải biết quá các về MYSQL, bạn vẫn có thể tiếp cận dễ dàng với ORM.Model k ràng buộc ngặt nghèo với ứng dụng, hay nói bí quyết khác, model thì linh hoạt, do vậy chúng ta có thể thay đổi hoặc sử dụng nó bất cứ chỗ nàoORM cho phép bạn tận dụng ưu điểm của OOP như kế thừa tài liệu mà không hẳn đau đầu

Nhược điểm

Với từng framework sẽ có một thư viện ORM không giống nhau, tất nhiên là các bạn phải mất thời hạn học nó. Và bởi vì chúng là tủ sách nên sẽ rất "nặng".Performance ổn đối với các truy tìm vấn thông thường, mà lại Raw SQL sẽ luôn luôn làm giỏi hơn với các dự án lớn.ORM được xem như là abstracts của DB. Nếu khách hàng không để ý đến những gì thực sự xẩy ra khi sử dụng ORM. Nó rất có thể là cái bẫy với những việc N + 1 query.4 Đánh giá chỉ performance của ORM

Như ở đoạn nhược điểm mình có nói ORM sẽ có được performance chậm trễ hơn đối với việc thực hiện raw sql. Dưới đấy là một những thống kê với Eloquent ORM của Laravel và raw mysql.Môi trường:

CPU: Quad core Intel Xeon E31220Network: Broadcom NetXtreme BCM5722 Gigabit Ethernet PCI ExpressMemory: 8.0 GBHDD: 2000.4 GBOperating System: CentOS

4.1 Insert

Ở đây những nhà thử nghiệm vẫn insert số lượng bài viết khác nhau trường đoản cú 1000 đến 10000 cho cả 2 kĩ thuật trong mỗi vòng lặp.

Eloquent ORM

Số lượtSố bài bác viếtLượt 1 (ms)Lượt 2(ms)Lượt 3 (ms)Trung bình cùng (ms)Sai lệch (ms)
11000665,25619,5585,6623,539,97
220001150114011101133,320,81
330001490149014201466,740,41
440001770179016701743,364,29
550002080209022202130,078,10
660002540251025602536,725,16
770002930301030803006,775,05
880003360352033803420,087,17
990003800390038803860,052,91
10100004270436043904340,062,44

Raw SQL

Số lượtSố bài viếtLượt 1 (ms)Lượt 2(ms)Lượt 3 (ms)Trung bình cùng (ms)Sai lệch (ms)
11000195,81189,62180,1188,57,91
22000322,78335,64307,01321,814,33
33000413,4437,62458,24436,422,44
44000598,87567,57559,01575,220,98
55000725,5740,94780,15748,928,17
66000867,93869,12891,27876,113,14
770001000996,14949,05981,728,36
880001150112011301133,315,27
990001190127012201226,740,41
10100001430138014501420,036,05

Từ bảng trên ta có biểu vật dụng như sau


4.2 Update

Eloquent ORM

Số lượtSố bài xích viếtLượt 1 (ms)Lượt 2(ms)Lượt 3 (ms)Trung bình cộng (ms)Sai lệch (ms)
11000305,59316,06297,93306,59,10
22000522,06565,12543,43543,521,53
33000778,4772,33790,52780,49,26
440001040101010801043,335,11
550001290124012601263,325,16
660002540251025602536,725,16
770002930301030803006,775,05
880003360352033803420,087,17
990003800390038803860,052,91
10100004270436043904340,062,44

Raw SQL

Số lượtSố bài xích viếtLượt 1 (ms)Lượt 2(ms)Lượt 3 (ms)Trung bình cộng (ms)Sai lệch (ms)
11000195,81189,62180,1188,57,91
22000322,78335,64307,01321,814,33
33000413,4437,62458,24436,422,44
44000598,87567,57559,01575,220,98
55000725,5740,94780,15748,928,17
66000867,93869,12891,27876,113,14
770001000996,14949,05981,728,36
880001150112011301133,315,27
990001190127012201226,740,41
10100001430138014501420,036,05

Từ bảng bên trên ta bao gồm biều vật dụng sau

4.3 Select

Ở đây những thứ nghiệm chia làm 3 lượt

4.4 Đánh giá và phân tích

Từ những số liệu bên trên có thể tiện lợi thấy được performance của raw sql rõ ràng tốt hơn so với ORM trong tất cả các hành động select, insert, update.

Xem thêm: Diện Tích Hình Thoi Bằng Một Nửa Diện Tích Hình Chữ Nhật Tính Chu Vi Hình Chữ Nhật

Lí do tại đây là: ORM cần thời gian tạo model instances, tạo ra các property cho mã sản phẩm và transform đối tượng người dùng model thành tài liệu quan hệ trước khi thực hiện việc giao tiếp với database. Tất cả những gì đằng sau nó là Laravel vẫn convert từng code Eloquent ORM thành câu lệnh SQL phù hợp và kế tiếp thực thi trên tầng database và trả lại kết quả lại tầng application. Vì chưng vậy thời gian để tiến hành 1 tác vụ luôn luôn mất nhiều thời hạn hơn so với câu hỏi dùng raw sql.

Nhưng khoan, đừng vội quan sát những con số trên nhưng vội nói ORM là đồ vứt đi.

Trong thực tế không ai select vài nghìn bản ghi, hay triển khai việc tạo thành vài nghìn bản ghi vào một lúc.

Tức là khi số lượng phiên bản ghi càng không nhiều thì độ chênh lênh về hiệu suất giảm đi đáng kể. Cơ hội đó thêm vào đó việc sử dụng cách kinh nghiệm cache của ORM tạo nên ứng dụng của công ty cũng tạm chấp nhận được đối với những ích lợi về vận tốc phát tiển ứng dụng(thời gian phạt triển), loại trừ việc áp dụng code lặp đi lặp lại, bảo mật tốt hơn vào những thứ tuyệt vời nhất khác nữa.

5. Tổng kết

Tóm lại, đi xuyên thấu cả bài xích viết, tôi đã mô tả cách hoạt động vui chơi của ORM, nêu các điểm ưu điểm và điểm yếu kém của ORM. Việc có nên áp dụng ORMhay không vẫn luôn là đề tài tranh luận chưa có hồi kết.

Về tay nghề của bản thân khi có tác dụng dự án, mình thường xuyên mix giữa ORM và Raw SQL làm sao để cho hiệu quả, với những truy vấn thông thường, ORM là tuyển lựa của mình. Cùng với các tình huống phải thao tác làm việc với nhiều phiên bản ghi,raw SQL gồm vẻ hợp lí hơn. Nhưng khi sử dụng raw sql các bạn phải thực sự cẩn trọng về vấn đề Sql injection.

Xem thêm: Soạn Người Lái Đò Sông Đà Chi Tiết ), Soạn Bài Người Lái Đò Sông Đà

Cảm ơn các bạn đã theo dõi bài viết trên, trong nội dung bài viết có xem thêm từ một vài nguồn.