# mysql-convert **Repository Path**: MacXiang/mysql-convert ## Basic Information - **Project Name**: mysql-convert - **Description**: 由特定格式下的json转为mysql语句 - **Primary Language**: TypeScript - **License**: AGPL-3.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 9 - **Forks**: 0 - **Created**: 2021-02-11 - **Last Updated**: 2025-08-19 ## Categories & Tags **Categories**: database-dev **Tags**: None ## README # mysql-convert #### 介绍 由特定格式下的 json 转为 mysql 语句 #### 软件架构 ``` ├─dist ts编译后存放路径,其结构基本与src一致,没啥好看的 ├─src 源码目录 |─test 测试开发目录 | |─dev.ts 测试用代码很少一看就懂 │ └─其他文件 没啥说的.偶尔测试会用 ``` #### 安装教程 npm i tmk-pay #### 使用说明 1. npm i @mac-xiang/mysql-convert 2. import {Literal, TmkMysql} from("tmk-mysql-convert"); 3. 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 --registry https://registry.npmjs.org npm config set scope mac-xiang --global npm version prerelease npm version prepatch 别笑,记不住