mysql数据库中 convert_mysql-convert

mysql-convert

介绍

由特定格式下的 json 转为 mysql 语句

软件架构

├─dist ts编译后存放路径,其结构基本与src一致,没啥好看的

├─src 源码目录

|─test 测试开发目录

| |─dev.ts 测试用代码很少一看就懂

│ └─其他文件 没啥说的.偶尔测试会用

安装教程

npm i tmk-pay

使用说明

npm i @mac-xiang/mysql-convert

import {Literal, TmkMysql} from("tmk-mysql-convert");

const tmkMysqlConvert = new TmkMysql(param);

param 参数介绍

备注:凡是没有默认值的,都为必填项

属性名

数据类型

简介

field

typeField

数据表结构,详情参考下方 typeField 结构说明

table

string

数据库表名

limit

int

在查找数据时限制所得数据的数目条数,避免数据过多卡机.默认:100

offset

int

查找数据时,起始偏移数.默认:0

auto

string[]

数据库中自动赋值字段(不允许插入值中含有此字段).默认:["id"]

read

string[]

数据库中的只读字段.默认:与 auto 字段相等

showField

string[]

在查询数据库时,如果未指定所需展示的字段名时,所包含的字段名.默认:field 全部

[propName: string]: [number, any?, any?];

typeField 数据类型:

例:{

字段名1:[数据最小值,数据最大值,是否整数], // 如果成员为3,则代表此字段为数值型,如果第三参数为非 0/空,则表示整数,否则为float

字段名2:[数据长度,超出长度后截取方式] // 如果成员为2,则表示此字段为文本型.数据长度则为此数据最大长度,超出长度后根据 超出长度截取方式进行截断数据. if(超出长度后截取方式) 最终值为取前 数据长度 数据.else 取数据尾部 长度为数据长度的值.

}

步骤 3 中所得 tmkMysqlConvert;

const sql=tmkMysqlConvert.sql(object); // sql 就是最终 sql 语句;

object 成员取值如下:

method:方法,取值范围如下; 默认:0

作用

0 | get | r | read

查找

1 | up | u | update

修改

2 | add | c | create

新增/插入

3 | del | d | delete

删除

table:如果使用 new Literal("string") 则值完全等于 string.否则取之前新建对象传入的数据表名.

where: 条件语句,为数组,其成员数据如下:

注:凡是没有默认值则为必填项.否则此条数据作废.

成员名

数据类型

默认值

说明

field

string

数据库字段名

logic

"and" | "or"

非"or"为"and"

与前一个条件的逻辑关系,首条件强制为 "and"

method

">" | "=" | "<=" | "!=" | "in" | "nin" | "regexp" | "like"

"="

mysql 的逻辑运算符,如果 值为 in/nin 则判断 value 是否为数组,如果不为数组,则放弃此条件,如果为数组,则根据字段值,进行每个元素的取值,对字段为数值类型非常严格,如果成员不能转化为数值类型,则放弃此值.文本型则进行 JSON 编码.并保证 mysql 识别为字符串编码.如果为 regexp,则 value 必须是 string,并且将其复制为正则表达式.如果为 like.则将 value 转为字符串,并在其前后增加 %

value

string | number | (string | number)[] | Literal

如果数据类型为 Literal 则 method 失效.并不做后面判断. 如果字段为数值类型,则判断此值是否为所设字段区间内(大于等于最小值,小于等于最大值),并且根据是否取整进行取整操作,符合条件则取值,否则作废. 如果字段为非数值类型,则将其 JSON 格式化为字符串,并转译其内容,保证内容在 mysql 语句中为字符串.

value: 在改/增时有效.

修改/新增 对应数据.属性名就是字段名,值为当前所设值.优先判定属性名是否在新建实例时所设field内,不在其内则放弃.对于非数值类型 则先 JSON 数据,再进行 mysql 特殊符号转码.如果是文本型数据,则判断是否超出字段允许长度.如果超出,则根据规则进行截取字符串的 前/后 限定长度数据. 如果方法为新增数据则:当做完判定后,在根据最终得到的数据进行字段判定.如果缺少某一字段.则根据字段类型进行填充,数值类型填充为0,文本型填充为空文本"".

limit:int 默认:创建对象时设定的值 数据长度限制.查找/修改 数据时有效

offset:int 默认:创建对象时设定的值 数据起始偏移.查找/修改 数据时有效

other: Literal, 默认:空. 处于安全考虑 此值必须是 Literal 类型.

此值只能由后端手动添加. 这里的值将附加在 mysql语句中 limit前面.用于自定义操作.例如添加排序语句等.

参与贡献

就我一个,但使用了 n 多包.

特技

由前端进行 mysql 语句规则创建,发送 json 到后端.然后后端解析 json 为 object 后,将值传入 sql 方法 得到返回值就是 sql 语句了.安全防注入.并且规则几乎能满足大多数需求了.甚至可以达到多表联查的功能,当然,非标准方法得用到 Literal,而 Literal 只能由 new Literal("xxx")进行创建.

npm 上传包命令

npm publish --registry http://registry.npmjs.org

npm config set registry https://registry.npmjs.org

npm publish --access public

npm config set scope mac-xiang --global

npm version prerelease

npm version prepatch

别笑,记不住

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值