martes, 27 de junio de 2017

Jesús Moreno - Ingeniero Ténico Informático - consultor Informático

Hola,
soy Jesús Moreno Ingeniero Técnico Informático en sistemas por la US y propietario de éste blog.

Mi trabajo en los ultimos años se centra especialmente en aplicaciones distribuidas con tecnologías web y centradas en software cliente servidor haciendo uso de sistemas de intercomunicación mediante protocolos json, xml, rest, soap y aplicaciones con frameworks javascript, html5, css3, php, asp, mysql, sqlserver...

Soy muy fan del software libre, que permite hacer llegar a todos el conocimiento y crear entre todos una comunidad mucho más eficaz.
El motivo principal de este blog es hacer llegar a todo el mundo una solución rápida y eficaz ante problemas que pueden surgirte mientras trabajas en un proyecto y que pueden hacerte perder mucho tiempo. Aportar una solución que otro conoce porque se ha enfrentado antes a la misma situación y ha conseguido solucionarla con éxito.
Por eso agradezco mucho vuestros comentarios de apoyo cuando os ha sido útil una entrada, porque demuestra que éste blog llega a la gente y consigue su objetivo.

Si estáis trabajando en un proyecto y tenéis dudas o errores que no os dejan continuar con vuestro trabajo. Podéis contactar conmigo dejando un comentario en esta entrada.

Saludos y buen día.

php y mssql

Below is the code for connecting to a MSSQL Server database.
<?php
$myServer = "localhost";
$myUser = "your_name";
$myPass = "your_password";
$myDB = "examples";

//connection to the database
$dbhandle = mssql_connect($myServer, $myUser, $myPass)
  or die("Couldn't connect to SQL Server on $myServer");

//select a database to work with

$selected = mssql_select_db($myDB, $dbhandle)
  or die("Couldn't open database $myDB");

//declare the SQL statement that will query the database
$query = "SELECT id, name, year ";
$query .= "FROM cars ";
$query .= "WHERE name='BMW'";

//execute the SQL query and return records
$result = mssql_query($query);

$numRows = mssql_num_rows($result);
echo "<h1>" . $numRows . " Row" . ($numRows == 1 ? "" : "s") . " Returned </h1>";

//display the results 
while($row = mssql_fetch_array($result))
{
  echo "<li>" . $row["id"] . $row["name"] . $row["year"] . "</li>";
}
//close the connectionmssql_close($dbhandle);
?>
Connect with a DSN
DSN stands for 'Data Source Name'. It is an easy way to assign useful and easily rememberable names to data sources which may not be limited to databases alone. If you do not know how to set up a system DSN read our tutorial How to set up a system DSN.
In the example below we will show you how to connect with a DSN to a MSSQL Server database called 'examples.mdb'  and retrieve all the records from the table 'cars'.
<?php

//connect to a DSN "myDSN" 

$conn = odbc_connect('myDSN','','');

if ($conn)
{
  //the SQL statement that will query the database
  $query = "select * from cars";
  //perform the query
  $result=odbc_exec($conn, $query);

  echo "<table border=\"1\"><tr>";

  //print field name
  $colName = odbc_num_fields($result);
  for ($j=1; $j<= $colName; $j++)
  {
    echo "<th>";
    echo odbc_field_name ($result, $j );
    echo "</th>";
  }

  //fetch tha data from the database 
  while(odbc_fetch_row($result))
  {
    echo "<tr>";
    for($i=1;$i<=odbc_num_fields($result);$i++)
    {
      echo "<td>";
      echo odbc_result($result,$i);
      echo "</td>";
    }
    echo "</tr>";
  }

  echo "</td> </tr>";
  echo "</table >";

  //close the connection 
  odbc_close ($conn);
}
else echo "odbc not connected";
?>
Connect without a DSN (using a connection string)
Let see a sample script to see how ADODB is used in PHP:
<?php
$myServer = "localhost";
$myUser = "your_name";
$myPass = "your_password";
$myDB = "examples";

//create an instance of the  ADO connection object$conn = new COM ("ADODB.Connection")
  or die("Cannot start ADO");

//define connection string, specify database driver$connStr = "PROVIDER=SQLOLEDB;SERVER=".$myServer.";UID=".$myUser.";PWD=".$myPass.";DATABASE=".$myDB;
  $conn->open($connStr); //Open the connection to the database

//declare the SQL statement that will query the database
$query = "SELECT * FROM cars";

//execute the SQL statement and return records
$rs = $conn->execute($query);

$num_columns = $rs->Fields->Count();
echo $num_columns . "<br>";

for ($i=0; $i < $num_columns; $i++) {
    $fld[$i] = $rs->Fields($i);
}

echo "<table>";
while (!$rs->EOF)  //carry on looping through while there are records
{
    echo "<tr>";
    for ($i=0; $i < $num_columns; $i++) {
        echo "<td>" . $fld[$i]->value . "</td>";
    }
    echo "</tr>";
    $rs->MoveNext(); //move on to the next record
}


echo "</table>";

//close the connection and recordset objects freeing up resources
$rs->Close();
$conn->Close();

$rs = null;
$conn = null;
?>
To create 'examples' database on your MSSQL Server you should run the following script:
CREATE DATABASE examples;
USE examples;
CREATE TABLE cars(
   id int UNIQUE NOT NULL,
   name varchar(40),
   year varchar(50),
   PRIMARY KEY(id)
);

INSERT INTO cars VALUES(1,'Mercedes','2000');
INSERT INTO cars VALUES(2,'BMW','2004');
INSERT INTO cars VALUES(3,'Audi','2001');

lunes, 12 de junio de 2017

Trabajar con SQL SERVER mediante linea de comandos

Trabajar con SQL SERVER mediante linea de comandos


Resultado de imagen de sql serverPuede ser útil conocer los equipos conectados a nuestra red, puesto que en cada uno de estos equipos puede estar corriendo un servicio de SQL SERVER al que podamos consultar informarción. Para ello usaremos el comando: net view

Para obtener la ip de un equipo y comprobar que esta disponible podremos realizar un test de red mediante el comando: ping <nombre_del_equipo>

Imagen relacionadaUna vez localizado un equipo podemos consumir el servicio de SQL SERVER mediante el comando: sqlcmd


Ejemplo de uso
  • sqlcmd -L                                        Lista las intancias disponibles en nuestra red
listado de parámetros completo de sqlcmd   
   -a packet_size  
   -A (dedicated administrator connection)  
   -b (terminate batch job if there is an error)  
   -c batch_terminator  
   -C (trust the server certificate)  
   -d db_name  
   -e (echo input)  
   -E (use trusted connection)  
   -f codepage | i:codepage[,o:codepage] | o:codepage[,i:codepage] 
   -g (enable column encryption) 
   -G (use Azure Active Directory for authentication)
   -h rows_per_header  
   -H workstation_name  
   -i input_file  
   -I (enable quoted identifiers)  
   -j (Print raw error messages)
   -k[1 | 2] (remove or replace control characters)  
   -K application_intent  
   -l login_timeout  
   -L[c] (list servers, optional clean output)  
   -m error_level  
   -M multisubnet_failover  
   -N (encrypt connection)  
   -o output_file  
   -p[1] (print statistics, optional colon format)  
   -P password  
   -q "cmdline query"  
   -Q "cmdline query" (and exit)  
   -r[0 | 1] (msgs to stderr)  
   -R (use client regional settings)  
   -s col_separator  
   -S [protocol:]server[instance_name][,port]  
   -t query_timeout  
   -u (unicode output file)  
   -U login_id  
   -v var = "value"  
   -V error_severity_level  
   -w column_width  
   -W (remove trailing spaces)  
   -x (disable variable substitution)  
   -X[1] (disable commands, startup script, environment variables, optional exit)  
   -y variable_length_type_display_width  
   -Y fixed_length_type_display_width  
   -z new_password   
   -Z new_password (and exit)  
   -? (usage)

Ejemplo de uso
  • sqlcmd -S <nombre_equipo>,<instancia> -U <usuario> -P <clave>
Conexión a una instancia mediante autorización en SQL SERVER

Jesús Moreno - Ingeniero Ténico Informático - consultor Informático

Hola, soy Jesús Moreno Ingeniero Técnico Informático en sistemas por la US y propietario de éste blog. Mi trabajo en los ultimos años se ...