Differences between revisions 1 and 28 (spanning 27 versions)
Revision 1 as of 2010-01-29 19:07:31
Size: 748
Editor: anderson-camtasia
Comment:
Revision 28 as of 2011-01-30 17:10:17
Size: 3737
Editor: 71-88-174-166
Comment:
Deletions are marked like this. Additions are marked like this.
Line 2: Line 2:
This class is about Database Management Systems. As such we talk about creating, managing and programming SQL databases. When time permits, we also cover spatial/spatial temporal data and database systems. This site contains content developed by Dr. Anderson for his classes.
Line 3: Line 4:
TODO: Intro to class... == 2011 Winter Class ==
Line 5: Line 6:
== Programming Resources ==  * [[DatabaseManagementSystems/Cptr319Schedule2011|Course Schedule 2011]]
Line 7: Line 8:
== Programming Examples ==
 * Lecture 1: It really easy that easy to do small things
  * Commandline [[DatabaseManagementSystems/DbConnectedExample|Connected Example]]
  * Forms [[DatabaseManagementSystems/DbDisconnectedExample|Disconnected Example]]
 * Lecture 2: Look at the Objects we used in the Forms from Lecture 1.
  * [[http://msdn.microsoft.com/en-us/library/system.data.dataset.aspx?PHPSESSID=tn8k5p1s508cop8gr43e1f34d2|DataSet Class]]
  * Filled by [[http://msdn.microsoft.com/en-us/library/bz9tthwx(VS.80).aspx|TableAdapter]] contained in the [[http://msdn.microsoft.com/en-us/library/bb384426.aspx|TableAdapterManager]]
  * [[http://msdn.microsoft.com/en-us/library/system.windows.forms.bindingsource.aspx|BindingSource as a service provider]]
   * How are GUI elements bound then?
   * How do the GUI elements change?
  * [[http://msdn.microsoft.com/en-us/library/system.windows.forms.bindingnavigator.aspx|BindingNavigator]]
 * Lecture 3: Detail Tables, Validation and other GUI Objects
  * What you bind to makes all the difference.
  * Responding to the Validating Event
  * For anything other than small, independent projects consider the [[http://msdn.microsoft.com/en-us/library/aa697427(VS.80).aspx|Entity Framework with LINQ]].

== Programming & Design Resources ==
Line 9: Line 27:
 * Domain Driven Design has an entire website to look at: http://domaindrivendesign.org/
 * NHibernate: NHibernate.org
 * Naked Entites/Objects (nakedobjects.com) is a for pay framework
 * CSLA.NET
 * SpecExpress specexpress.codeplex.com
 * [[http://www.fabforce.net/dbdesigner4/|DBDesigner]] is an awesome tool that went for pay by oracle now. Get the old one and don't pay for the ability to reverse engineer a diagram from a database. Works with Oracle, MSSQL and MySQL.
 * [[http://domaindrivendesign.org/|Domain Driven Design website]]
 * [[http://msdn.microsoft.com/en-us/practices/default.aspx|MSDN Patterns and Practices]]
 * [[http://nhibernate.org|NHibernate]]
 * [[http://www.nakedobjects.com|Naked Entites/Objects is a for pay framework]]
 * [[http://www.lhotka.net/cslanet/|CSLA.NET]]
 * [[http://specexpress.codeplex.com|SpecExpress]]
 * [[http://www.jetbrains.com/teamcity/download/|TeamCity]]
 * [[http://sourceforge.net/projects/automapper-dn/|AutoMapper]]
 * [[http://www.linqpad.net/|Link Pad]] allows you to write scratch c# LINQ code and claims it can be used as a drop in replacement for SQL Server Management Studio
Line 17: Line 40:
== Chapter Hints ==
Line 18: Line 42:
  === Chapter 6.1: Relational Algebra ===

READ THIS BEFORE YOU DO YOUR HOMEWORK!

'''Rule 1:''' You don't need to qualify the results of a natural join. The results of a natural join ALWAYS only have one copy of overlapping attributes.

'''Rule 2:''' Predicates, attribute lists and functions in <<latex($\sigma, \Pi, \mathcal{G}$)>> are always subscript.

'''Rule 3:''' Relations, whether expressions or names, NEVER appear as a superscript or subscript.

'''Rule 4:''' Input relations, whether expressions or name, always have parenthesis around them. E.g.

<<latex(\Huge$_{sect\_id,course\_id,year,semester}\mathcal{G}_{count(ID)}(student \bowtie takes)$)>>

Database Management Systems

This class is about Database Management Systems. As such we talk about creating, managing and programming SQL databases. When time permits, we also cover spatial/spatial temporal data and database systems. This site contains content developed by Dr. Anderson for his classes.

2011 Winter Class

Programming Examples

Programming & Design Resources

Learning to program something more complex than a one off programming assignments for students can be difficult. Where do the experts learn to program large database applications and what tools and methods do they use? This section is not an answer, but a suggestion on where to look for those answers. Someday, I hope to have a class that explores this in depth.

And many more to follow I'm sure.

Chapter Hints

Chapter 6.1: Relational Algebra

READ THIS BEFORE YOU DO YOUR HOMEWORK!

Rule 1: You don't need to qualify the results of a natural join. The results of a natural join ALWAYS only have one copy of overlapping attributes.

Rule 2: Predicates, attribute lists and functions in <<latex($\sigma, \Pi, \mathcal{G}$)>> are always subscript.

Rule 3: Relations, whether expressions or names, NEVER appear as a superscript or subscript.

Rule 4: Input relations, whether expressions or name, always have parenthesis around them. E.g.

<<latex(\Huge$_{sect\_id,course\_id,year,semester}\mathcal{G}_{count(ID)}(student \bowtie takes)$)>>

DatabaseManagementSystems (last edited 2024-02-25 16:33:21 by scot)