400 likes | 511 Views
Datasets, Business Objects or Just LINQ. Sahil Malik www.winsmarts.com Prerequisites for this presentation: 1) .NET 2) Lots of coffee. Level: Intermediate. Sofia, Bulgaria October 10th. A little bit about me. MVP C# INETA Speaker telerik Evangelist Book Author X 3
E N D
Datasets, Business Objects or Just LINQ SahilMalik www.winsmarts.com Prerequisites for this presentation: 1) .NET 2) Lots of coffee. Level: Intermediate Sofia, Bulgaria October 10th
A little bit about me. • MVP C# • INETA Speaker • telerik Evangelist • Book Author X 3 • Article Author X n • Site: • www.winsmarts.com • Blog: • blah.winsmarts.com
A bit about what I will talk about .. • This presentation is all about practical tips, technology applied rather than technology presented. • The case for disconnected data • Mechanisms to represent disconnected data • DataSets and Business Objects • Stand in .NET 2.0, and compare the two • Code Examples. • And what happens when you throw the future in the mix?
The Connected • Pessimistic Concurrency. • Keeping a connection open – while u wait !! • A much lower possibility of concurrency conflicts. • Simpler/More Straightforward.
The Connected – Lets be Practical! • If amazon.com maintained an open database connection, for every visitor on their site. • About 40 million visitors a day • At an average, lets assume that each visitor were to stay online for 5 minutes. • Lets to be fair, assume, no connection pooling.
Connected – GEE WHIZ!! • Total number of average open connections • 40,000,000 / (24 * 60/5) = 312,500 • Total licensing cost on an Oracle database – • Ouch amount of $. • Total licensing cost on SQL Server – • Also an Ouch amount of $. • And don’t forget the nuclear power plant to run your servers.
Connected – But it’s not just about $ • What about a distributed architecture? • Web Services? • Disconnected Salesman? • The whole UDDI concept – a.k.a. Microsoft and IBM’s idea for World “Piece”.
Disconnected • Connect • Read • Disconnect • Others may use your connection. • Work on your data • Re Connect • Submit Changes • Disconnect
Demo #1 The difference connection pooling makes.
Disconnected Architecture DATA + ê DATA
Disconnected Data • Two choices • Business Objects • The DataSet family.
Business Objects - Pros • A class instance that holds your data, and represents it in a semi structured hierarchical fashion that is specific to your domain. • You can put “smarts” in your business object. • Your business object “means” something – it’s not a dumb bucket of data.
Business Objects - Cons • You have to write them • You loose the basic ability to work with data • Sorting • Searching • Filtering • Your business objects, are a complete reinvention, in every system you will ever work on.
The DataSet family - Pros • Built into the framework. • You don’t have to write it. • Comes with a decent ability to search/sort/filter etc. • You can even add limited smarts to your DataSet by adding partial classes or strongly typing the DataSet.
The DataSet family - Cons • “Limited” smarts • It’s really just a dumb bucket of data. • Not semi-structured or hierarchical • Just rows and columns.
Active BO versus Passive Dataset • Passive • Less work • Your application keeps your data clean • Lower impedance mismatch with the database • Easy SOA, more distributed. • Active • More work • Your data keeps your application clean • Higher impedance mismatch with the database • SOA is tougher, less distributed.
DataSet or BO? • So are you more of a DataSet person? Or a Business Object person? • WHAT AN AWFUL CHOICE TO MAKE!! On one hand I loose the ability to validate and represent my data. On the other, I loose searching/sorting, and have to perform a lot of work translating to and from the underlying data store. • Which is why I am looking forward to ADO.NET vNext and LINQ.
Hmmmmm ….. SO WHAT DOES LINQ*.* GIVE YOU?
Tell me, which car do you like better? BEFORE WE ANSWER THAT Ferrari Honda Civic
Tell me, which car do you like better? BEFORE WE ANSWER THAT Business Objects based Architecture Datasets based Architecture
vNext = LINQ, LINQ2SQL, LINQ2Dataset, LINQ2Entity, ADO.NET eF WHAT DOES VNEXT GIVE YOU? Business Objects based Architecture Datasets based Architecture
vNext = LINQ, LINQ2SQL, LINQ2Dataset, LINQ2Entity, ADO.NET eF HOW DOES VNEXT GIVE YOU.. Business Objects based Architecture Datasets based Architecture
vNext • .. Makes working with Business Objects easier. • LINQ • ADO.NET eF • LINQ to Entity • LINQ to SQL • .. Makes working with Datasets easier. • LINQ to DataSet
Demo #2 How LINQ makes working with Business Objects easier.
Demo #3 LINQ to DataSet – How does that help?
ADO.NET vNext –high level overview • It’s about bridging the conceptual and logical model. • The 4 models Physical Logical Conceptual Presentation
ADO.NET vNext –high level overview Database Conceptual Schema / Client Views Your Business Logic
ADO.NET vNext –high level overview • This mapping in done in various XML Files .csdl Conceptual Schema .msl The Mapping .ssdl Logical Schema
EDM – Entity Data Model • Entities • Relationship • Inheritance • “is a” relationship when tested against a base entity type. • Complex Types
What about DLINQ? • It’s called LINQ to SQL now • You can use it where the logical model and the conceptual model are the same. • Further Reading • ADO.NET vNext CTP http://shrinkster.com/i5y • DLINQ and LINQ http://shrinkster.com/i5x
A bit about release dates CLR 2.0 .NET 2.0 .NET 3.0 WF/WCF/WPF/Cardspace SharePoint 2007 Vista All this stuff Orcas, .NET vNext, ADO.NET vNext, LINQ *.* Nov 2005 End 2006ish Future
Clearing a few misconceptions • ADO.NET vNext is unlike other ORMs in the market place. • Minimalist approach, rather than everything and the kitchen sink. • ADO.NET vNext introduces the concept of “Client Views” and thus “set based theory” in object oriented code. • Queries are more sophisticated than simple string matching • It takes the approach of attacking the conceptual model, rather than get mired in object to relational translation.
Demo #4 LINQ to Entity, ADO.NET vNext – How do they help, (and not help).
Thank You www.winsmarts.com blah.winsmarts.com