Collected posts: Oracle, SQL, PL/SQL, Performance, Security...(More than 300 blogs)

dimanche 22 décembre 2013

Understand Nulls values into Oracle (2) : Nulls in Conditions

This second post, we will talk about how Oracle evaluate conditions :

        A condition that evaluates to UNKNOWN acts almost like FALSE. For example, a SELECT statement with a condition in the WHERE clause that evaluates to UNKNOWN returns no rows. However, a condition evaluating to UNKNOWN differs from FALSE in that further operations on an UNKNOWN condition evaluation will evaluate to UNKNOWN. Thus, NOT FALSE evaluates to TRUE, but NOT UNKNOWN evaluates to UNKNOWN.
Table 2-20 shows examples of various evaluations involving nulls in conditions. If the conditions evaluating to UNKNOWN were used in a WHERE clause of a SELECT statement, then no rows would be returned for that query.
Table 2-20 Conditions Containing Nulls
Condition
Value of A

Evaluation
a IS NULL
10
SQL> SELECT 1 FROM DUAL WHERE 10 IS NULL;

No rows selected
FALSE
a IS NOT NULL
10
SQL> SELECT 1 FROM DUAL WHERE 10 IS NOT NULL;

         1
----------
         1

TRUE
a IS NULL
NULL
SQL> SELECT 1 FROM DUAL WHERE NULL IS  NULL;

         1
----------
         1
TRUE
a IS NOT NULL
NULL

SQL> SELECT 1 FROM DUAL WHERE NULL IS NOT  NULL;

No rows selected
FALSE
a = NULL
10
SELECT 1 FROM DUAL WHERE NULL=10;
No rows selected
UNKNOWN
a != NULL
10
SELECT 1 FROM DUAL WHERE NULL=10;
No rows selected

UNKNOWN
a = NULL
NULL
SQL> SELECT 1 FROM DUAL WHERE N!ULL=NULL;
No rows selected
UNKNOWN
a != NULL
NULL
SQL> SELECT 1 FROM DUAL WHERE NULL!=NULL;

No rows selected
UNKNOWN
a = 10
NULL
SELECT 1 FROM DUAL WHERE NULL=10;
No rows selected ucune ligne sÚlectionnÚe
UNKNOWN
a != 10
NULL
SELECT 1 FROM DUAL WHERE NULL!=10;
No rows selected
UNKNOWN
NOT(a=NULL)
NULL
SQL>  select * from dual where not(null=null)
No rows selected

UNKNOWN


For the truth tables showing the results of logical conditions containing nulls, see Table 7-5, Table 7-6, and Table 7-7.

Nulls with Comparison Conditions

To test for nulls, use only the comparison conditions IS NULL and IS NOT NULL. If you use any other condition with nulls and the result depends on the value of the null, then the result is UNKNOWN. Because null represents a lack of data, a null cannot be equal or unequal to any value or to another null. However, Oracle considers two nulls to be equal when evaluating a DECODE function. Refer toD ECODE for syntax and additional information.
Oracle also considers two nulls to be equal if they appear in compound keys. That is, Oracle considers identical two compound keys containing nulls if all the non-null components of the keys are equal.(Constraints)

In next posts we will continue to explore more behavior related to nulls values .

Understand Nulls values into Oracle (1)

The aim of this post is to explain how oracle process nulls values. It is based on Oracle Documentation. It shows different behaviors related to Nulls values.
        If a column in a row has no value, then the column is said to be null, or to contain null. Nulls can appear in columns of any datatype that are not restricted by NOT NULL or PRIMARY KEY integrity constraints. Use a null when the actual value is not known or when a value would not be meaningful.
Oracle Database treats a character value with a length of zero as null. However, do not use null to represent a numeric value of zero, because they are not equivalent.
Note:
Oracle Database currently treats a character value with a length of zero as null.

Character with a length of zeor


However, this may not continue to be true in future releases, and Oracle recommends that you do not treat empty strings the same as nulls.
Any arithmetic expression containing a null always evaluates to null. For example, null added to 10 is null.
SELECT NULL+10 FROM DUAL ; è NULL
In fact, all operators (except concatenation) return null when given a null operand.
select null||'STRING' from dual ; è ‘STRING’

ORDER BY

NULL values sort higher than NOT NULL values when ORDER BY sorts on a column containing NULL values.


  • If the null ordering is not specified then the handling of the null values is:
    • NULLS LAST if the sort is ASC
    • NULLS FIRST if the sort is DESC
  • If neither ascending nor descending order is specified, and the null ordering is also not specified, then both defaults are used and thus the order will be ascending with NULLS LAST.
 
ORDER BY DESC


For functional reasons we need get employees having the highest commissions first. There are two features used in this case:
NULLS FIRST
Specifies that NULL values should be returned before non-NULL values.
NULLS LAST
Specifies that NULL values should be returned after non-NULL values.



NULLS LAST 

In next posts we will continue to explore more behavior related to nulls values .


Next : Understand Nulls values into Oracle (2) : Nulls in Conditions


mardi 17 décembre 2013

Oratop - an interesting database monitoring tool for linux

Oratop - an interesting database monitoring tool for linux

 

Using DTrace on Oracle Linux by Richard Friedman

Using DTrace on Oracle Linux

by Richard Friedman

An introduction to DTrace probes and providers for Oracle Linux and how they are different from those in Oracle Solaris. Also covers DTrace commands and scripting. 

vendredi 22 novembre 2013

Comment vérifier et activer Parallel DML (nouveauté 11.2.0.4 et 12c)

Comment vérifier et activer Parallel DML (nouveauté 11.2.0.4 et 12c)

By Franck Pachot

Interesting article. Read it


mercredi 26 juin 2013

Oracle Database 12c Review :: Finally, a true cloud database

JUNE 26, 2013

Oracle Database 12c review: Finally, a true cloud database

Pluggable databases bring a new level of efficiency and ease to database consolidation, while a wealth of other new features address performance, availability, and more

Interesting article. Read it

mardi 26 mars 2013

Oracle White Paper :SQL Profiles: Technical Overview



What is a SQL profile? 
            A SQL profile is a set of auxiliary information specific to a SQL statement. Conceptually, a SQL
profile is to a SQL statement what statistics are to a table or index. The database can use the
auxiliary information to improve execution plans.
A SQL profile contains corrections for poor optimizer estimates discovered by the SQL Tuning
advisor. This information can improve optimizer cardinality and selectivity estimates, which in
turn leads the optimizer to select better plans.
The SQL profile does not contain information about individual execution plans. Rather, the
optimizer has the following sources of information when choosing plans:
• The environment, which contains the database configuration, bind variable values, optimizer
statistics, data set, etc.
• The supplemental statistics in the SQL profile
 Therefore, SQL profiles just guide the optimizer to a better plan.
Sql-profiles-technical-overview-128535

lundi 4 mars 2013

SYS.DBMS_SESSION :ORA-01031: insufficient privileges






Lors de l'activation de traçage Oracle en utilisant SYS.DBMS_SESSION.session_trace_enable
J'ai réçu l'erreur Oracle suivante:

ORA-01031: insufficient privilegesORA-06512: at "SYS.DBMS_SESSION", line 276ORA-06512: at line 3,
begin
dbms_session.session_trace_enable();end;

Un simple grant execute sur dbms_session package ne fonctionne pas; vous avez besoin de faire :


grant CONNECT_9I from YourOracleUser ;

Assigner le rôle CONNECT_9I à l'utilisateur oralce  YourOracleUser.

Le rôle CONNECT_9I a les privilèges nécessaires pour utiliser le Package DBMS_SESSION