Documentation ¶
Index ¶
- func AesDecrypt(crypted, key []byte) ([]byte, error)
- func AesDecrypt_PHP(crypted, key []byte) ([]byte, error)
- func AesEncrypt(origData, key []byte) ([]byte, error)
- func AesEncrypt_PHP(origData, key []byte) (string, error)
- func CheckDate(date string) error
- func Connection(database string) (*sql.DB, error)
- func ConnectionCloud() (*sql.DB, error)
- func DiferenciaDate(date ...string) float64
- func GetDateLocationString() string
- func GetDateLocationTime() time.Time
- func GetDay() int64
- func GetDayDate(date string) (string, int)
- func GetFechaLocationString() string
- func GetFechaLocationStringAdd(days int) string
- func GetHoraLocationString() string
- func GetKey_PrivateCrypto() []byte
- func GetMonth() int64
- func GetMonthDate(date string) (string, int)
- func GetMonthString() string
- func GetYear() int64
- func GetYearDate(date string) (string, int)
- func GetYearString() string
- func IndexOf_String(arreglo []string, search string) int
- func InterfaceToString(params ...interface{}) string
- func IsItHoliday(date string, days_holidays []string) bool
- func Null() *regexp.Regexp
- func Number() *regexp.Regexp
- func PKCS5Padding(src []byte, blockSize int) []byte
- func PKCS7Padding(cipherText []byte, blockSize int) []byte
- func PKCS7UnPadding(origData []byte) []byte
- func Query_Cross_Update(query string) string
- func SumarDate(date string, days int) string
- type DataType
- type Fields
- type OperatorWhere
- type QConfig
- type Querys
- func (q *Querys) All() ([]map[string]interface{}, error)
- func (q *Querys) And(and string, op OperatorWhere, arg interface{}) *Querys
- func (q *Querys) Close()
- func (q *Querys) Connect(config QConfig) *Querys
- func (q *Querys) Exec(config QConfig) *Querys
- func (q *Querys) ExecTx() *Querys
- func (q *Querys) GetErrors() error
- func (q *Querys) GetQuery() string
- func (q *Querys) GroupBy(group ...string) *Querys
- func (q *Querys) Join(tp TypeJoin, table string, on string) *Querys
- func (q *Querys) Limit(limit ...int) *Querys
- func (q *Querys) One() (map[string]interface{}, error)
- func (q *Querys) Or(or string, op OperatorWhere, arg interface{}) *Querys
- func (q *Querys) OrderBy(campos ...string) *Querys
- func (q *Querys) ResetQuery()
- func (q *Querys) Select(campos ...string) *Querys
- func (q *Querys) SetNewArgs(arg ...interface{}) error
- func (q *Querys) SetQueryString(query string, arg interface{}) *Querys
- func (q *Querys) SetTable(table string) *Querys
- func (q *Querys) Text(columna string) (interface{}, error)
- func (q *Querys) Top(top int) *Querys
- func (q *Querys) Where(where string, op OperatorWhere, arg interface{}) *Querys
- type Regex
- type SqlExecMultiple
- func (sq *SqlExecMultiple) Commit() error
- func (sq *SqlExecMultiple) Exec(params ...bool) error
- func (sq *SqlExecMultiple) ExecTransaction(t *Transaction) error
- func (sq *SqlExecMultiple) New(database string) *SqlExecMultiple
- func (sq *SqlExecMultiple) SetInfo(table string, datos ...map[string]interface{}) *Transaction
- type SqlExecSingle
- func (sq *SqlExecSingle) Delete(schema []Fields) error
- func (sq *SqlExecSingle) Exec(database string, params ...bool) error
- func (sq *SqlExecSingle) Insert(schema []Fields) error
- func (sq *SqlExecSingle) New(table string, datos ...map[string]interface{}) *SqlExecSingle
- func (sq *SqlExecSingle) Update(schema []Fields) error
- type Transaction
- type TypeFloat64
- type TypeInt64
- type TypeJoin
- type TypeStrings
- type TypeUint64
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AesDecrypt ¶
func AesDecrypt_PHP ¶
func AesEncrypt ¶
func AesEncrypt_PHP ¶
func CheckDate ¶
*
- Retorna el índice de un elemento en un arreglo de strings
- date[string] = fecha a validar formato string dd/mm/yyyy
- return [bool],[error] = [true or false],[descripción del error or nil]
func ConnectionCloud ¶
func DiferenciaDate ¶
*
- Retorna la diferencia entre dos fechas en días.
- @param date {[]string}: fecha inicial y fecha final en formato dd/mm/yyyy, si no se pasa la fecha inicial se toma la fecha actual
- @return {float64} = diferencia entre fechas en días
func GetDateLocationString ¶
func GetDateLocationString() string
*
- Retorna Fecha en formato yyyy-mm-dd hh:mm:ss en zona horaria (America/Bogota)
- Return [string] : fecha formato string yyyy-mm-dd hh:mm:ss (America/Bogota)
func GetDateLocationTime ¶
retorna la fecha segun la locacion del usurio es este caso esta configurado para (America/Bogota)
func GetDayDate ¶
func GetFechaLocationString ¶
func GetFechaLocationString() string
*
- Retorna fecha en formato dd/mm/yyyy en zona horaria (America/Bogota)
- Return [string] : fecha formato string dd/mm/yyyy (America/Bogota)
func GetFechaLocationStringAdd ¶
agrega dias a la fecha actual y retorna fecha en formato string segun la location del usuario = (America/Bogota) 01/01/2021
func GetHoraLocationString ¶
func GetHoraLocationString() string
retorna fecha en formato string segun la location del usuario = (America/Bogota) 01:01:59
func GetKey_PrivateCrypto ¶
func GetKey_PrivateCrypto() []byte
func GetMonthDate ¶
func GetMonthString ¶
func GetMonthString() string
func GetYear ¶
func GetYear() int64
retorna la fecha segun la locacion del usurio es este caso esta configurado para (America/Bogota) 2021-01-01 12:00:00.000
func GetYearDate ¶
func GetYearString ¶
func GetYearString() string
retorna la fecha segun la locacion del usurio es este caso esta configurado para (America/Bogota) 2021-01-01 12:00:00.000
func IndexOf_String ¶
func InterfaceToString ¶
func InterfaceToString(params ...interface{}) string
recibe un valor interface que no se reconoce su tipo y devuelve un string
func IsItHoliday ¶
func PKCS5Padding ¶
func PKCS7Padding ¶
func PKCS7UnPadding ¶
func Query_Cross_Update ¶
Types ¶
type Fields ¶
type Fields struct { Name string Description string Type DataType Required bool PrimaryKey bool Where bool Update bool Default interface{} Empty bool ValidateType interface{} }
func SchemaForDelete ¶
func SchemaForUpdate ¶
type OperatorWhere ¶
type OperatorWhere string
* operaciones utilizadas con la sentencia WHERE
const ( I OperatorWhere = "=" D OperatorWhere = "<>" MY OperatorWhere = ">" MYI OperatorWhere = ">=" MN OperatorWhere = "<" MNI OperatorWhere = "<=" LIKE OperatorWhere = "LIKE" IN OperatorWhere = "IN" NOT_IN OperatorWhere = "NOT IN" BETWEEN OperatorWhere = "BETWEEN" NOT_BETWEEN OperatorWhere = "NOT BETWEEN" )
type Querys ¶
type Querys struct { Table string /** nombre de la tabla*/ // contains filtered or unexported fields }
func (*Querys) All ¶
* All recupera todos los resultados de la consulta SQL y los devuelve como una lista de mapas.
Esta función se utiliza para obtener todos los resultados de una consulta SQL ejecutada previamente utilizando el método Exec, y devuelve los resultados como una lista de mapas donde cada mapa representa una fila de resultados, con los nombres de las columnas como claves y los valores de las columnas como valores.
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} result,err:=queryBuilder.Select("campo1, campo2").Where("campo3", "=", valor).Exec("mi_database").All() // Obtiene todos los resultados de la consulta ejecutada.
Devuelve:
- Una lista de mapas, donde cada mapa representa una fila de resultados con los nombres de las columnas como claves y los valores de las columnas como valores.
- Un error, si ocurre alguno durante el proceso de recuperación de resultados.
func (*Querys) And ¶
func (q *Querys) And(and string, op OperatorWhere, arg interface{}) *Querys
* And añade una cláusula AND adicional a la cláusula WHERE existente de la consulta SQL. La condición, el operador y el argumento se especifican como parámetros.
Esta función se utiliza para agregar condiciones adicionales a la cláusula WHERE de la consulta SQL. Si la cláusula WHERE aún no está especificada en la consulta, esta función no hace nada.
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} result,err:=queryBuilder.Select("campo1, campo2").Where("campo3", "=", valor).And("campo4", ">", otroValor).Exec("mi_database").All() consultaFinal := queryBuilder.GetQuery()
Parámetros:
- and: Condición adicional para agregar a la cláusula WHERE existente.
- op: Operador para comparar valores en la condición (por ejemplo, "=", "<>", ">", "<","<=", ">=", "LIKE", "IN", "NOT IN", "BETWEEN" "NOT BETWEEN").
- arg: Valor que se compara en la condición.
Devuelve:
- Un puntero al struct Querys actualizado para permitir el encadenamiento de métodos.
func (*Querys) Exec ¶
* Exec ejecuta la consulta SQL en la base de datos y almacena los resultados en la estructura Querys.
Esta función se utiliza para ejecutar consultas SQL en la base de datos y almacenar los resultados en la estructura Querys para su posterior procesamiento.
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} result,err:=queryBuilder.Select("campo1", "campo2").Where("campo3", "=", valor).Exec("mi_database").All() // Ejecuta la consulta SQL utilizando la configuración proporcionada.
Parámetros:
- config: Configuración para la conexión a la base de datos, incluyendo detalles como la nube, el nombre de la base de datos, etc.
Devuelve:
- Un puntero al struct Querys actualizado con los resultados de la consulta ejecutada.
func (*Querys) GetQuery ¶
* GetQuery devuelve la consulta SQL completa construida utilizando los métodos del struct Querys.
Esta función se utiliza para obtener la consulta SQL completa que se ha construido utilizando los métodos del struct Querys, incluyendo la selección de columnas, cláusulas JOIN, condiciones WHERE, agrupamiento GROUP BY, ordenamiento ORDER BY, y limitación de resultados con TOP o LIMIT.
Devuelve:
- Una cadena que representa la consulta SQL completa construida.
func (*Querys) GroupBy ¶
* GroupBy establece la cláusula GROUP BY de la consulta SQL. Puede especificar una lista de campos como argumentos.
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} result,err:=queryBuilder.Select("campo1", "campo2").GroupBy("campo4", "campo5").Exec("mi_database").All() consultaFinal := queryBuilder.GetQuery()
Parámetros:
- group: Lista de nombres de campos a utilizar en la cláusula GROUP BY.
Devuelve:
- Un puntero al struct Querys actualizado para permitir el encadenamiento de métodos.
func (*Querys) Join ¶
* Join añade una cláusula JOIN a la consulta SQL. El tipo de unión (INNER, LEFT, RIGHT, etc.), la tabla y la condición ON se especifican como parámetros.
Ejemplo de uso:
queryBuilder := &Querys{Table: "tabla_principal"} result,err:=queryBuilder.Select("tabla_principal.columna1, tabla_secundaria.columna2"). Join("INNER_JOIN", "tabla_secundaria", "tabla_principal.id = tabla_secundaria.id"). Where("tabla_principal.columna3", "=", valor).Exec("mi_database").All() consultaFinal := queryBuilder.GetQuery()
Parámetros:
- tp: Tipo de unión (INNER, LEFT, RIGHT, etc.).
- table: Nombre de la tabla a unir.
- on: Condición ON para la unión.
Devuelve:
- Un puntero al struct Querys actualizado para permitir el encadenamiento de métodos.
func (*Querys) Limit ¶
* Limit establece la cláusula LIMIT de la consulta SQL para seleccionar un número específico de filas, con opción para especificar un offset.
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} result,err:=queryBuilder.Select().Where("campo3","=", valor).Limit(10).Exec("mi_database").All() // Limita la consulta a 10 filas result,err:=queryBuilder.Select("campo1", "campo2").Where("campo3","=", valor).Limit(10,3).Exec("mi_database").All() // Limita la consulta a 10 filas omitiendo 3 filas en el conjunto de resultados de una consulta consultaFinal := queryBuilder.GetQuery()
Parámetros:
- limit: Lista de uno o dos enteros. Si se proporciona un solo entero, establece el límite de filas. Si se proporcionan dos enteros, el primero especifica el límite de filas y el segundo especifica el offset.
Devuelve:
- Un puntero al struct Querys actualizado para permitir el encadenamiento de métodos.
func (*Querys) One ¶
* One recupera un solo resultado de la consulta SQL y lo devuelve como un mapa.
Esta función se utiliza para obtener un solo resultado de una consulta SQL ejecutada previamente utilizando el método Exec, y devuelve el resultado como un mapa donde las claves son los nombres de las columnas y los valores son los valores de las columnas correspondientes para la primera fila de resultados.
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} result,err:=queryBuilder.Select("campo1, campo2").Where("campo3", "=", valor).Exec("mi_database").One() // Obtiene un solo resultado de la consulta ejecutada.
Devuelve:
- Un mapa donde las claves son los nombres de las columnas y los valores son los valores de las columnas correspondientes para la primera fila de resultados.
- Un error, si ocurre alguno durante el proceso de recuperación del resultado.
func (*Querys) Or ¶
func (q *Querys) Or(or string, op OperatorWhere, arg interface{}) *Querys
* Or añade una cláusula OR adicional a la cláusula WHERE existente de la consulta SQL. La condición, el operador y el argumento se especifican como parámetros.
Esta función se utiliza para agregar condiciones adicionales a la cláusula WHERE de la consulta SQL. Si la cláusula WHERE aún no está especificada en la consulta, esta función no hace nada.
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} result,err:=queryBuilder.Select("campo1, campo2").Where("campo3", "=", valor).Or("campo4", ">", otroValor).Exec("mi_database").All() consultaFinal := queryBuilder.GetQuery()
Parámetros:
- and: Condición adicional para agregar a la cláusula WHERE existente.
- op: Operador para comparar valores en la condición (por ejemplo, "=", "<>", ">", "<","<=", ">=", "LIKE", "IN", "NOT IN", "BETWEEN" "NOT BETWEEN").
- arg: Valor que se compara en la condición.
Devuelve:
- Un puntero al struct Querys actualizado para permitir el encadenamiento de métodos.
func (*Querys) OrderBy ¶
* OrderBy establece la cláusula ORDER BY de la consulta SQL. Puede especificar una lista de campos como argumentos.
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} result,err:=queryBuilder.Select("campo1, campo2").Where("campo3","=", valor).OrderBy("campo4 DESC", "campo5 ASC").Exec("mi_database").All() consultaFinal := queryBuilder.GetQuery()
Parámetros:
- campos: Lista de nombres de campos a utilizar en la cláusula ORDER BY.
Devuelve:
- Un puntero al struct Querys actualizado para permitir el encadenamiento de métodos.
func (*Querys) ResetQuery ¶
func (q *Querys) ResetQuery()
func (*Querys) Select ¶
* Select establece la cláusula SELECT de la consulta SQL. Puede especificar una lista de campos como argumentos. Si no se proporcionan campos, se seleccionan todos (*).
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} result,err:=queryBuilder.Select().Exec("mi_database").All() result,err:=queryBuilder.Select("campo1,campo2").Exec("mi_database").All() result,err:=queryBuilder.Select("campo1", "campo2").Exec("mi_database").All() consultaFinal := queryBuilder.GetQuery()
Parámetros:
- campos: Lista de nombres de campos a seleccionar. Si está vacío, se seleccionan todos los campos.
Devuelve:
- Un puntero al struct Querys actualizado para permitir el encadenamiento de métodos.
func (*Querys) SetNewArgs ¶
func (*Querys) SetQueryString ¶
* SetQueryString establece una consulta SQL completa y sus argumentos en el struct Querys.
Esta función se utiliza para establecer una consulta SQL completa y sus argumentos en el struct Querys. Esto permite ejecutar consultas SQL personalizadas que no se construyeron utilizando los métodos de construcción de consultas normales del struct Querys.
Parámetros:
- query: La consulta SQL completa que se va a establecer en el struct Querys.
- arg: Los argumentos de la consulta SQL, que pueden ser un solo valor o un slice de valores.
Devuelve:
- Una referencia al struct Querys actualizado con la consulta SQL y sus argumentos.
func (*Querys) Text ¶
* Text recupera el valor de una columna específica de la primera fila de resultados de la consulta SQL.
Esta función se utiliza para obtener el valor de una columna específica de la primera fila de resultados de una consulta SQL ejecutada previamente utilizando el método Exec.
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} queryBuilder.Select("campo1, campo2").Where("campo3", "=", valor).Exec("mi_database") // Ejecuta la consulta SQL utilizando la configuración proporcionada. valor, err := queryBuilder.Text("nombreColumna") // Obtiene el valor de la columna "nombreColumna".
Parámetros:
- columna: Nombre de la columna de la cual se desea obtener el valor.
Devuelve:
- El valor de la columna especificada.
- Un error, si ocurre alguno durante el proceso de recuperación del valor.
func (*Querys) Top ¶
* Top establece la cláusula LIMIT de la consulta SQL para seleccionar un número específico de filas.
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} result,err:=queryBuilder.Select("campo1", "campo2").Top(10).Exec("mi_database").All() consultaFinal := queryBuilder.GetQuery()
Parámetros:
- top: Número de filas a seleccionar.
Devuelve:
- Un puntero al struct Querys actualizado para permitir el encadenamiento de métodos.
func (*Querys) Where ¶
func (q *Querys) Where(where string, op OperatorWhere, arg interface{}) *Querys
* Where establece la cláusula WHERE de la consulta SQL con una condición y un operador. La condición puede contener placeholders ($) para argumentos de la consulta. El operador se utiliza para comparar valores en la condición. El argumento es el valor que se comparará en la condición.
Ejemplo de uso:
queryBuilder := &Querys{Table: "mi_tabla"} result,err:=queryBuilder.Select("campo1, campo2").Where("campo3", "=", valor).Exec("mi_database").All() consultaFinal := queryBuilder.GetQuery()
Parámetros:
- where: Condición para la cláusula WHERE.
- op: Operador para comparar valores en la condición (por ejemplo, "=", "<>", ">", "<","<=", ">=", "LIKE", "IN", "NOT IN", "BETWEEN" "NOT BETWEEN").
- arg: Valor que se compara en la condición.
Devuelve:
- Un puntero al struct Querys actualizado para permitir el encadenamiento de métodos.
type SqlExecMultiple ¶
type SqlExecMultiple struct {
// contains filtered or unexported fields
}
func (*SqlExecMultiple) Commit ¶
func (sq *SqlExecMultiple) Commit() error
func (*SqlExecMultiple) Exec ¶
func (sq *SqlExecMultiple) Exec(params ...bool) error
*
- Ejecuta el query
- returns {error}: retorna errores ocurridos durante la ejecución
func (*SqlExecMultiple) ExecTransaction ¶
func (sq *SqlExecMultiple) ExecTransaction(t *Transaction) error
func (*SqlExecMultiple) New ¶
func (sq *SqlExecMultiple) New(database string) *SqlExecMultiple
*
- Reception datos para crear query para insertar, actualizar o eliminar
- datos {[]map[string]interface{}}: datos a insertar, actualizar o eliminar
- name {string}: nombre de la tabla
- returns {*SqlExec} retorna SqlExec struct
func (*SqlExecMultiple) SetInfo ¶
func (sq *SqlExecMultiple) SetInfo(table string, datos ...map[string]interface{}) *Transaction
*
- Reception datos para crear query para insertar, actualizar o eliminar
- datos {[]map[string]interface{}}: datos a insertar, actualizar o eliminar
- name {string}: nombre de la tabla
- returns {*SqlExec} retorna SqlExec struct
type SqlExecSingle ¶
type SqlExecSingle struct {
// contains filtered or unexported fields
}
func (*SqlExecSingle) Delete ¶
func (sq *SqlExecSingle) Delete(schema []Fields) error
*
- Valida los datos para Eliminar y crea el query para Eliminar
- schema {[]Model}: modelo de la tabla
- returns {error}: retorna errores ocurridos en la validación
func (*SqlExecSingle) Exec ¶
func (sq *SqlExecSingle) Exec(database string, params ...bool) error
*
- Ejecuta el query
- returns {error}: retorna errores ocurridos durante la ejecución
func (*SqlExecSingle) Insert ¶
func (sq *SqlExecSingle) Insert(schema []Fields) error
*
- Valida los datos para insertar y crea el query para insertar
- schema {[]Fields}: modelo de la tabla
- returns {error}: retorna errores ocurridos en la validación
func (*SqlExecSingle) New ¶
func (sq *SqlExecSingle) New(table string, datos ...map[string]interface{}) *SqlExecSingle
*
- Reception datos para crear query para insertar, actualizar o eliminar
- datos {[]map[string]interface{}}: datos a insertar, actualizar o eliminar
- name {string}: nombre de la tabla
- returns {*SqlExec} retorna SqlExec struct
func (*SqlExecSingle) Update ¶
func (sq *SqlExecSingle) Update(schema []Fields) error
*
- Valida los datos para actualizar y crea el query para actualizar
- schema {[]Model}: modelo de la tabla
- returns {error}: retorna errores ocurridos en la validación
type Transaction ¶
type Transaction struct {
// contains filtered or unexported fields
}
func (*Transaction) Delete ¶
func (t *Transaction) Delete(schema []Fields) error
func (*Transaction) Insert ¶
func (t *Transaction) Insert(schema []Fields) error
func (*Transaction) Update ¶
func (t *Transaction) Update(schema []Fields) error
type TypeFloat64 ¶
type TypeStrings ¶
type TypeUint64 ¶
type TypeUint64 struct {
Max uint64
}