当前位置: 首页 > news >正文

做移动端网站软件韩国购物网站

做移动端网站软件,韩国购物网站,小学生制作书签,易语言做网站视频文章目录 学习链接模块访问者模式parser模块statement模块Expression模块deparser模块 测试TestDropTestSelectTestSelectVisitor 学习链接 java设计模式#xff1a;访问者模式 github使用示例参考 测试 JSqlParser使用示例 JSqlParse#xff08;一#xff09;基本增删改… 文章目录 学习链接模块访问者模式parser模块statement模块Expression模块deparser模块 测试TestDropTestSelectTestSelectVisitor 学习链接 java设计模式访问者模式 github使用示例参考 测试 JSqlParser使用示例 JSqlParse一基本增删改查语句build JSqlParse二带where的查询语句build JSqlParser专栏系列教程 jsqlparser:基于抽象语法树(AST)遍历SQL语句的语法元素 Sql解析转换之JSqlParse完整介绍 JSqlParser系列之二代码结构原 JSQLPARSER解析SQL知识入门 jsqlparser基本使用 模块 访问者模式 访问者模式理解 有固定结构的数据封装类结构基本不会发生变化。它们都有1个接收访问者的方法。 访问者针对每1个具体的结构封装类都有1个具体的访问方法。 在具体的结构封装类接收访问者的方法中可直接调用访问者针对当前结构类的方法。 如果封装类结构不是固定的那么不能使用这种模式 parser模块 statement模块 Expression模块 deparser模块 测试 TestDrop 先创建java对象结构使用deparser将java对象转为得到sql字符串 import net.sf.jsqlparser.schema.Table; import net.sf.jsqlparser.statement.drop.Drop; import net.sf.jsqlparser.util.deparser.DropDeParser; import org.junit.Test;public class TestDrop {Testpublic void test_drop() {// 创建DropDrop drop new Drop();// 创建TableTable table new Table();table.setName(sys_user);// 设置dropdrop.setName(table);drop.setType(table);drop.setIfExists(true);// 最终的sqlStringBuilder stringBuilder new StringBuilder();// 使用DropDeParser来将java对象(封装了sql信息)转为具体的sql语句// 这里的代码是参照StatementDeParser#visit(Drop)DropDeParser dropDeParser new DropDeParser(stringBuilder);dropDeParser.deParse(drop);// 获取最终的目标sqlString sql dropDeParser.getBuffer().toString();// DROP table IF EXISTS sys_userSystem.out.println(sql);}} TestSelect 给原来的sql语句添加查询条件age 18 and dept_id in (1,2,3) package com.zzhua;import net.sf.jsqlparser.JSQLParserException; import net.sf.jsqlparser.expression.LongValue; import net.sf.jsqlparser.expression.operators.conditional.AndExpression; import net.sf.jsqlparser.expression.operators.relational.EqualsTo; import net.sf.jsqlparser.expression.operators.relational.ExpressionList; import net.sf.jsqlparser.expression.operators.relational.InExpression; import net.sf.jsqlparser.parser.CCJSqlParserUtil; import net.sf.jsqlparser.schema.Column; import net.sf.jsqlparser.statement.Statement; import net.sf.jsqlparser.statement.select.PlainSelect; import net.sf.jsqlparser.statement.select.Select; import net.sf.jsqlparser.statement.select.SelectBody; import net.sf.jsqlparser.util.deparser.ExpressionDeParser; import net.sf.jsqlparser.util.deparser.SelectDeParser; import net.sf.jsqlparser.util.deparser.StatementDeParser; import org.junit.Test;import java.util.ArrayList;public class TestSelect {Testpublic void test_select() throws JSQLParserException {Statement statement CCJSqlParserUtil.parse(select id,nick_name from sys_user where id 10);if (statement instanceof Select) {System.out.println(select语句);Select select (Select) statement;StringBuilder buffer new StringBuilder();// 这里的代码是参照 StatementDeParser#visit(Select)// SelectParser实现了SelectVisitor接口, 能够访问PlainSelect、SetOperationList、WithItemSelectDeParser selectDeParser new SelectDeParser();selectDeParser.setBuffer(buffer);ExpressionDeParser expressionDeParser new ExpressionDeParser(selectDeParser, buffer);selectDeParser.setExpressionVisitor(expressionDeParser);// SelectBody接收selectParser的访问(访问的结果会添加到buffer中)select.getSelectBody().accept(selectDeParser);// 输出原始的sql: SELECT id, nick_name FROM sys_user WHERE id 10System.out.println(buffer);SelectBody selectBody select.getSelectBody();if (selectBody instanceof PlainSelect) {// 原来的selectBodyPlainSelect plainSelect (PlainSelect) select.getSelectBody();// age 18EqualsTo equalsTo new EqualsTo();Column ageColumn new Column(age);equalsTo.setLeftExpression(ageColumn);equalsTo.setRightExpression(new LongValue(18));// 在原来的where条件中拼接上刚刚创建的条件 age18, 并使用And连接起来AndExpression andExpression1 new AndExpression(plainSelect.getWhere(), equalsTo);// dept_id in (1,2,3)InExpression inExpression new InExpression();inExpression.setLeftExpression(new Column(dept_id));ExpressionList expressionList new ExpressionList(new ArrayList());expressionList.getExpressions().add(new LongValue(1));expressionList.getExpressions().add(new LongValue(2));expressionList.getExpressions().add(new LongValue(3));inExpression.setRightItemsList(expressionList);AndExpression andExpression2 new AndExpression(andExpression1, inExpression);// 替换掉原来的where条件plainSelect.setWhere(andExpression2);// 直接参考StatementDeParserStatementDeParser statementDeParser new StatementDeParser(new StringBuilder());Select newSelect new Select();newSelect.setSelectBody(plainSelect);statementDeParser.visit(newSelect);// 输出sql: SELECT id, nick_name FROM sys_user WHERE id 10 AND age 18 AND dept_id IN (1, 2, 3)System.out.println(statementDeParser.getBuffer());}}}} TestSelectVisitor Slf4j public class TestSelectVisitor {public static void main(String[] args) throws Exception {String sqlStr SELECT\n su.dept_id deptId,\n su.user_id,\n sr.role_id,\n su.user_name,\n sd.dept_name,\n sr.role_name\n FROM\n sys_user AS su\n JOIN sys_dept sd ON su.dept_id sd.dept_id\n JOIN sys_user_role sur ON sur.user_id su.user_id\n JOIN sys_role sr ON sur.role_id sr.role_id\n WHERE\n sd.dept_name 研发部门\n AND su.user_name admin\n AND su.dept_id 103\n OR sr.role_name 超级管理员\n ORDER BY\n sd.create_time DESC;Select querySql (Select)CCJSqlParserUtil.parse(sqlStr);querySql.getSelectBody().accept(new SelectVisitorAdapter() {Overridepublic void visit(PlainSelect plainSelect) {log.info(--------------查询列名----------------------------------------);plainSelect.getSelectItems().stream().forEach(selectItem - {selectItem.accept(new SelectItemVisitorAdapter() {Overridepublic void visit(SelectExpressionItem selectExpressionItem) {log.info(selectExpressionItem.getExpression().toString());if (selectExpressionItem.getAlias()!null) {log.info(列别名 {},selectExpressionItem.getAlias().getName());}}});});log.info(--------------From Table Info----------------------------------------);log.info(plainSelect.getFromItem().toString());if (plainSelect.getFromItem().getAlias()!null) {log.info(表别名plainSelect.getFromItem().getAlias().getName());}log.info(--------------Join Table Info----------------------------------------);plainSelect.getJoins().stream().forEach(join - {log.info(join.toString());log.info(关联表{} ,join.getRightItem());if (join.getRightItem().getAlias()!null) {log.info(关联表别名{},join.getRightItem().getAlias().getName());}log.info(关联条件{},join.getOnExpression().toString());});log.info(--------------Where Info----------------------------------------);plainSelect.getWhere().accept(new ExpressionVisitorAdapter() {Overridepublic void visitBinaryExpression(BinaryExpression expr) {log.info(表达式{},expr.toString());log.info(表达式左侧{},expr.getLeftExpression().toString());log.info(表达式右侧{},expr.getRightExpression().toString());}});log.info(--------------增加查询条件----------------------------------------);try {plainSelect.setWhere(new AndExpression(CCJSqlParserUtil.parseCondExpression(11),plainSelect.getWhere()));} catch (JSQLParserException e) {throw new RuntimeException(e);}}});log.info(语句{},querySql.toString());} }/* --------------查询列名---------------------------------------- su.dept_id 列别名 deptId su.user_id sr.role_id su.user_name sd.dept_name sr.role_name --------------From Table Info---------------------------------------- sys_user AS su 表别名su --------------Join Table Info---------------------------------------- JOIN sys_dept sd ON su.dept_id sd.dept_id 关联表sys_dept sd 关联表别名sd 关联条件su.dept_id sd.dept_id JOIN sys_user_role sur ON sur.user_id su.user_id 关联表sys_user_role sur 关联表别名sur 关联条件sur.user_id su.user_id JOIN sys_role sr ON sur.role_id sr.role_id 关联表sys_role sr 关联表别名sr 关联条件sur.role_id sr.role_id --------------Where Info---------------------------------------- 表达式sd.dept_name 研发部门 AND su.user_name admin AND su.dept_id 103 OR sr.role_name 超级管理员 表达式左侧sd.dept_name 研发部门 AND su.user_name admin AND su.dept_id 103 表达式右侧sr.role_name 超级管理员 --------------增加查询条件---------------------------------------- 语句SELECT su.dept_id deptId, su.user_id, sr.role_id, su.user_name, sd.dept_name, sr.role_name FROM sys_user AS su JOIN sys_dept sd ON su.dept_id sd.dept_id JOIN sys_user_role sur ON sur.user_id su.user_id JOIN sys_role sr ON sur.role_id sr.role_id WHERE 1 1 AND sd.dept_name 研发部门 AND su.user_name admin AND su.dept_id 103 OR sr.role_name 超级管理员 ORDER BY sd.create_time DESC */
http://www.hkea.cn/news/14270695/

相关文章:

  • 用邮箱做网站如何把自己的网站推广
  • 微信公众平台对接网站seo 优化 服务
  • 网站建设方案策划书ppt用rp怎么做网站原型
  • 民非企业网站建设费怎么记账网络科技网站有哪些方面
  • 如何做试玩类网站网站配色教程
  • 有哪些做婚礼平面设计的网站网站有中文源码加英文怎么做
  • 成都建设网站的公司无锡地区网站制作公司排名
  • 拿自己爱人做网站厦门建设局耿家强
  • 包头哪有做网站的建设局主要负责什么
  • 市政建设招标网站有哪些wordpress 的环境搭建
  • 洮南网站建设哪家好通联支付网络服务股份有限公司
  • 互联网营销常用网站怎么用图片做网站背景图
  • 怎么建设网站运城2024年阳性最新症状
  • 网站流量如何做找网页模板的网站
  • 企业网站是企业在互联网上进行网络营销企业收录网站
  • 望牛墩做网站linkcat wordpress
  • asp.net+制作网站开发重庆教育建设集团有限公司官方网站
  • 网站建设需要学多久知乎有创意的设计产品
  • php做的网站网站运营案例
  • 电商网站开发平台用什么人开发pc端软件下载
  • 杨浦区建设小学网站首页建设银行代发工资网站
  • 外贸网站建设模板windows 2003 取消网站访问密码
  • 做自媒体一般都注册几个网站上市公司网站的作用
  • 建站中心网站开发安全性
  • 山东做网站的织梦 别人 网站 模板
  • 网站开发所需硬件wordpress站内301
  • 保洁公司做网站有什么作用专做外贸库存的网站
  • 我做的网站平台百度搜不到网站优化的方式有哪些
  • 网站什么时候恢复彩色邢台做网站企业
  • 厦门seo公司网站家具制作网站