|
Posted by Tony Rogerson on 10/02/64 11:47
> Agreed with your example, but in the real world, case can matter for some
> data. Is your name "tony", "Tony", or "ToNy"? It does make a difference
> when referring to proper nouns. If it didn't make a difference, then "e.
> e. cummings" name would not have garnered so much attention throughout the
> years.
The default setting should reflect what is the general, and in my experience
and opinion case insensitive is the general, all you are doing is comparing
and building a collation rule based on grammar.
Think through the example, there is no case in speech only gramatical rules.
Is Mac Mc, Mac etc...
Case does matter at times, but is it the general case, what proportion of
the time does it matter 80/10 (not/matters)???
> So assume that you allow object names to be case sensitive. Then assume
> that you port from a RDBMS that allows this to an RDBMS that does not. You
> will run in to a problem trying to create that second Employees table no
> matter how it is spelled (case-wise). If you truly want to consider
> portability, you will make your object names different regardless of case.
Assume you develop on your oracle system which is case insensitive, the
sloppy developer references the table as Employee and then employee in views
meaning the same table - it will work, now move that implementation to a
case sensitive database and it breaks - thats my point, case insensitive
promotes sloppy programming, I follow Erlands example, all object names and
identifiers are lower case and then you have no problems.
The problems gets worse when programmers start referencing those identifier
names in applications.....
--
Tony Rogerson
SQL Server MVP
http://sqlserverfaq.com - free video tutorials
"Brian Peasland" <oracle_dba@nospam.peasland.net> wrote in message
news:Iz5vJz.9p4@igsrsparc2.er.usgs.gov...
>> As for data Oracle has it completely wrong,
>
> If you do not like the default collation, then change it. Both SQL Server
> and Oracle let you change the case sensitivity of its data.
>
>> collation should reflect the real world if a salesman shouts out AKA do
>> they mean aka, Aka, AKa, AKA or what????
>
> Agreed with your example, but in the real world, case can matter for some
> data. Is your name "tony", "Tony", or "ToNy"? It does make a difference
> when referring to proper nouns. If it didn't make a difference, then "e.
> e. cummings" name would not have garnered so much attention throughout the
> years.
>
> Sometimes, case does not matter, sometimes it does.
>
>> You should not have to rely on doing this data verification yourself,
>> adding constraints to check case etc... is just making up for a poor
>> initial decision to go with case sensitivity.
>>
>> This is the biggest pain in the arse in the business intelligence and
>> reporting area.
>
> Agreed! I worked on a project where we had to compare the address someone
> entered with what was in our database. Using case sensitive searching,
> "ave" does not match "Ave" or "AVE". Of course, it does not match "Avenue"
> either but that is a different animal to skin.
>
>> Case Insensitive is how the real world works and that should be the
>> default for any database 'period'.
>
> I would disagree. Modelling the real world is rarely as simple as black
> and white. If one comes up with a hard and fast rule, you'll come up with
> an exception to that rule. If you do not like my example above with proper
> nouns, then consider this example:
>
> I have a business rule to store my user's password in a table in my
> database. That password is composed of characters and numbers.
> Furthermore, to increase my password complexity, I require at least one
> lower case character and at least one upper case character. Case
> sensitivity is now a must. Windows uses case sensitivity in its passwords
> as do some applications.
>
> In many cases, the real world does not matter what case you use. But in
> some cases, case does matter.
>
>> As for Object names it shouldn't matter but case insenitive promotes poor
>> programming practice.
>
> It respectfully disagree here as well. If object names are allowed to be
> case sensitive, then a table with name "Employees" would differ from a
> table named "employees". Two tables with two different names (based on
> case), but seem to be representing the same real world entity. Which table
> do I use to to get my company's employee information? Object names being
> case sensitive can lead to confusion when the only difference between the
> objects (on the surface) is the case sensitivity to their names.
>
>> Consider portability to other products and systems.....
>
> So assume that you allow object names to be case sensitive. Then assume
> that you port from a RDBMS that allows this to an RDBMS that does not. You
> will run in to a problem trying to create that second Employees table no
> matter how it is spelled (case-wise). If you truly want to consider
> portability, you will make your object names different regardless of case.
>
> And object names being case insensitive or case sensitive really is not
> about programming, but rather database schema design. Maybe it's splitting
> hairs, but these are two different things.
>
> Cheers!
> Brian
>
>
> --
> ===================================================================
>
> Brian Peasland
> oracle_dba@nospam.peasland.net
> http://www.peasland.net
>
> Remove the "nospam." from the email address to email me.
>
>
> "I can give it to you cheap, quick, and good.
> Now pick two out of the three" - Unknown
[Back to original message]
|