martes, 29 de junio de 2010

UBUNTU: modem HUAWEI K3765 en Lucid Lynx (10.04)

En principio basta con instalar el paquete "usb-modeswitch" (usando Synaptic, aptitude, apt o tu método favorito) y luego irse a Sistema -> Preferencias -> Conexiones de red -> Banda ancha móvil -> Agregar y metemos los datos que obtendremos de nuestro proveedor de servicios de red.

Gracias a digital nomad y a My brain is here.

Actualización 16/07/2010: Pues no ha resultado tan fácil... A las dos semanas me ha venido el comercial para decirme que no consigue conectarse usando el módem usb y efectivamente, al pincharlo lo reconoce como dispositivo de almacenamiento pero no como módem.. :S

lunes, 21 de junio de 2010

MYSQL: importar una tabla CSV en nuestra BBDD

mysql> LOAD DATA INFILE 'data.txt' INTO TABLE tbl_name
-> FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
-> LINES TERMINATED BY '\n';

Gracias a deadlykyo.

jueves, 17 de junio de 2010

UBUNTU: instalar adobe flash plugin para Chrome

Para la versión Ubuntu 10.04 (imagino que para anteriores y posteriores no debe ser muy difícil) lo que he hecho para instalar el plugin de Adobe Flash Player (el que usa youtube para mostrar vídeos, por ejemplo) ha sido lo siguiente:

1) Ir a la página de descargas de Adobe Flash Player PLugin

2) Descargar el plugin (el paquete para Ubuntu debería valer, pero yo no conseguí descargarlo. En vez de eso descargué el .tar.gz para linux).

3) Descomprimir el fichero libflashplayer.so en la carpeta /opt/google/chrome/plugins (si la carpeta /plugins no existe la creamos).

4) Hay que decirle a Chrome que busque plugins al iniciar. Para ello hacemos click derecho en el botón Aplicaciones, Editar los menús, Internet -> Google Chrome, Propiedades y en comando tiene que decir lo siguiente:

/opt/google/chrome/google-chrome --enable-plugins %U

Con esto debería estar instalado. Gracias a Howtoforge.com

miércoles, 16 de junio de 2010

MYSQL: nombres de campo con espacios

Podemos referenciar un nombre de campo con espacios en MySQL metiendo el nombre del campo entre acento invertido.

Ej: SELECT `nombre del campo con espacios` FROM miTabla

MYSQL: TRABAJAR CON STRINGS

Hoy vamos con dos funciones curiosas para trabajar con cadenas de texto que ofrece MySQL:

Substring(cadena, indice_Inicial, indice_Final) nos devuelve la subcadena contenida en 'cadena' entre las posiciones indice_Inicial e indice_Final.

Ej: Substring('Buenos dias',3,5) nos devuelve la cadena 'enos '.

InStr(cadena, subcadena) nos devuelve el índice en el que 'subcadena' aparece por primera vez dentro de 'cadena'.

Ej: InStr('Buenos dias','dias') nos devuelve el valor entero 8 mientras que InStr('Buenos dias','oreja') nos devuelve 0.

martes, 15 de junio de 2010

MS SQL: Tamaño ocupado por las tablas de una BBDD

Muchas gracias a http://www.textil.org/sistemas/index.php/2009/02/tamanyo-tablas-y-vistas-indexadas-en-sql-server/ por colgar en su web un script para ver el tamaño que ocupa en disco las tablas de una base de datos:

-- Cursor que contiene todos los objetos que ocupan espacio

DECLARE objects_cursor CURSOR LOCAL FAST_FORWARD READ_ONLY FOR

SELECT name

FROM sysobjects o

WHERE

o.xtype = 'U'

CREATE TABLE #results (

name SYSNAME, rows CHAR(11),

reserved VARCHAR(18), data VARCHAR(18),

index_size VARCHAR(18),Unused VARCHAR(18))

--Recorremos el cursor obteniendo la información de espacio ocupado

DECLARE @object_name AS SYSNAME

OPEN objects_cursor



FETCH NEXT FROM objects_cursor

INTO @object_name;

WHILE @@FETCH_STATUS = 0

BEGIN

INSERT INTO #results

EXEC sp_spaceused @object_name

FETCH NEXT FROM objects_cursor

INTO @object_name;

END;

CLOSE objects_cursor;

DEALLOCATE objects_cursor;

UPDATE #results
SET
reserved = LEFT(reserved,LEN(reserved)-3),
data = LEFT(data,LEN(data)-3),
index_size = LEFT(index_size,LEN(index_size)-3),
Unused = LEFT(Unused,LEN(Unused)-3)

viernes, 11 de junio de 2010

HTML: pasar variables entre formularios

Una vez que hemos declarado un formulario usando la etiqueta:


<form action="pagina.php" id="idformulario" method="get" nombre="nombreformulario">


y dentro del formulario elementos de captura de datos, como un campo de texto o un desplegable:

Nombre: <input id="nombre" name="nombre" type="text" />

Creamos un botón para enviar los datos:

<input id="enviar" name="enviar" type="submit" value="enviar" />

Al darle al botón, nos enviará a la página que hayamos determinado en el atributo action del form, y desde esta página podemos recuperar las variables con el código:

$_GET['nombre_variable']

Para nuestro ejemplo capturaríamos el valor del campo de texto usando:

$_GET['nombre']

miércoles, 9 de junio de 2010

DRUPAL: comprobar el rol de un usuario

Para saber si un usuario tiene un rol determinado, se puede usar la siguiente sentencia:


if (in_array('rol', array_values($user->roles))) {
   /*
      código
   */
}

DRUPAL: deserializar datos personalizados de usuario

Al crear un usuario en DRUPAL, tenemos la opción de guardar datos adicionales además de los estrictamente necesarios. Estos datos se guardan en el campo 'data' de la tabla 'users'. Para extraer estos datos, usaríamos:


$datos = unserialize($registro['data']);

En $registro['data'] obviamente tenemos ese campo adicional extraído de una consulta (ver http://diariosbinarios.blogspot.com/2010/06/drupal-ejecutar-una-consulta-contra-la.html).

Tendríamos un array en $datos al que accederíamos, como siempre, por sus índices. Por ejemplo:

$edad = $datos['edad'];

DRUPAL: ejecutar una consulta contra la base de datos

Un sitio Drupal forzosamente está ligado a una base de datos MySQL, que utiliza para almacenar datos de los usuarios, de las páginas, etc. Aunque se puede conectar a bases de datos externas yo voy a explicar cómo ejecutar consultas sobre la base de datos vinculada a Drupal.

Si queremos ejecutar una consulta que no devuelve datos (por ejemplo, un CREATE, INSERT, UPDATE, DELETE...) simplemente podemos ejecutar:

db_query($consulta)

donde $consulta es un string que contiene la consulta. Ej:

$consulta = "DELETE FROM paises WHERE nombre_pais = 'Pandora'";

db_query($consulta);

Ojo con las comillas, lo aconsejable es usar comillas dobles para el string que contiene la consulta y comillas simples para la propia consulta.

Si la consulta devuelve valores (típicamente un SELECT) para acceder a los valores que nos devuelve haremos lo siguiente:

$consulta = 'SELECT nombre_pais FROM paises';

$resultado = db_query($consulta);

while ($fila = db_fetch_array($resultado)) {
   /*
      Nos devuelve en $fila un array con los valores de cada fila.
      A estos valores accedemos mediante su índice.
   */
   echo $fila['nombre_pais'] . '
';
}

Nos imprimiría todos los nombres de países en líneas separadas.

DRUPAL: cómo enviar correo

La forma más sencilla (aunque no la más correcta) de enviar un correo en Drupal 6.x es utilizando la función:

drupal_mail_send($message)

La variable $message es un array con los siguientes índices:

$message = array(
'from' => 'direccion.de.correo@del.remitente',
'to' => 'direccion.de.correo@del.destinatario',
'body' => 'contenido del mail',
'subject' => 'asunto del mail'
);

Para ello debemos haber configurado antes correctamente un servidor SMTP. Yo sólo he configurado un servidor SMTP con autenticación TLS para lo cuál he instalado el módulo SMTP Authentication http://drupal.org/project/smtp

Si no fuera necesaria la autenticación, creo que sólo sería necesario configurar los parámetros en el archivo php.ini en la sección smtp.

martes, 8 de junio de 2010

PHP: Trabajar con cadenas

Digamos que tengo algo como esto:

$cadena = 'esto es una cadena de caracteres en php';

La funcion substr($cadena, 3, 7) devolvería el string 'o es un'. Es decir, la cadena que empieza en la posición 3 con longitud 7. Esto es así porque en PHP los arrays empiezan en la posición 0.

Para concatenar strings en php, usamos el operador "." (sí, el punto de final de sentencia).

Por ejemplo:

$cadena1 = 'Hola ';
$cadena2 = 'Mundo.';

El valor de $cadena1 . $cadena2 sería 'Hola Mundo.'

MYSQL: DIFERENCIA ENTRE DATETIME Y TIMESTAMP

Datetime almacena fechas en formato '1000-01-01 00:00:00' a '9999-12-31 23:59:59'.

Timestamp almacena un número enorme que es el número de segundos transcurridos desde el 1-1-1970 en el primer segundo, y sólo llega hasta el año 2038.

http://www.forosdelweb.com/f86/diferencias-entre-timestamp-datetime-590772/

MYSQL: DIFERENCIA ENTRE CHAR Y VARCHAR

A la hora de definir un tipo CHAR o VARCHAR en una columna de una tabla en MySQL tenemos que especificar la longitud máxima que tomarán los valores de esa columna (hasta 255 para CHAR, VARCHAR admite hasta 65535 en mySQL 5.0.3 y posterior).

La diferencia es que en CHAR siempre se ocuparán en memoria tantos byes como hayamos especificado, añadiendo espacios al final, mientras que VARCHAR no almacena aquellos bytes que no sean necesarios, a cambio de usar un byte adicional (dos si la longitud es mayor de 255) para definir la longitud.

Por eso para longitudes fijas será mejor usar CHAR, pero para longitudes variables es mejor VARCHAR.

Más detalle en http://dev.mysql.com/doc/refman/5.0/es/char.html

MYSQL: CREAR UNA TABLA CON INDICE AUTO INCREMENTAL

Para crear una tabla con una columna con un valor numérico que sea clave primaria y que además se vaya autoincrementando con cada inserción, usar:

CREATE TABLE ("nombre de la tabla" "tipo de la columna" AUTO_INCREMENT PRIMARY KEY);