Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   Sentencia SQL desde Delphi con Cremillas (https://www.clubdelphi.com/foros/showthread.php?t=76826)

BlueSteel 29-11-2011 20:07:51

Sentencia SQL desde Delphi con Cremillas
 
Hola a Todos...

Espero que el titulo sea el adecuado, y les cuento el error que tengo

ejecuto una sentencia en el SQL Server y funciona super bien

Código SQL [-]
SELECT IDENT_CURRENT('Tarjeta') as Num

Lo que hace la sentencia anterior es asignar a Num el valor actual del Campo Identidad de una Tabla (Tarjeta)

si ejecuta la sentencia desde delphi 7, me da error, y se que son las cremillas que estan antes y despues de Tarjeta.... pero no se como ponerlas

Código Delphi [-]
Datos.AQ_Select.Close;
Datos.AQ_Select.SQL.Clear;
Datos.AQ_Select.SQL.Add('Select Ident_Current('Tarjeta') as Num');
Datos.AQ_Select.Open;

Ahora la pregunta es como declaro las Cremillas dentro de una sentencia de SQL desde Delphi...

Si le quito las cremillas si bien compila, me arroja error de ejecución...

Salu2:D:p:confused:

roman 29-11-2011 20:17:45

Código Delphi [-]
Datos.AQ_Select.SQL.Add('Select Ident_Current(''Tarjeta'') as Num');

Por cierto, son comillas, no cremillas :)

// Saludos

newtron 29-11-2011 20:23:07

Cita:

Empezado por roman (Mensaje 419889)
Código Delphi [-]Datos.AQ_Select.SQL.Add('Select Ident_Current(''Tarjeta'') as Num');


Por cierto, son comillas, no cremillas :)

// Saludos

¿Eso se lo traga?

Yo hubiera pensado que se hacía así:

Código Delphi [-]
Datos.AQ_Select.SQL.Add('Select Ident_Current('+QuotedStr('Tarjeta')+') as Num');

roman 29-11-2011 21:07:59

Sí. En delphi, para poner una comilla dentro de una cadena de texto, se pone dos veces. Pero también como tú lo propones se puede.

// Saludos

BlueSteel 29-11-2011 21:54:35

Tnks Roman... ha... y sorry... ahora se llaman comillas.... ;):D

Casimiro Noteví 29-11-2011 22:28:10

Cita:

Empezado por BlueSteel (Mensaje 419898)
... ahora se llaman comillas.... ;):D

Yo lo he conocido como "comillas" de toda la vida, comillas simples y comillas dobles.

ecfisa 30-11-2011 00:41:25

Cita:

Empezado por Casimiro Notevi (Mensaje 419903)
Yo lo he conocido como "comillas" de toda la vida, comillas simples y comillas dobles.

También yo. Ante la duda de que fuera otro modo de llamarlas, busque en la web y parece ser que cremillas es sinónimo de lo que yo conocía por diéresis.

Saludos. :)

olbeup 30-11-2011 08:37:55

Cita:

Empezado por ecfisa (Mensaje 419921)
También yo. Ante la duda de que fuera otro modo de llamarlas, busque en la web y parece ser que cremillas es sinónimo de lo que yo conocía por diéresis.

Saludos. :)

Si parece una enfermeda diéresis parecido a diálisis, que mal suena, mejor llamar comillas simples o dobles, no os parece.

Un saludo.

Casimiro Noteví 30-11-2011 09:06:57

En el diccionario no viene cremilla, ni en ningún sitio que he mirado.

newtron 30-11-2011 09:26:14

Cita:

Empezado por roman (Mensaje 419896)
Sí. En delphi, para poner una comilla dentro de una cadena de texto, se pone dos veces. Pero también como tú lo propones se puede.

// Saludos

Lo digo porque mi base de datos no se traga las comillas dobles en las instrucciones, tienen que ser simples.

Por cierto... ¿cremilla no es eso que nos echamos para el sol en la playa? :p

olbeup 30-11-2011 09:50:51

Si, para evitar el sol, tan bonito que tenemos en españa.

ecfisa 30-11-2011 15:53:20

Cita:

Empezado por olbeup (Mensaje 419929)
Si parece una enfermeda diéresis parecido a diálisis, que mal suena, mejor llamar comillas simples o dobles, no os parece.

Un saludo.

Es que cremillas ni siquiera es sinónimo de comillas dobles o simples. Es sinónimo de diéresis (¨), como la utilizada en la letra u de la palabra pingüino.

Saludos. :)

Al González 30-11-2011 15:59:54

Cita:

Empezado por olbeup (Mensaje 419929)
Si parece una enfermeda diéresis parecido a diálisis, que mal suena, mejor llamar comillas simples o dobles, no os parece.

Las comillas son las comillas (', ", «, »...) y la diéresis es la diéresis (¨ -> ü). Dos cosas muy diferentes.

Las palabras que "suenan mal" son aquellas que se leen con prejuicios y las que se escriben con descuido. :)

newtron 30-11-2011 16:52:58

Por favor, si teneis un tema distinto del original deberiais de crear un hilo nuevo, ¿habéis leido ya la guía de estilo? :p:D

Casimiro Noteví 30-11-2011 17:13:52

Cita:

Empezado por newtron (Mensaje 419991)
Por favor, si teneis un tema distinto del original deberiais de crear un hilo nuevo, ¿habéis leido ya la guía de estilo? :p:D

Cierto :)
Pues entonces, otra forma:

Código Delphi [-]
Datos.AQ_Select.SQL.Add('Select Ident_Current('+#39+'Tarjeta'+#39+') as Num');

roman 30-11-2011 17:25:02

Cita:

Empezado por newtron (Mensaje 419935)
Lo digo porque mi base de datos no se traga las comillas dobles en las instrucciones, tienen que ser simples

Como yo lo puse no son comillas dobles sino dos comillas sencillas juntas. Cuando el compilador ve eso, pone una sólo comilla (necesita las dos sólo para saber que dicha comilla forma parte del texto y no es el delimitador de éste), de manera que lo que llega al servidor es una comilla sencilla.

Por otra parte es raro que no acepte comillas dobles, ¿qué servidor es?

// Saludos

newtron 30-11-2011 17:32:47

Cita:

Empezado por roman (Mensaje 420003)

Por otra parte es raro que no acepte comillas dobles, ¿qué servidor es?

// Saludos

ElevateDB, una base de datos de la empresa que creó las dbisam, me gusta, pero según lo que estoy viendo por aquí si hubiera andado por este foro hace unos años de forma habitual lo hubiera montado todo con Firebird. Ya la cosa tiene mal apaño.

Saludos

roman 30-11-2011 17:43:52

Cita:

Empezado por newtron (Mensaje 420007)
si hubiera andado por este foro hace unos años de forma habitual lo hubiera montado todo con Firebird.

En el error cargas la penitencia... :rolleyes:

// Saludos

newtron 30-11-2011 18:07:39

Cita:

Empezado por roman (Mensaje 420008)
En el error cargas la penitencia... :rolleyes:

// Saludos

Bueno, ahora que no se vende un pimiento y tengo tiempo igual me pongo poquito a poco a convertir todo a Firebird. Estimo que en un par de años puedo tener ya una versión beta. :p

Casimiro Noteví 30-11-2011 19:37:11

Pues si usa sql estandar (más o menos), la conversión puede ser rápida :)


La franja horaria es GMT +2. Ahora son las 05:40:14.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi