如何让idea代码文件名tab窗口过多不自动隐藏

假如要编辑的代码窗口很多,默认tab上文件名超过一定数目会自动隐藏而只能点击下拉按钮下拉查找,这就比较麻烦了,如何让其全部显示呢?可参考下面:打开idea如图界面,点击Settings,打开Settings窗口,找到Editor Tabs(可利用搜索功能),取消勾选的 Show tabs in single row即可。

sqlite转换成MySQL迁移及一键sqlite转MySQL软件

下列是我从网上搜集并做的一个整理,若有未提及地方请指出:从sqlite数据库导入到mysql数据库实例从sqllite中导出数据文件库XX.sql的文件。导入到mysql数据库中。键入命令: source /smb/works/mysql.sql出现很多如下的错误:You have an error in your SQL syntax; check the manual thatcorresponds to your MariaDB server version for the right syntax to use near XXXXXXXXX原因是sqllite与mysql语句有很大的区别:左边为MYSQL、右边为SQLite1、启动事务Mysql 为start transactionSqlite 为 begin transaction2、提交事务Mysql 为commitSqlite 为commit transaction因此需要移除所有的 [BEGIN TRANSACTION] [COMMIT] 以及 任何包含 [sqlite_sequence] 的(整)行3 创建表Mysql的库名、表名、列明等都不需要使用[ ]sqlite 所有的名称都需要增加[ ]4、数据类型sqlite的数据类型mysql都支持。但是sqlite中定义了范围在mysql中导入会报错。只有varchar需要定义范围。5、冲突解决SQLite 的 ONCONFLICT子句不是独立的SQL命令。这是一条可以出现在许多其他SQL命令中的非标准的子句。在Mysql中不支持。6、引号将 ["] 改为 [`]也可以移除全部的 ["] ,但是如果有一些函数名作为字段名(e.g. regexp)时将会遇到错误需要注意一些默认为 ["] ,其作用不在字段上的,不应被替换而应当被保留7、将所有 [autoincrement] 改为 [auto_increment]8、将所有 ['f'] 改为 ['0'] 并将所有 ['t'] 改为 ['1']或者['False']改为['0']及['True']改为['1']9、text字段不能设置unipue,需改为varchar(255)10、注意sqlite是不区分类型的,所以有些整形字段和text字段要修改配合mysql。11、默认设为CURRENT_TIMESTAMP的字段类型一定为TIMESTAMP。另外还有其他可能不同的字段类型在导入sql报错时候可以百度解决将修改完的sql文件保存,然后通过工具导入到mysql中即可。参考原文:https://www.2cto.com/database/201604/501991.html          https://blog.csdn.net/duomoke/article/details/48246229当然最后来个最简单sqlite转MySQL方法,可以使用sqliteToMysql软件一键转换,只需要选择原db地址及目标MySQL地址即可,下载链接如下(有内购 不过可以免费试用):链接:https://pan.baidu.com/s/18mEN4JfHffseYf9N3GCeyA 提取码:9vv9

pgsql中能用to_date表示详细时间么?怎么表示具体时间段

    在Oracle中选择具体时间区间只需将字符用to_date进行转换成时间即可。但是在postgresql中是不是发现没效果咯?!    测试发现pgsql中的to_date真的是将时间转换成日期,而非精确到分秒,如下sql:select * from LOG a  where  a.CREATE_TIME >= to_date('2019-01-08 00:00:00','yyyy-MM-dd HH24:mi:ss') and a.CREATE_TIME <= to_date('2019-01-08 16:30:43','yyyy-MM-dd HH24:mi:ss')这样写虽然具体时间不一样,但是由于转换的是日期因此两实际时间在pgsql中是一样的,这种情况只需要将to_date改成to_timestamp即可,以后注意pgsql中to_date返回的是日期,非具体时间。

Could not set parameters for mapping: ParameterMapping{property='param'错误

mybatis中出现这样错误,Could not set parameters for mapping: ParameterMapping{property='param'问题原来出在xml中,由于#号修饰的变量加了引号所致,问题如下:select  code from sys_code where codename = '#{area}'解决方法也很简单,将引号去掉或者改为$,#{area}自带引号

System.out.println与System.err.println的区别

err是运行期异常和错误反馈的输出流的方向System.err.println只能在屏幕上实现打印,即使你重定向了也一样用err打印出的 字符串,再eclipse的console会显示成红色标准输出往往是带缓存的,而标准出错没有缓存(默认设置,可以改)System.out.println("1");System.out.println("2");System.err.println("3");上述输出1、2顺序输出,3输出顺序不定

SpringBoot统一异常处理研究

系统对异常的处理使用统一的异常处理流程:1、自定义异常类型。2、自定义错误代码及错误信息。3、对于可预知的异常由程序员在代码中主动抛出,由SpringMVC统一捕获。 可预知异常是程序员在代码中手动抛出本系统定义的特定异常类型,由于是程序员抛出的异常,通常异常信息比较齐全,程序员在抛出时会指定错误代码及错误信息,获取异常信息也比较方便。4、对于不可预知的异常(运行时异常)由SpringMVC统一捕获Exception类型的异常。 不可预知异常通常是由于系统出现bug、或一些不要抗拒的错误(比如网络中断、服务器宕机等),异常类型为RuntimeException类型(运行时异常)。5、可预知的异常及不可预知的运行时异常最终会采用统一的信息格式(错误代码+错误信息)来表示,最终也会随请求响应给客户端。1、在controller、service、dao中程序员抛出自定义异常;springMVC框架抛出框架异常类型2、统一由异常捕获类捕获异常,并进行处理3、捕获到自定义异常则直接取出错误代码及错误信息,响应给用户。4、捕获到非自定义异常类型首先从Map中找该异常类型是否对应具体的错误代码,如果有则取出错误代码和错误信息并响应给用户,如果从Map中找不到异常类型所对应的错误代码则统一为99999错误代码并响应给用户。5、将错误代码及错误信息以Json格式响应给用户。错误处理实战在共有项目中common中建exception包专门来存错误处理类.CustomExceptionpublic class CustomException extends RuntimeException {    private ResultCode resultCode;    public CustomException(ResultCode resultCode){        //异常信息 错误代码+异常信息        super("错误代码:"+resultCode.code()+"错误信息:"+resultCode.message());        this.resultCode=resultCode;    }    public ResultCode getResultCode(){        return this.resultCode;    }}其中作为响应的结果的ResultCode接口为 定义了基础信息:public interface ResultCode {    //操作是否成功,true为成功,false操作失败    boolean success();    //操作代码    int code();    //提示信息    String message();}ExceptionCastpublic class ExceptionCast {    //使用静态方法抛出自定义异常    public static void cast(ResultCode resultCode){        throw new CustomException(resultCode);    }}ExceptionCatch@ControllerAdvicepublic class ExceptionCatch {    private static final Logger LOGGER = LoggerFactory.getLogger(ExceptionCatch.class);    //使用EXCEPTIONS存放异常类型和错误代码的映射,ImmutableMap的特点的一旦创建不可改变,并且线程安全    private static ImmutableMap<Class<? extends Throwable>,ResultCode> EXCEPTIONS;    //使用builder来构建一个异常类型和错误代码的异常    protected static ImmutableMap.Builder<Class<? extends Throwable>,ResultCode> builder = ImmutableMap.builder();    @ExceptionHandler(Exception.class)    @ResponseBody    public ResponseResult exception(Exception e){        LOGGER.error("catch exception : {}\r\nexception: ",e.getMessage(), e);        if(EXCEPTIONS == null)            EXCEPTIONS = builder.build();        ResultCode resultCode = EXCEPTIONS.get(e.getClass());        ResponseResult responseResult;        if (resultCode != null) {            responseResult = new ResponseResult(resultCode);        } else {            responseResult = new ResponseResult(CommonCode.SERVER_ERROR);        }        return responseResult;    }    //捕获CustomEcception异常    @ExceptionHandler(CustomException.class)    @ResponseBody    public ResponseResult customException(CustomException e) {        LOGGER.error("catch exception : {}\\r\\nexception: ", e.getMessage(), e);        ResultCode resultCode = e.getResultCode();        ResponseResult responseResult = new ResponseResult(resultCode);        return responseResult;    }    static{        //在这里加入一些基础的异常类型判断        builder.put(HttpMessageNotReadableException.class,CommonCode.INVALID_PARAM);    }}CommonCodeimport lombok.ToString;@ToStringpublic enum CommonCode implements ResultCode{    INVALID_PARAM(false,10003,"非法参数!"),    SUCCESS(true,10000,"操作成功!"),    FAIL(false,11111,"操作失败!"),    UNAUTHENTICATED(false,10001,"此操作需要登陆系统!"),    UNAUTHORISE(false,10002,"权限不足,无权操作!"),    SERVER_ERROR(false,99999,"抱歉,系统繁忙,请稍后重试!");//    private static ImmutableMap<Integer, CommonCode> codes ;    //操作是否成功    boolean success;    //操作代码    int code;    //提示信息    String message;    private CommonCode(boolean success,int code, String message){        this.success = success;        this.code = code;        this.message = message;    }    @Override    public boolean success() {        return success;    }    @Override    public int code() {        return code;    }    @Override    public String message() {        return message;    }}CmsCodeimport lombok.ToString;@ToStringpublic enum CmsCode implements ResultCode {    CMS_ADDPAGE_EXISTSNAME(false,24001,"页面名称已存在!"),    CMS_GENERATEHTML_DATAURLISNULL(false,24002,"从页面信息中找不到获取数据的url!"),    CMS_GENERATEHTML_DATAISNULL(false,24003,"根据页面的数据url获取不到数据!"),    CMS_GENERATEHTML_TEMPLATEISNULL(false,24004,"页面模板为空!"),    CMS_GENERATEHTML_HTMLISNULL(false,24005,"生成的静态html为空!"),    CMS_GENERATEHTML_SAVEHTMLERROR(false,24006,"保存静态html出错!"),    CMS_COURSE_PERVIEWISNULL(false,24007,"预览页面为空!");    //操作代码    boolean success;    //操作代码    int code;    //提示信息    String message;    private CmsCode(boolean success, int code, String message){        this.success = success;        this.code = code;        this.message = message;    }    @Override    public boolean success() {        return success;    }    @Override    public int code() {        return code;    }    @Override    public String message() {        return message;    }}服务层add方法添加错误处理public CmsPageResult add(CmsPage cmsPage) {    if (cmsPage==null)        ExceptionCast.cast(CommonCode.INVALID_PARAM);//抛出通用错误类中的无效参数    //检验页面是否存在 根据页面名称 站点id 页面path查询    CmsPage cmsPage1 = cmsPageRepository.findByPageNameAndSiteIdAndPageWebPath(cmsPage.getPageName(), cmsPage.getSiteId(), cmsPage.getPageWebPath());    /*if (cmsPage1 == null) {        cmsPage.setPageId(null);//添加页面主键由spring data自动生成        cmsPageRepository.save(cmsPage);        //返回结果        CmsPageResult cmsPageResult = new CmsPageResult(CommonCode.SUCCESS, cmsPage);        return cmsPageResult;    }else { //如果不等于null就是有页面 添加失败抛出已存在页面异常        ExceptionCast.cast(CmsCode.CMS_ADDPAGE_EXISTSNAME);    }    return new CmsPageResult(CommonCode.FAIL, null);//如果存在则返回null 失败信息*/    //先列出所有错误再执行正确执行结果    if (cmsPage1!=null){        ExceptionCast.cast(CmsCode.CMS_ADDPAGE_EXISTSNAME);    }    cmsPage.setPageId(null);//添加页面主键由spring data自动生成    cmsPageRepository.save(cmsPage);    //返回结果    return new CmsPageResult(CommonCode.SUCCESS, cmsPage);}注意:启动类上要加上扫描异常处理类所在位置的包,例如:@ComponentScan(basePackages={"com.xuecheng.framework"})

SpringBoot统一异常处理研究

Java写Windows电脑开机自动访问上网验证页面

只针对于一些需要在登录页面输入账户名密码才能上网的情形。Java写的,打包成jar用bat运行即可,然后在Windows计划任务中将bat加为开机或登录启动即可。public class Main {    //连接    public static boolean isReachable(String remoteInetAddr) {        boolean reachable = false;        InetAddress address = null;        try {            address = InetAddress.getByName(remoteInetAddr);            reachable = address.isReachable(5000);        } catch (UnknownHostException e) {        } catch (IOException e) {        }        return reachable;    }    public static void main(String[] args) {        while (true) {            Boolean bon = false;            bon = isReachable("baidu.com");            if (bon)                return;            conn(bon);        }    }    //打开URL    public static void conn(boolean bon) {        URL url = null;        if (!bon) {            try {                url = new URL("这里填可以一键验证的网址 参数等可按F12获取");                InputStream in = url.openStream();//打开到此 URL 的连接并返回一个用于从该连接读入的 InputStream                System.out.println("重连成功");                in.close();//关闭此输入流并释放与该流关联的所有系统资源。            } catch (IOException e) {                System.out.println("无法连接到:" + url.toString());            }        }    }}

Windows电脑利用cmd运行jar文件

将java控制台程序打包成jar后怎么直接在本机运行呢?其实很简单:java -jar D:\ideawork\fileClean\out\artifacts\fileClean_jar\fileClean.jar后面D盘路径改成你jar所在路径即可

markdown清除本地冗余图片文件Java源码

        所用腾讯微盘同步助手即时同步文件,图片文件也是设置默认保存在笔记目录下。Markdown有一个问题就是文档中图片链接删除,源文件仍会存在于图片文件夹,下列这个程序可以对比并删除冗余的图片或资源文件(假删除,冗余文件将会移动到笔记文件夹中到 回收站 文件夹中,确定要删除时可以将整个文件夹手动删除)。public class Main {    static ArrayList<String> list= new ArrayList<>();    static String text;    public static void main(String[] args) {        File file = new File("D:\\微云同步助手\\QQ\\笔记");        //获取其file对象      //获取其file对象        func(file);        for (String s : list) {            String fileName = s.substring(s.lastIndexOf("\\") + 1, s.length());//获取文件名            if (!text.contains(fileName)){ //如果图片等资源在md内容中不存在即删除                System.out.println(fileName+"删除成功");                String hs=file+"\\回收站\\";                if (!new File(hs).exists())                    new File(hs).mkdir();                new File(s).renameTo(new File(hs+fileName));            }        }    }    /**     * 遍历目录     * @param file     */    private static void func(File file) {        File[] fs = file.listFiles();        for (File f : fs) {            if (f.isDirectory() && !f.toString().contains("回收站"))    //排除回收站目录                func(f);            if (f.isFile()) {      //若是文件,直接打印详细路径                String s = f.toString();                if (s.endsWith(".md")) {//获取md文件内容                    text += readToString(s);                } else {                    list.add(s);                }            }        }    }    /**     * 获取文本     * @param fileName     * @return     */    public static String readToString(String fileName) {        String encoding = "UTF-8";        File file = new File(fileName);        Long filelength = file.length();        byte[] filecontent = new byte[filelength.intValue()];        try {            FileInputStream in = new FileInputStream(file);            in.read(filecontent);            in.close();        } catch (FileNotFoundException e) {            e.printStackTrace();        } catch (IOException e) {            e.printStackTrace();        }        try {            return new String(filecontent, encoding);        } catch (UnsupportedEncodingException e) {            System.err.println("The OS does not support " + encoding);            e.printStackTrace();            return null;        }    }}当然也可以用BufferedReaderpublic class Main {    static ArrayList<String> list= new ArrayList<>();    static StringBuilder text=new StringBuilder();    /**     * 暴力比较     * @param args     * @throws IOException     */    public static void main(String[] args) throws IOException {        long start = System.currentTimeMillis();        File file = new File("D:\\坚果云\\CodeNote");        //获取其 file 对象        System.out.println("正在处理中……");        func(file);        for (String s : list) {            String fileName = s.substring(s.lastIndexOf("\\") + 1, s.length());//获取文件名            if (!text.toString().contains(fileName)){ //如果图片等资源在 md 内容中不存在即删除                System.out.println(fileName+"删除成功 ");                String hs=file+"\\回收站\\";                if (!new File(hs).exists())                    new File(hs).mkdir();                new File(s).renameTo(new File(hs+fileName));            }        }        long end=System.currentTimeMillis();        long time=end-start;        System.out.println("已完成,耗时"+time+" ms, 请按任意键退出");        System.in.read();    }    /**     * 遍历目录     * @param file     */    private static void func(File file) throws IOException {        File[] fs = file.listFiles();        for (File f:fs) {            if (f.isDirectory() && !f.toString().contains("回收站"))    //排除回收站目录                func(f);            if (f.isFile()) {      //若是文件,直接打印详细路径                String s = f.toString();                if (s.endsWith(".md")) {//获取 md 文件内容                    text.append(readToString(s));                    System.out.println("读取"+text.length()/1000+"K个字符");                } else {                    list.add(s);                }            }        }    }    /**     * 获取文本     * @param fileName     * @return     */    public static String readToString(String fileName) throws IOException {        BufferedReader br = new BufferedReader(new FileReader(fileName));        String line;        StringBuilder txt = new StringBuilder();        while ((line = br.readLine()) != null) {            txt.append(line);        }        br.close();        return txt.toString();    }}再改进下吧,用正则,精确点匹配(也不是很精确,因为不同文件夹可能有同名文件,不过能保证一个文件夹有文件 a.png跟 aaa.png不至于都匹配上)package com.company;import java.io.*;import java.util.ArrayList;import java.util.regex.Matcher;import java.util.regex.Pattern;public class Main {    static ArrayList<String> list= new ArrayList<>();    static StringBuilder text=new StringBuilder();    public static void main(String[] args) throws IOException {        ArrayList<String> picList = new ArrayList<>();        long start = System.currentTimeMillis();        File file = new File("D:\\坚果云\\CodeNotes");        //获取其 file 对象        System.out.println("正在处理中……");        func(file);        int i=0;        int delCount=0;        String ContentArea = text.toString();        String regex = "\\(assets/.*?\\.\\w+\\)";        Pattern pt=Pattern.compile(regex);        Matcher mt=pt.matcher(ContentArea);        while(mt.find()) {            String replace = mt.group().replace("(assets/", "").replace(")", "");            picList.add(replace);            i++;        }        System.out.println("原文包含"+i+"张图片");        for (String s : list) {            String fileName = s.substring(s.lastIndexOf("\\") + 1, s.length());//获取文件名            int count=0;            for (String pic : picList) {                if (pic.equals(fileName)){                    count++;                }            }            if (count<=0){                delCount++;//                System.out.println(fileName+"删除成功 ");                String hs=file+"\\回收站\\";                if (!new File(hs).exists())                    new File(hs).mkdir();                if (!new File(s).renameTo(new File(hs + fileName))){                    new File(hs + fileName).delete();                    new File(s).renameTo(new File(hs + fileName));                }            }        }        long end=System.currentTimeMillis();        long time=end-start;        System.out.println("已清理"+delCount+"张图片或文件,耗时"+time+" ms, 请按任意键退出");        System.in.read();    }    private static void func(File file) throws IOException {        File[] fs = file.listFiles();        for (File f:fs) {            if (f.isDirectory() && !f.toString().contains("回收站"))    //排除回收站目录                func(f);            if (f.isFile()) {      //若是文件,直接打印详细路径                String s = f.toString();                if (s.endsWith(".md")) {//获取 md 文件内容                    text.append(readToString(s));                } else {                    list.add(s);                }            }        }    }    public static String readToString(String fileName) throws IOException {        BufferedReader br = new BufferedReader(new FileReader(fileName));        String line;        StringBuilder txt = new StringBuilder();        while ((line = br.readLine()) != null) {            txt.append(line);        }        br.close();        return txt.toString();    }}

给button加超链接 window.open与window.location.href区别

加超链接很简单,只需要在标签里添加点击事件:onclick="window.open('/admin/goods_edit.html')"或者onclick="window.location.href='/admin/goods_edit.html'"再抑或在外部加个a标签即可。window.open只是打开页面window.location.href打开页面并刷新