sábado, 16 de noviembre de 2019

Web AAPI :net Core

Estructura

Como estructura generaremos los siguientes cuatro proyectis

3 Bibliotecas de clase .Net Core
   Models
   Data
   Dtos

1.-Solución WEB Net Core Vacía
   Api

En en el proyecto de Data ejecutaremos los siguientes comandos (desde la consola del administrador de paquetes NuGet.
 
Install-Package Microsoft.EntityFrameworkCore.SqlServer -version 2.2.6 
Install-Package Microsoft.EntityFrameworkCore.Tools -version 2.2.6
scaffold-dbcontext "Data Source=localhost\SQLEXPRESS;Initial Catalog=TuBD;Integrated Security=True;" Microsoft.EntityFrameworkCore.SqlServer 





lunes, 27 de mayo de 2019

Caracteres Extraños Oracle ñ

En algunos casos al trabajar con bases de datos Oracle nos encontramos con que algunos caracteres especiales tales como Ñ, Á ü, no son mostrados correctamente.

Lo más probable es que el error se esté generando debido a que el cliente y el servidor de la base de datos tiene configurado diferente Juego de caracteres.

Para corregir este problema es necesario igualar el juego de caracteres de la base de datos y del cliente que esta realizando la consulta , inserción y actualización (Es recomendable revisar y unificar la  juego de caracteres de cada uno de los clientes que se conecte a la BD. de lo contrario podría existir discrepancia entre lo que diferentes clientes pueden ver)

1.- Ejecuta la siguiente consulta en la base de datos Oracle  con la que estas experimentando el problema: 

SELECT *
FROM V$NLS_PARAMETERS
WHERE PARAMETER in ('NLS_LANGUAGE','NLS_TERRITORY','NLS_CHARACTERSET'); 


    El resultado de la consulta deberá ser similar al siguiente: 
   


2.- Genera una cadena con los tres  valores devueltos. La cadena deberá tener la siguiente estructura: [NS_LANGUAGE_[NLS_TERRITORY].[NLS_CHARACTERSET]


3.- Agrega una nueva entrada en las variables del entorno del sistema (Inicio>>Este Equipo>>(botón secundario)>>Propiedades>>Configuración Avanzada del sistema.>>Variables del Entorno)


Ejemplo: MEXICAN SPANISH_MEXICO.WE8ISO8859P1



4.- Reinicia el sistema





viernes, 1 de febrero de 2019

Cursores Implicitos Oracle

Los cursores no son mi herramienta favorita pero por alguna razón que no tengo muy clara la realidad es que en el mundo de Oracle es una de las formas más comunes de hacer las cosas .. Cursor para esto, cursor para aquello, todo se puede resolver con cursores y la verdad es que he de reconocer que tienen un gran poder sin embargo prefiero prescindir de ellos en la medida de lo posible.

Pero para aquellos casos en los que no hay más opciones o la manera rápida de hacerlo es mediante un cursos aqui les dejo la forma que considero más sencilla de trabajar con cursores son los cursores implicitos. Aqui dejo un ejemplo de como se pueden usar 



BEGIN
    FOR  REGISTRO IN  (SELECT CAMPO1, CAMPO2
                                   FROM   Tabla1                 T1
                                              Inner join Tabla2  T2 On T1.A = T2.B
                                         )
     LOOP
          DBMS_OUTPUT.put_line(registro.campo1);     
    END LOOP;        

END; 


En esta entrada comparto un script para poder enviar correos desde Power Shel es importante señalar que antes de poder realizar el envío desde cuentas de gmail u outlook es necesario habilitar el envío de Aquí puedes encontrar un manual de como hacerlo.

$EmailFrom = "pruebas@gmail.com"
$EmailPass = "1234"
$EmailTo = "pruebas@gmail.com"
$Subject = "Prueba de correo PowerShel"
$Body = "Cuertpo del correo"
$SMTPServer = "smtp.gmail.com"
$SMTPMessage = New-Object System.Net.Mail.MailMessage($EmailFrom,$EmailTo,$Subject,$Body)
$SMTPClient = New-Object Net.Mail.SmtpClient($SmtpServer, 587)
$SMTPClient.EnableSsl = $true
$SMTPClient.Credentials = New-Object System.Net.NetworkCredential($EmailFrom, $EmailPass)
$SMTPCliente.EnableSsl = $true;
$SMTPClient.send($SMTPMessage)



Es posible que el antivirus bloquee el envío de correos en esta caso podrías recibir un error similar al siguiente:





Si este es el caso revisa

Para enviar el mismo correo varias veces puedes sustituir la ultima linea por estas tres lineas:

for($i=0; $i -lt 3; $i++)
{
   $SMTPClient.send($SMTPMessage)
}