Programación

La programación informática o programación algorítmica, acortada como programación, es el proceso de diseñar, codificar, depurar y mantener el código fuente de programas computacionales.

Algoritmo

Un algoritmo es una secuencia no ambigua, finita y ordenada de instrucciones que han de seguirse para resolver un problema. Un programa normalmente implementa (traduce a un lenguaje de programación concreto) uno o más algoritmos.

Compilación

El programa escrito en un lenguaje de programación de alto nivel (fácilmente comprensible por el programador) es llamado programa fuente y no se puede ejecutar directamente en una computadora.

Desarrollador

Para conseguirlo se hace uso de tecnologías de software del lado del servidor y del cliente que involucran una combinación de procesos de base de datos con el uso de un navegador web a fin de realizar determinadas tareas o mostrar información.

Diseño Web

Actividad que consiste en la planificación, diseño, implementación y mantenimiento de sitios web. No es simplemente la implementación del diseño convencional ya que se abarcan diferentes aspectos como el diseño gráfico web; diseño de interfaz y experiencia de usuario

martes, 28 de marzo de 2017

¿Programar genera estrés?



Vease al programador como aquella persona de ojos rojos que trabaja día y noche, y no tiene vida. Pues esto es parcialmente falso.

Los primeros pasos de nuestra vida

Cuando comenzamos en este mundo, los primeros empleos que van a conseguir no son de los mejores, pagan poco y piden mucho, y esto es normal debido a nuestra falta de experiencia y estas empresas normalmente, no estan constituidas para liderar un área de TI o simplemente no saben lo que es estoI. Pero de cierto modo, es una gran oportunidad para aprender de todo un poco y así, más adelante profundizar en algo específico.

Es inevitable obviar el estrés en esta, normalmente, aquí el joven programador decide si seguir en esto o migrar a QA, analista, etc, debido a que nos vamos a quedar más horas de lo normal para corregir nuestros errores, vamos hacer de todo: frontend, backend, maquetación y en el peor de los casos, hasta photoshop.


Los que sobrevivieron a la primera oleada

A este punto todavía pensamos como Junior, pero ya tenemos cierta experiencia y deberíamos tener claro lo que QUEREMOS HACER y en que ESPECIALIZARNOS. Entonces, tu criterio de búsqueda debería ser optar por una empresa en la que puedas crecer profesionalmente asumiendo nuevos retos. Si logramos conseguir una empresa buena, entonces la cosa se pondrá más interesante, el estrés se verá opacado por los nuevos retos afrontar, el trabajo en équipo (cosa que asumo no veías antes), verás que hay varios desarrolladores trabajando en un mismo proyecto usando un sistema de versiones, aprenderás más de tecnología, cosas que harán que crezcas profesionalmente y te olvidarás del estrés a pesar que te quedes más de lo normal.

El estrés volverás cuando te comiences aburrir de hacer lo mismo, entonces, tendrás que cambiar de trabajo. Ojo, si te aburres a pesar que afrontas nuevos retos, entonces esto no es lo tuyo.


Menos errores, más eficientes

Ya no somos pequeños padawans, tampoco seniors, pero conocemos del tema, cometemos menos errores, creamos código más eficiente, reutilizable. Por ende, nuestra prioridad debe ser asumir nuevos retos, conocer nuevos modelos de negocios, más de tecnología, tal vez nos toque ver arquitectura de software. A este punto ya conoces el trabajo en équipo, tienes un buen lider técnico que sabe hacer su trabajo, delega bien las tareas, eres lo suficientemente hábil para acabar a tiempo tus cosas por lo tanto, podrás salir a tu hora sin tener que quedarte de más, y mejor aún, sentirás que tienes tiempo de sobra. Mi consejo es, si tienes tiempo de sobra, investiga algo, es lo que suelo hacer yo.

El paso siguiente

Tenemos experiencia, brindamos buenas soluciones, preguntamos muy poco, somos autodidactas (basta con leer la documentación para entender), pero asumir nuevos retos ya no es tan interesante, ahora buscamos una empresa que sea más flexible, que no tenga muchas restricciones que puedas ir vestido como quieras, si llegas tarde, que no te digan nada y que paguen bien. En este punto me encuentro yo, normalmente acabo rápido mis deberes y me doy tiempo para hacer otras cosas, muy rara vez trabajo demás y solo me quedo cuando quiero. Lo que me gusta hacer en esta fase es apoyar al équipo, participar en las decisiones, plantear nuevas estrategias para lograr los objetivos, ver de arquitectura y mejorar mi ingles (todo en mi empresa es ingles).


Conclusión

Personalmente el estrés lo he dejado a un lado y cuando lo hago es normalmente porque me aburro y siento que no avanzo, por suerte en la empresa que estoy es americana y los gringos siempre estan a la vanguardia, se aprenden muchas cosas, tengo un buen lider técnico y el dueño conoce bastante de tecnología (no hay forma de discutirle de algo porque es muy probable que tu no tengas la razón).

Algunos factores a considerar que me han hecho dejar a un lado el estrés:

Equipo mejor organizado, tenemos un tester y un LT que conoce bastante (más que yo).
No tengo que venir formal al trabajo, odio las corbatas.
Horarios flexibles (lo importante es cumplir 8 horas al día)
Viernes de Whisky

Razones principales del estrés

Empresa con pésima organización
No comprendemos los procesos, muchos errores técnicos
Poco personal
Líder técnico ineficiente
Hacemos de todo
Trabajamos por cumplir, no por pasión
Ver lo mismo aburre, innovar sería lo ideal
Usar corbata
Trabajamos más horas de lo normal y sentimos que no progresamos


Recomendaciones

Si ya conoces tu trabajo, sabes que tienes experiencia, no necesitas quedarte de más.
Nadie te puede obligar a quedarte si realmente no quieres
Haz deporte (ayuda mucho), yo hago box en las noches y spinning
Sal con tus amigos, conoce nuevas personas, ten vida social
Disfruta de los videojuegos, ve películas
Busca un pasatiempo, disfrútalo
Ten sexo!!!!

fuente anexsoft.

domingo, 26 de marzo de 2017

Java Top 5 Servidores de Aplicación Opensources


Este artículo es una breve revisión de los servidores de software abierto JEE que existen en el mercado. Serán listados incluyendo algunos detalles para cada servidor de aplicación.
WidFly – JBoss Application Server
Visión General
WidFly inicialmente conocida como JBoss Application Server, es un software de aplicación creado por JBoss, ahora desarrollado por Red Hat. WidFly esta escrito en Java y se puede ejecutar en las mejoras plataformas Java EE, se encuentra disponible en multi plataformas.
En terminos de API, WidFly soporta el último estándar en Java Enterprise ( Java EE 7) y esta basado en los mejores proyectos de software abierto tales como:
Undertow (servidor web)
Apache CXF (web services basado en SOAP)
RestEasy ( web services basado en REST)
Infinispan (plataforma de Data Grid y Cluster )
HornetQ (proveedor de JMS)
JGroups (framework de comunicación Multicast)
En términos de arquitectura interna, WidFly (tal cual JBoss AS 7) esta diseñado en una arquitectura modular basado en dos proyectos principales:
JBoss Module, maneja la carga de los recursos de clase en el contenedor
Modular Service Container (MSC), que proporciona una forma de instalar, des-instalar y administrar los servicios utilizados por el contenedor.
WidFly se puede ejecutar de dos formas: con un simple JVM y multi-JVM o modo domain.

GlassFish
Visión General
GlassFish es un servidor de aplicaciones de código abierto iniciado por Sun Microsystems para la plataforma Java EE y ahora patrocinado por la corporación Oracle.
El servidor GlassFish 4.0 esta desarrollado a través de un proyecto de la comunidad de sofware en http://glassfish.java.net/. El proyecto GlassFish proporciona un proyecto estructurado para el desarrollo el cual permite tener disponibles las nuevas características de la plataforma Java EE en forma más rápido que en otros servidores.
GlassFish esta construido en un núcleo modular basado en OSGi, GlassFish se ejecuta sobre la aplicación de Apache Felix. También se ejecuta con Equinox OSGi o Knopflerfish OSGi.
Apache Geronimo
Apache Geronimo es un servidor de software abierto que integra los mejores proyectos de software abierto creados para Java/OSGi el cual conoce las necesidades de programadores y administradores de sistema. Entonces la característica más importante de este servidor es que contiene una colección de los mejores proyectos de software abierto para hacer un servidor complementa funcional. Los componentes del núcleo de Jeronimo incluyen:
 Apache Tomcat (Servidor HTTP y contenedor de servlet)
Jetty (Servidor HTTP y contenedor de servlet, alternativo a Tomcat)
Apache ActiveMQ (proveedor de JMS 1.1)
Apache OpenEJB (contenedor EJB)
Apache OpenJPA (Implementación de Java Persistence API – JPA 1.0)
Apache ServiceMix (Enterprise Services Bus)
Apache CXF (framework de web services con una variedad de protocolos)
Apache Derby (administrador de base de datos relacional con un soporte nativo para JDBC)
Apache WADI (solución cluster y de balanceo de carga)
El núcleo de Geronimo es un framework para los servicios del núcleo y control de los componentes básicos del servidor. Todo en Geronimo es un GBean: contenedor, conector, adaptador, aplicación y más. Un GBean es la unidad mínima de Geronimo, el cual consiste en un conjunto de clases (.jar) y el plan de implementación.
JOnAS
Visión General
JOnAs es una implementación de software libre de la especificación de JEE para servidores de aplicación, desarrollada y alojada el consorcio ObjectWeb.
Las características de JOnAS lo certifican como un contenedor Java EE 6. Proporciona un contenedor de EJB a través de EasyBeans y esta disponible con un servidor Tomcat y un servidor Jetty. JVM 6 esta soportado y los intentos de ejecutar en una pila libre con el classpath GNU son prometedores. Además de la pila de Java EE, JOnAS proporciona mecanismos de alto nivel para cluster y así proporcionar escalabilidad y alta disponibilidad.

Apache Tomcat EE
Visión General
Apache TomEE es la edición Java EE de Apache Tomcat, el cual combina varios proyectos Java incluyendo Apache OpenEJB, ApacheOpenWebBeans, Apache OpenJPA, ApacheMyFaces y otros. El proyecto tiene una certificación de la corporación Oracle como un servidor compatible del perfil web Java EE 6 , que es una parte de toda la especificación Java EE.
Básicamente ApacheTomEE es ensamblada de vanilla Apache Tomcat.
Este artículo esta basado en Top 5 OpenSource Application Servers

lunes, 20 de marzo de 2017

Las tendencias de programación que deberías conocer, seas desarrollador o no



Es evidente que el desarrollo de software está presente en la vida moderna y a estas alturas existe una app móvil o web para casi todas las situaciones. Entender la tecnología y su evolución es también la capacidad de aprovecharla al máximo.

Cada año surgen nuevas prácticas y tecnologías, y qué mejor fuente para enterarse que los propios desarrolladores. Todos los años el foro de dudas para programadores Stack Overflow realiza una encuesta entre sus millones de usuarios para medir el pulso de la industria. Los resultados de este año ya están publicados y las respuestas han brindado un panorama muy interesante sobre las tendencias de empresas y programadores.

45 preguntas respondidas por 56.032 usuarios desde 173 países. Más de 3 millones de desarrolladores visitan esta web desde España y 1.023 participaron en la encuesta.

Datos que llaman la atención:

La gran mayoría de los participantes se definen como “Full Stack Developers” (si no te suena, te explicamos de qué vá más adelante).
Para aprender nuevas tecnologías, el camino preferido es ser autodidacta.
Casi la mitad son desarrolladores/programadores sin titulación oficial. Y prefieren ser llamados “desarrollador” a “programador”.
El lenguaje más popular es JavaScript.
El stack de tecnologías frontend más popular está formado por  AngularJS, Node.js y JavaScript.
Los desarrolladores que manejan JavaScript, Node.js, AngularJS y tecnologías Cloud son los mejor pagados.
Node.js. AngularJS y Python ocupan los primeros lugares en tecnologías que los desarrolladores quieren aprender.
63% de especialistas en Big Data trabajan con Python.
Star Wars es la favorita de los desarrolladores cuarentones, Star Trek es muy querida por los más seniors, y entre los más jóvenes (menos de 30) Babylon 5, Dr Who y Firefly también dan pelea.



Estas respuestas interesan no sólo a programadores

Los desarrolladores son los arquitectos del mundo moderno. Apps y dispositivos moldean nuestra vida y manera de relacionarnos, por esta razón, no hay que perder de vista cuál es la tendencia del desarrollo moderno. Toma nota:

Si eres desarrollador

Si no te has dado cuenta hasta ahora, los stacks MEAN y Django marcarán un antes y un después en tu carrera como desarrollador web. Revisa los blogs técnicos de la mejores empresas como Netflix o Amazon y averigua las últimas tendencias. Ten presente el concepto “Arquitectura de Microservicios”, pues es lo que pega fuerte en este momento.
Si quieres marcar la diferencia, apunta a convertirte en “Full Stack Developer”, es decir, un profesional que maneja los diferentes componentes de un producto de software, sabe cómo se relacionan y sabe desarrollarlos con las herramientas más ágiles.
El título universitario no condiciona tu éxito en esa entrevista de trabajo que anhelas. Manejar tecnologías modernas y poder mostrar un proyecto funcional será tu mejor arma.
La pista más importante: PREPÁRATE. No es suficiente conocer algunas de las herramientas. Las empresas buscan a Full Stack Developers con el arsenal más actualizado y criterio para saber aplicarlo a cualquier proyecto.
Full Stack.



Si eres recruiter

Un título no garantiza el perfil más cualificado. La Universidad brinda una excelente base, pero no enseña tecnologías modernas, así que fíjate en los desarrolladores con proyectos y apps publicadas, activos en redes técnicas como gitHub, Twitch y el propio Stack Overflow.
Mantente al día con nuevas herramientas y busca desarrolladores que las conozcan no sólo por el nombre.
La versatilidad de un desarrollador asegura un proyecto con final feliz. Durante su carrera el programador tiene que actualizarse como mínimo cada cuatro años, así que toma muy en cuenta la capacidad del candidato para aprender nuevas herramientas y aplicarlas en un plazo breve.
Si no eres desarrollador

Internet es el nuevo terreno de acción. Si no te encuentran, no existes. Sin importar el sector, cualquier proyecto o empresa puede evolucionar a pasos gigantes gracias a una solución tecnológica. Manejar tendencias y vocabulario facilitará la comunicación con profesionales técnicos y por lo tanto asegurará que tus proyectos se realicen eficazmente.
Conocer qué opciones hay y qué es posible hacer te dará una perspectiva amplia de tu negocio o proyecto y estimulará tu creatividad para innovar.
… Y si además de conocer las opciones, sabes desarrollarlas, serás un profesional muy valioso sea cual sea tu profesión, ya que contarás con el criterio suficiente para agilizar tu proyecto o empresa con herramientas modernas.
Cualquier persona puede convertirse en programador y cualquier desarrollador (jovenzuelo o dinosaurio) puede dar el salto a las grandes ligas. Recuerda que es un trabajo fundamentalmente intelectual y la clave está en la preparación.

Las oportunidades están allí. No hay tiempo que perder

Las empresas punteras alrededor del mundo tiene algo en común entre sus diferentes productos: un backend muy potente y escalable, al que se accede hoy en día fundamentalmente a través de clientes móviles y clientes web.

La demanda de desarrolladores capaces de sacar adelante este tipo de proyectos es enorme y mundial. Sólo en EEUU, se estiman van a faltar en 2020 cerca de 400 mil desarrolladores de software y en el resto del mundo -España incluida- el escenario profesional no es muy diferente. Fórmate para lo mejor, es lo más importante. La edad en este entorno no es una pega para competir por los mejores puestos de trabajo lo cual es una gran noticia.

Una excelente opción para actualizarte de forma definitiva y eficiente, sin importar edad o años de experiencia, es el KeepCoding Web Development Bootcamp. Una formación intensiva donde, a través del entrenamiento riguroso, te convertirás en un Full Stack Developer preparado según lo que piden las empresas más importantes del mundo.

Es un programa duro, un maratón de tecnologías desafiante, pero muy, muy efectivo y a la vez compatible con trabajo. Un entorno donde no sólo aprenderás la correcta asimilación de todos los conceptos, sino las mejores prácticas para aplicarlos.

Los conceptos que realmente necesitas

Aprenderás a usar la Arquitectura de Microservicios (MSA), que permite usar diferentes stacks tecnológicos según la tarea asignada, así se logra un backend más potente y eficaz. Conocerás JavaScript desde los fundamentos, aplicándolo tanto del lado del cliente, como del servidor. Verás a fondo los stacks MEAN y Django.
Tanto si buscas actualizar tus aptitudes como si estás comenzando en desarrollo web, esta es la formación que te lleva rápidamente a dar un salto profesional. Interfaces adaptativas, automatización de tareas, buenas prácticas de desarrollo, trabajo en equipo…

A todo eso se suman módulos de optimización (SEO), analytics y tests A/B desde el punto de UX y de monetización, Gestión de Proyectos Ágiles, TDD, control de versiones con Git, y mucho más.  Además, crearás un proyecto real (clon de Medium) y en cada módulo se desarrolla un elemento de la arquitectura del producto, para unirlos todos en la Práctica Final.

Empresas y startups buscan talento de donde sea ¿Qué harás al respecto?

Si quieres reforzar tu base de programación, actualizarte con nuevas tecnologías, reciclarte con una apuesta segura, brindar valor a tu carrera o emprender un proyecto técnico con los más altos estándares, no lo pienses más, KeepCoding te acerca a los mejores puestos de trabajo en todo el mundo.

Si tienes dudas, podrás aclararlas en vivo este viernes. Conoce todo lo que podrás disfrutar en el Bootcamp el 15 de abril a las 21:30 en YouTube. Descubre aquí todos los detalles.

El desarrollo es una opción absolutamente viable para cambiar tu vida. Sólo necesitas las herramientas adecuadas, ganas y disciplina para lograr ese sueño profesional.

fuente: stack overflow

lunes, 13 de marzo de 2017

JSON en SQL Server 2016: Página 4 de 4 Páginas

Exportar datos como JSON, for JSON

En este post final de nuestra serie de JSON cuatro, nos muestra la capacidad de formato de resultados de la consulta como texto JSON mediante la cláusula de JSON para. Si estás familiarizado con la cláusula FOR XML, entenderás fácilmente para JSON
Cuando se agrega la cláusula de JSON para el final de una consulta SELECT de SQL, SQL Server los resultados, formato como texto JSON y devolverlos al cliente. Cada fila tiene un formato como un objeto JSON, valores de las celdas del resultado se generará como valores de objetos JSON y nombres de columna o alias se utilizarán como nombres de clave. Tenemos dos tipos de cláusulas para JSON:
  • FOR JSON PATH: Le permite definir la estructura de una salida JSON usando los nombres de columna/alias. Si pones nombres separados por punto en los alias de columna, propiedades JSON seguirá la Convención de nomenclatura. Esta función es similar a la de ruta XML donde se pueden utilizar rutas de slash separado.
  • FOR JSON AUTO Crea automáticamente matrices anidadas de sub JSON basados en la jerarquía de la tabla en la consulta. Una vez más, esto es similar a la de XML AUTO.
Texto JSON que se genera con una cláusula para JSON puede transformarse a la forma relacional usando OPENJSON.

Conclusión

JSON funciones en SQL Server le permiten consultar y analizar los datos JSON como transformar JSON a dominios relacionales y datos relacionales a JSON. Permiten integrar SQL Server con los sistemas externos que producen o consumen datos JSON sin transformaciones adicionales en la capa de aplicación. 

SQL Server también proporciona un modelo de almacenamiento híbrida donde combinas datos relacionales y JSON. Este modelo permite hacer compensaciones entre alto rendimiento evolución de acceso y flexibilidad rápida de datos. Puede utilizar las mismas técnicas de indexación en columnas estándar y los valores en texto JSON. 

El modelo híbrido conserva todas las ventajas del motor de SQL Server con lenguaje de consulta totalmente potente y transacciones ACID. También cuenta con modelos de gestión y seguridad bien conocidos, varias funciones que trabajan con funciones JSON y un amplio ecosistema de herramientas compatibles con SQL Server.

JSON en SQL Server 2016: Página 1 de 4
JSON en SQL Server 2016: Página 2 de 4
JSON en SQL Server 2016: Página 3 de 4

JSON en SQL Server 2016: Página 3 de 4 Páginas

Transformar texto JSON a tabla relacional – OPENJSON
OPENJSON es una función del valor de tabla (TVF) que se ve en texto JSON, localiza una gran variedad de objetos JSON, recorre en iteración los elementos de la matriz y cada elemento devuelve una fila en el resultado de salida.

En el ejemplo anterior, podemos especificar dónde ubicar la matriz JSON que debe ser abierta (es decir, en el $. Ruta de órdenes), qué columna debe ser devuelto como resultado, y donde en el JSON pueden ubicarse los valores de los objetos que se devolverá como células. 
OPENJSON se puede utilizar en cualquier consulta que trabaja con datos. Como ejemplo, podemos transformar un conjunto de filas de una matriz JSON en la variable @orders e insertarlos en una tabla estándar:
INSERT INTO Orders(Number, Date, Customer, Quantity)
SELECT Number, Date, Customer, Quantity
 OPENJSON (@orders)
 WITH (
        Number varchar(200), 
        Date datetime,
        Customer varchar(200),
        Quantity int
 ) AS OrdersArray
Cuatro columnas en el conjunto de resultados devuelto por OPENJSON se definen en la cláusula WITH. OPENJSON tratará de encontrar las propiedades de número, fecha, cliente y la cantidad en cada objeto JSON y convertir sus valores en columnas en el resultado. Por defecto, es NULL devuelve si no se encuentra la propiedad. La Asunción en la consulta anterior es que la variable @orders contiene la siguiente matriz JSON:
'[
   {"Number":1, "Date": "8/10/2012", "Customer": "Adventure works", "Quantity": 1200},
   {"Number":4, "Date": "5/11/2012", "Customer": "Adventure works", "Quantity": 100},
   {"Number":6, "Date": "1/3/2012", "Customer": "Adventure works", "Quantity": 250},
   {"Number":8, "Date": "12/7/2012", "Customer": "Adventure works", "Quantity": 2200}
]'
Como se puede ver, la transformación de un texto JSON a una forma relacional es simple. Solo tienes que especificar nombres de columna y tipos y OPENJSON encontrará propiedades en JSON que coinciden con estas columnas. En este ejemplo, se utiliza JSON simple; sin embargo, OPENJSON puede manejar cualquier estructura anidada/jerárquica de objetos JSON. 
, OPENJSON puede utilizarse para combinar relacional y datos JSON en la misma consulta. Si suponemos que la matriz JSON que se muestra en el ejemplo anterior se almacena en la columna de pedidos, la consulta siguiente puede combinar las columnas y los campos JSON:
SELECT Id, FirstName, LastName, Number, Date, Customer, Quantity
 FROM Person
    CROSS APPLY OPENJSON (OrdersJson)
                            WITH (
                                        Number varchar(200), 
                                        Date datetime,
                                        Customer varchar(200),
                                        Quantity int ) AS OrdersArray
OPENJSON abre una matriz de cada celda y devuelve una fila por cada objeto JSON (es decir, elemento) en la matriz. Cruz OPENJSON aplicar sintaxis se utilizan para "juntar" filas en la tabla con la tabla interna del niño que se materializará de una matriz JSON en la celda JSON.

Indexación de datos JSON

Aunque los valores en JSON formato como texto, puede indexarlos al igual que cualquier otros valores en columnas de la tabla. Puede utilizar Cluster no estándar o índices de búsqueda de texto completo. 
Si desea crear un índice en alguna propiedad JSON que se utiliza con frecuencia en las consultas, puede crear una columna calculada no persistió que hace referencia el valor y se crea un índice estándar en esa columna. En el ejemplo siguiente, optimizamos consultas que filtran filas mediante la propiedad de .Company $ en la columna de InfoJSON:
ALTER TABLE Person
ADD vCompany AS JSON_VALUE(InfoJSON, '$.Company')
CREATE INDEX idx_Person_1
    ON Person(vCompany)
Como se puede ver, SQL Server proporciona un modelo híbrido, donde usted puede poner valores de JSON en columnas de clave o incluye y utiliza valores JSON y columnas estándar en el mismo índice. 
Puesto que JSON es texto normal, usted puede utilizar el índice de texto completo. Se pueden crear índices de texto completo en matrices de valores. 

Crear un índice de texto completo en una columna que contiene una matriz JSON, o puede crear una columna calculada que hace referencia a un array en la columna existente y crear un índice de búsqueda de texto completo en la columna:
ALTER TABLE Person
ADD vEmailAddresses AS JSON_QUERY(InfoJSON, '$.Contact.Emails')
CREATE FULLTEXT INDEX ON Person(vEmailAddresses)
    KEY INDEX PK_Person_ID ON jsonFullTextCatalog;
Índice de texto completo es útil si usted necesita para optimizar las consultas que intentan encontrar filas en la matriz JSON contiene algún valor:
SELECT PersonID, FirstName,LastName,vEmailAddresses
FROM Person
WHERE CONTAINS(vEmailAddresses, 'john@mail.microsoft.com')
Esta consulta devolverá filas de persona donde la matriz de correo electrónico contiene el valor 'john@mail.microsoft.com'. Índice de texto completo no tiene ninguna regla especial para el análisis de JSON. Dividirá un array JSON usando separadores (es decir doble comillas, comas, soportes) y los valores del índice en un array. Índice de texto completo es aplicable en matrices de números y valores de cadena simple. Si tienes objetos más complejos de una matriz JSON, un índice de texto completo no se puede aplicar directamente porque el sistema no sabe la diferencia entre claves y valores. 

Como se puede ver, los mismos métodos de indexación se utilizan tanto en columnas relacionales y valores JSON.
JSON en SQL Server 2016: Página 1 de 4
JSON en SQL Server 2016: Página 2 de 4
JSON en SQL Server 2016: Página 4 de 4