Saturday, October 27, 2007

Continuación %ROWTYPE

A few days ago, I posted an entry, Anchored Declarations - %TYPE and %ROWTYPE. That article talked about using anchored declarations in your PL/SQL code.

PeteF ask a couple of questions about that post:

Inglés:

Nice little article - I have a couple of questions... Is there any way to utilise the %rowtype attribute from within a trigger i.e. can I easily populate a rowtype variable with all the old (or new) columns in one shot? Number two - is there an easy way to write the rowtype variable back to the DB without having to mention every column name? As you say in your article - all sacrilege I'm sure but hey ;) tia Pete


Español
Niza poco el artículo - Tengo un par de preguntas ... ¿Hay alguna forma de utilizar el atributo de rowtype% dentro de un disparador es decir que fácilmente puede rellenar el rowtype variable con todas las viejas (o nuevas) las columnas de una sola? Número dos, hay una forma sencilla de escribir la variable de rowtype al PP, sin tener que mencionar el nombre de columna? Como usted dice en su artículo, todos los sacrilegio estoy seguro, pero bueno;) Pete tia


Pete - No puedo ayudarle en la pregunta # 1. Por lo que sé, usted tiene que hacer referencia a cada una de las columnas por separado cuando se utiliza :new y :old. Hay que ser agradable ser capaz de ceder todo en una marejada foop pero por desgracia, :new y :old son seudo columnas, en contraposición a los registros.

Sobre la pregunta, el número 2, la respuesta es afirmativa. Puedes seleccionar una rowtype variables, hacer algunos cambios y, a continuación, inserte de nuevo.

declare
v_emp_rec employees%rowtype;
begin
select *
into v_emp_rec
from employees
where rownum = 1;

v_emp_rec.last_name := 'Lewis';
v_emp_rec.first_name := 'Cunningham';
v_emp_rec.email := 'lewis@email.com';
v_emp_rec.employee_id := 9999;

insert into employees values v_emp_rec;

end;
/


En ésta, que ha cambiado los campos requeridos (PK y el mensaje que es una clave única) y el nombre y, a continuación, inserta la fila como una fila nueva.

Schwierman también publicó un comentario:

Inglés:
Number two...

Have you tried the bulk collect update statement. I am using a table array, but, maybe a rowtype would work.

FORALL x IN 1 .. ptbl_lp_io.COUNT SAVE EXCEPTIONS
UPDATE lp
SET ROW = ptbl_lp_io (x)
WHERE lp_id = ltbl_lp_id (x);


Español
Número dos ...

Has intentado recoger la mayor parte de actualización. Estoy utilizando una tabla matriz, pero tal vez un rowtype de trabajo.

FORALL x IN 1 .. ptbl_lp_io.COUNT SAVE EXCEPTIONS
UPDATE lp
SET ROW = ptbl_lp_io (x)
WHERE lp_id = ltbl_lp_id (x);


Creo que se pete responder a la segunda pregunta del uso de bulk collect. Un completo ejemplo de ello es:

SQL> CREATE TABLE employees_new AS SELECT * FROM employees WHERE ROWNUM < 1;

Table created.

SQL> SELECT COUNT(*) FROM EMPLOYEES;

COUNT(*)
----------
107

SQL> SELECT COUNT(*) FROM employees_new;

COUNT(*)
----------
0

SQL> DECLARE
2
3 type arr_emp_recs IS TABLE OF employees % rowtype;
4 v_emp_rec arr_emp_recs;
5 BEGIN
6
7 SELECT *
8 bulk collect
9 INTO v_emp_rec
10 FROM employees;
11
12 FORALL x IN 1..v_emp_rec.COUNT
13 INSERT INTO employees_new VALUES v_emp_rec(x);
14
15 COMMIT;
16
17 END;
18 /

PL/SQL procedure successfully completed.

SQL> SELECT COUNT(*) FROM employees_new;

COUNT(*)
----------
107

SQL>

Declaraciones anclado - %TYPE y %ROWTYPE

Cuando se declara una variable, hay que darle un tipo de datos y de un tamaño.

Vamos a suponer por un momento que tengo una tabla que se parece a esto:

SQL> desc employees
Name Null? Type
----------------------------------------- -------- ----------------------------
EMPLOYEE_ID NOT NULL NUMBER(6)
FIRST_NAME VARCHAR2(20)
LAST_NAME NOT NULL VARCHAR2(25)
EMAIL NOT NULL VARCHAR2(25)
PHONE_NUMBER VARCHAR2(20)
HIRE_DATE NOT NULL DATE
JOB_ID NOT NULL VARCHAR2(10)
SALARY NUMBER(8,2)
COMMISSION_PCT NUMBER(2,2)
MANAGER_ID NUMBER(6)
DEPARTMENT_ID NUMBER(4)
SQL>


Podría crear un pl/sql- código de la unidad que acceder a algunas de estas columnas. Por ejemplo:

DECLARE
v_employee_id NUMBER(6);
v_hire_date DATE;
v_last_name VARCHAR2(25);
BEGIN
SELECT employee_id, last_name, hire_date
INTO v_employee_id, v_last_name, v_hire_date
FROM employees
WHERE rownum = 1;
END;


En este fragmento de código, declaró el número 6 dígitos de longitud, una fecha y un varchar2 de 25 caracteres de largo. Aunque estos tamaños coinciden con mi cuadro, hay una forma mejor de hacer esto:

DECLARE
v_employee_id employees.employee_id%TYPE;
v_hire_date employees.hire_date%TYPE;
v_last_name employees.last_name%TYPE;
BEGIN
SELECT employee_id, last_name, hire_date
INTO v_employee_id, v_last_name, v_hire_date
FROM employees
WHERE rownum = 1;
END;


Mismos resultados, pero ahora mi software es sólo un poco más fácil de mantener. Si yo uso constantemente %TYPE todo mi código, puede cambiar el tamaño de columna con un poco menos preocupación. Técnicamente, puede ser capaz de cambiar los tipos de datos y estar bien, pero he encontrado que, en la práctica, cuando el usuario cambia los tipos de datos, se necesitará revisar una gran cantidad de su código.

%TYPE es usado cuando usted se refiere son las columnas individuales. Hay muchos casos en donde será usado toda una fila. En lugar de crear manualmente un tipo de registro, puede declarar una variable de %ROWTYPE. Por ejemplo, a continuación voy a seleccionar todas las columnas de mi tabla:

DECLARE
v_employees employees%ROWTYPE;
BEGIN
SELECT *
INTO v_employees
FROM employees
WHERE rownum = 1;
END;


Esta recoge la totalidad de las columnas y los ponga a disposición en su programa. Puede detallar cada una de las columnas en su lista de selección como este:

DECLARE
v_employees employees%ROWTYPE;
BEGIN
SELECT employee_id, first_name, last_name,
email, phone_number, hire_date, job_id, salary,
commission_pct, manager_id, department_id
INTO v_employees
FROM employees
WHERE rownum = 1;
END;


Si lo hace detallar cada una de las columnas, es necesario mantenerlos en las columnas en el mismo orden que se declaran en su mesa. Si añade una columna de la tabla, tendrá que modificar su código.

"SELECT *" es más fácil de leer. Asimismo, en los casos en que es necesario recoger las nuevas columnas (por lo general, los procedimientos de mantenimiento tipo), "SELECT *" recoge nuevas columnas con un solo recompilar, en contraposición a la necesidad de añadir manualmente las columnas.

Este es un caso en el que usted necesita para hacer una llamada en cuanto a si un "SELECT *" es una mala cosa o no. Yo no tengo un problema con el "SELECT *" en estos casos. En realidad, me atrevería a decir incluso recomendar que en el caso de que usted realmente necesita todas las columnas (o incluso la mayoría de las columnas). Me doy cuenta de que es una herejía para muchos. Oh, bien.

Una última nota es que %TYPE y %ROWTYPE también como parámetros de trabajo y es una gran manera de enviar datos en torno a que es arrastrada desde su base de datos. Por ejemplo:

CREATE OR REPLACE 
PROCEDURE get_employee( p_employee_rec OUT employees%ROWTYPE )
AS
BEGIN
SELECT *
INTO p_employee_rec
FROM employees
WHERE rownum = 1;
END;


Este fragmento de código devolverá un registro de los datos del empleado a la llamada de rutina.

%TYPE y %ROWTYPE se llaman anclado declaraciones. Básicamente, usted es el tipo de datos de su anclaje declaraciones a la columna de definiciones en su base de datos. Además de asegurar que sus datos tipos y tamaños siempre coinciden, se hace más fácil ya que el código no tiene que buscar los tamaños, así como cada vez que escribir un pedazo de código.

Utilice anclado declaraciones. Utilizar de manera consecuente y la gente que sigue a lo largo de atrás para mantener su código gracias.

Saturday, October 13, 2007

Por favor, ayúdame a cabo y responder a una pregunta

Como es posible que puedas decir, no soy un experto español. Quería crear un blog para que más personas puede ayudar a empezar con Oracle por lo que optaron por crear un blog que se escribe en español. Yo uso el traductor Google herramienta para crear este blog de escritos que he hecho en inglés.

Entonces, mi pregunta es, ¿encontraste esta página útil? Aun con la mala gramática? ¿Le gustaría a mí seguir con la publicación?

Gracias de antemano por su respuesta. Soy consciente de que tomar el tiempo para hacerlo.

LewisC

¿Qué es una base de datos de enlace?

Una base de datos de enlace es la forma de Oracle le permite conectarse desde una base de datos a otro. Un enlace a la base de datos de una base de datos remota utilizando una ID y una contraseña al igual que un usuario, pero sólo permite el acceso programático.

Base de datos permitirá a los vínculos de procesamiento distribuido. Replicación es un excelente ejemplo de una aplicación que utiliza la base de datos enlaces. Replicación de bases de datos Oracle utiliza vínculos con el movimiento de datos de una base de datos a otro.

Un vínculo es una base de datos en un solo sentido conducto que le permita realizar LMD contra bases de datos remotas al igual que lo haría en contra de una base de datos local. Su SQL no es necesario cambiar los requisitos, salvo que la base de datos que desea acceder.

En segundo lugar, la vinculación requiere de bases de datos remotas de base de datos que se definan a su servidor. El cliente pueda que no saben nada acerca de una base de datos y que todavía existe la posibilidad de crear un enlace. Lo inverso también es válido; Si el cliente es consciente de una base de datos, pero el servidor no es, no puede crear un vínculo.

Ejemplos de la creación y uso de PP Enlaces

Seleccione sysdate doble de la tabla en una base de datos remota RemoteDB nombres de los usuarios conectados mediante un enlace:

CREATE DATABASE LINK MyRemoteDB USING 'RemoteDB';

SELECT sysdate FROM DUAL@MyRemoteDB;


Ejecutar un procedimiento almacenado en la base de datos remota:

BEGIN
runProc@MyRemoteDB;
END;


Ejecuta una función envasados en la base de datos remota:

DECLARE
var1 VARCHAR2(10);
BEGIN
Var1 := runFunc@MyRemoteDB;
END;


Crear una cuenta utilizando el seleccionado anteriormente:

CREATE OR REPLACE VIEW Remote_Sysdate_VW AS
SELECT sysdate AS remoteSysdate
FROM DUAL@MyRemoteDB;

SELECT * FROM remote_sysdate_vw;

¿Cuáles son los NCHAR y NVARCHAR2 tipos de datos?

Usted podrá declarar NVARCHAR2 lugar de VARCHAR2. NVARCHAR2 se utiliza para almacenar los conjuntos de caracteres Unicode. Yo, personalmente, nunca han tenido un uso para NVARCHAR2. Si escribir aplicaciones multilingües y utilizar un juego de caracteres Unicode, en lugar de utilizar NVARCHAR2 VARCHAR2. CHAR también tiene un correspondiente NCHAR.

Largo restricciones son las mismas que un VARCHAR2 y UTF8 puede almacenar 32767 dividido por 2 y UTF16 puede almacenar 32767 dividido por 3. No se puede mezclar y combinar VARCHAR2 NVARCHAR2 y las variables. Usted debe escoger uno o el otro y se pegan con él. Ambos están disponibles en SQL y PL / SQL.

What is the CHAR Datatype?

CHAR es una longitud fija de datos. Si no se especifica un tamaño máximo, el valor por defecto es 1. El tamaño máximo para un carácter en una columna es de 2000 bytes y 32767 en PL / SQL.

Yo bastante considerar CHAR a ser un legado de datos. Algunas personas utilizan CHAR (1) para almacenar indicadores (Y, N, etc) o como una tabla BOOLEAN. Prefiero usar VARCHAR2 incluso en esos casos.

Un caso que puede estar justificada (en mi opinión, de todos modos, esta es mi opinión) sería rellenar los datos desde o hacia un modelo de informe que tendrá que ser reproducida. Por ejemplo, si lee un archivo de longitud fija, y puede que necesite para generar el archivo de longitud fija que en el futuro, que se va a guardar su conversión de algunos generales por el almacenamiento de los datos en una longitud fija de datos (es decir CHAR).

Una de las áreas que la gente meterse en problemas son CHAR y VARCHAR2 comparaciones. Si se quede con VARCHAR2, usted no tendrá problemas.

¿Cuál es la FECHA Dato?

DATE El dato es un dato fecha. Almacena una fecha y una hora. La fecha parte se basa en el número de días desde el 1 de enero de 4712 aC. El tiempo se basa en el número de segundos desde mediados de la noche.

Un campo de fecha se declara como una variable seguida por el nombre DATE palabra clave:

v_date_field DATE;

No hay "correcto" el formato de una fecha. El formato está determinada por varios factores. En la base de datos, se puede establecer que la NLS_DATE_FORMAT. Independientemente de cómo se establece el valor por defecto en su base de datos, siempre debe asegurarse de que explícitamente el uso de un formato de fecha al convertir la máscara.

Voy a cubrir funciones de la conversión de todos los tipos de datos en un futuro artículo, pero creo que esto es importante. Si necesita comparar una fecha para un literal, asegúrese de usar un formato de fecha máscara. Usted podría decir:

WHERE date_field = '01-01-1999'

O usted podría decir:

WHERE date_field = to_date('01-01-1999', 'DD-MM-YYYY')

Y eso nos lleva a la razón por la que utilizar un DATE lugar de un personaje o de un campo numérico. Yo estoy a menudo preguntó acerca de las mejores prácticas, con fechas y horas. Por alguna razón, nunca he entendido, algunas personas consideran que el almacenamiento de las fechas y horas como el número de caracteres y es mejor que la de Oracle que permite que los datos que manejan en un formato nativo. Llámame vago, pero si Oracle puede hacerlo por mí, voy a dejarlo.

A modo de ejemplo, digamos que usted desea añadir 1 día a la fecha. Si esa fecha se almacena en un personaje sobre el terreno, usted tendría que hacer algún tipo de transformación y manipulación de lograr eso. Si usamos una fecha sobre el terreno, es tan fácil como date_field + 1. ¿Cómo lograr la adición de una hora? El uso de un tipo de la fecha, no puedo añadir date_field + 1 / 24. Es decir, añadir un 1 a 1 día y obtener añadir 1/24th de un día llegar hasta 1 hora. Para añadir 2 horas, yo añadiría date_field + 2 / 24. ¿Cómo hacerlo con un carácter sobre el terreno?

Reconozco si almacena los datos en un campo numérico, que puede ser más fácil de almacenar como un personaje. En ese caso, la adición de 1 día o 1 hora podría ser bastante fácil. Pero, ¿cómo se puede añadir 3 meses? Con un campo de fecha, se utiliza add_months (date_field, 3). ¿Cómo restar 3 meses? Con un campo de fecha, se utiliza add_months (date_field, -3). ¿Cómo obtener el último día del mes en un campo de fecha? Con un campo de fecha, se puede decir last_day (date_field). La lista va en un sobre.

Aquí está una de las normas más importantes que usted puede aprender acerca de cómo utilizar una base de datos. Si puede hacerlo por ti, y mucho. Si se trata de la fecha o la hora, por no hablar de que la gestión de la base de datos para usted. Gastar su tiempo escribiendo aplicaciones, y no bajo nivel de apoyo rutinas.

Algunas normas acerca de la fecha en que las matemáticas son cuando usted restar una fecha a partir de la fecha, se obtiene un número de días. Al restar el número de una fecha, se obtiene una fecha menos de la fecha de inicio. Cuando se añade un número a la fecha, se obtiene una fecha posterior a la fecha de inicio. No se puede añadir una fecha a fecha.

Saturday, October 6, 2007

El usar NVL2

NVL2 es una pequeña función aseada del SQL que pienso soy underused. Se parece a mí que podría tener un nombre mejor.

El formato es NVL2 (expr1, expr2, expr3). Qué lo hace es si expr1 es NULL, él vuelve expr3. Si expr1 NOT NULL, vuelve expr2.

IF la declaración para hacer igual parecería:

IF expr1 IS NULL 
THEN
expr3
ELSE
expr2
END IF


Tiendo para conseguir expr2 y expr3 al revés cada vez que utilizo esta función. No soy seguro porqué. Conjeturo que resuelvo mentalmente expresiones del non-NOT antes NO de expresiones.

Tan si funcionaste esta escritura:

SELECT nvl2('ABC', 'DEF', 'GHI')
FROM DUAL
/


SELECT nvl2(NULL, 'DEF', 'GHI')
FROM DUAL
/


Conseguirías esta salida:

NVL
---
DEF


1 row selected.


NVL
---
GHI


1 row selected.

Quitar los espacios después de TO_CHAR con el modificante del formato de FM

Hoy, voy a darte una extremidad de Oracle para conseguir librado de espacios después de que hayas utilizado TO_CHAR:

Si funciono esta escritura:

select to_char(1234.89, '$999,990.00') num_format
from dual
/

select to_char(SYSDATE, 'Day, Month DD, YYYY') date_format
from dual
/

Consigo:

NUM_FORMAT
------------
$1,234.89

1 row selected.

DATE_FORMAT
-----------------------------
Friday , August 14, 2006

1 row selected.

¿Notas el plomo el espaciar en la primera declaración y el espaciamiento impar en el segundo?

Eso puede ser molesto. Conseguir libró de él, uso justo el modificante de la máscara del formato de FM.

Ahora puedo funcionar esto:

Y consigo:

NUM_FORMAT
------------
$1,234.89

1 row selected.

DATE_FORMAT
-----------------------------
Friday, August 14, 2006

1 row selected.

Monday, October 1, 2007

¿Cuál es la diferencia entre el SQL y PL/SQL?

¿Cuál es SQL?

El SQL se compone de DML y de DDL. DML son las palabras claves que utilizas tener acceso y manipular a datos, por lo tanto la lengua de manipulación de datos conocida. DDL son las palabras claves que utilizas crear objetos tales como opiniónes, tablas y procedimientos, por lo tanto el idioma de definición de datos conocido. Los ejemplos de DML son SELECT, UPDATE, INSERT, MERGE, DELETE, etc. Los ejemplos de DDL son CREATE TABLE, ALTER VIEW, CREATE OR REPLACE PROCEDURE, el etc.

Ejemplo DDL:


CREATE TABLE whatever (
column1 NUMBER NOT NULL PRIMARY KEY,
column2 VARCHAR2(10),
column3 DATE );


Ejemplo DML:


INSERT INTO whatever (column1, column2, column3)
VALUES (1, 'Text Data', sysdate );

SELECT column1, column2, column3
FROM whatever;

COMMIT;


¿Cuáles son comandos del SQL?

Los comandos del SQL son los comandos que no son realmente una parte del estándar del SQL pero son apoyados por las herramientas que apoyan el SQL. Por ejemplo, el SQL*Plus ha estado alrededor de un de largo plazo y muchas herramientas que permiten el scripting también permiten comandos del SQL*Plus. Cuando alguien me pregunta acerca de un comando del SQL, primero clarifico si el medio una palabra clave del SQL o un comando del SQL*Plus (o un poco de otra herramienta).

Los comandos del SQL se significan generalmente de ayudar a formato para hacer salir: La BREAK, BTITLE, COLUMN, PRINT o ellos se significan para crear o para almacenar datos o las escrituras: COMPUTE, DEFINE, STORE, SAVE. Hay también los comandos que obran recíprocamente con la base de datos: SHUTDOWN, CONNECT, COPY. Y hay por lo menos uno que obra recíprocamente con datos: XQUERY.

Tan cuando oyes a alguien referir a un comando del SQL, primero preguntar si realmente significan el SQL o si significan la herramienta del SQL ellos están utilizando.

¿Cuál es PL/SQL?

La respuesta rápida es de la guía del usuario de PL/SQL:

PL/SQL, extensión procesal de Oracle del SQL, es un lenguaje de programación fourth-generation avanzado (4GL). Ofrece características de la software-ingeniería tales como encapsulación de datos, sobrecargar, tipos de la colección, excepciones, y ocultar de la información. PL/SQL también apoya prototyping y el desarrollo rápidos con la integración apretada con el SQL y la base de datos de Oracle.


¿Pero qué ese medio? La llave aquí es las palabras: extensión procesal del SQL. PL/SQL es una lengua procesal como C++, Java, ADA, etc. Si tiene variables y declaraciones de la variable, los controles condicionales como IF y CASE. Tiene estructuras de colocación tales como LOOP, FOR LOOP y WHILE LOOP. PL/SQL utiliza el SQL para utilizar, para manipular y para ahorrar datos a la base de datos.

Si deseara crear mis el propios, muy corto, definición de PL/SQL sería ésta: PL/SQL es el lenguaje de programación nativo de Oracle que proporciona el desarrollo base de datos-céntrico del uso. Puede llamar nativo el SQL estático y proporciona métodos múltiples de llamar el SQL dinámico.

Ejemplo PL/SQL:


BEGIN
-- A PL/SQL cursor
FOR c1 IN (
SELECT * FROM whatever ) -- This is SQL called by PL/SQL
LOOP

DBMS_OUTPUT.PUT_LINE( 'Column1 is: ' || TO_CHAR(c1.column1) ||
', Column2 is: ' || c1.column2 ||
', Column3 is: ' || TO_CHAR(c1.column3 ) );
END LOOP;

END;


Y ahora la respuesta a la pregunta principal: ¿cuál es la diferencia entre el SQL y PL/SQL? El SQL es una lengua orientada los datos para los sistemas que seleccionan y de manipulaciones de datos. PL/SQL es una lengua procesal para crear usos. No tienes normalmente un “uso del SQL”. Tienes normalmente un uso que utilice el SQL y una base de datos emparentada en el back-end. PL/SQL puede ser la lengua del uso apenas como Java o poder de PHP. El SQL puede ser la fuente de los datos para tus pantallas, Web pages e informes. PL/SQL pudo ser la lengua que utilizas construir, ajustar a formato y exhibir esas pantallas, Web pages e informes.

Pensar en él tienen gusto de esto: El código que hace tu función del programa es PL/SQL. El código que manipula los datos es SQL DML. El código que crea objetos almacenados de la base de datos es SQL DDL. DDL compila el código que se escribe en PL/SQL. PL/SQL puede llamar el SQL para realizar la manipulación de datos. Los comandos que ajustaron a formato la salida de una herramienta no se relacionan con el SQL estándar o con PL/SQL.

My Zimbio
KudoSurf Me!