对于取多个枚举字段,select 中带子查询 和 全部用left join 哪个好呢?

我们有一个枚举表SY_ECODE。
但是一条数据的七八个字段都是枚举选项,数据库存的是枚举编码,每次查询数据取对应的枚举值,如果left join 的话,就要七八次,就如下边的SQL。我感觉用子查询的话好看一点,写起来也方便,不然的话l要eft join好多次,到底怎么优化呢?

select
        (select e.ECODETEXT from SY_ECODE e where e.ecode = o.otsstatus and e.ecodetype = 'SQM_OTS_STATUS') otsstatus,
        (select e.ECODETEXT from SY_ECODE e where e.ecode = c.conclusion and e.ecodetype = 'SQM_OTS_CONCLUSION') conclusion,
        (select e.ECODETEXT from SY_ECODE e where e.ecode = p.parttype and e.ecodetype = 'SQM_APQP_PART_TYPE') parttype,
        (select e.ECODETEXT from SY_ECODE e where e.ecode = p.professional and e.ecodetype = 'SQM_APQP_PROFESSION') professionalText,
        (select e.ECODETEXT from SY_ECODE e where e.ecode = p.developtype and e.ecodetype = 'SQM_APQP_PART_DEVTYPE') developtype,
        (select e.ECODETEXT from SY_ECODE e where e.ecode = j.PROJECTLEVEL and e.ecodetype = 'SQM_APQP_PROJECT_LEVEL') PROJECTLEVEL,
        (select pf.platform from GPIS_BASE_PLATFORM pf where pf.id = p.platformid) platformText,
        (select u.usertext from sy_user u where u.usercode = a.DEVUSERCODE ) devUserText,
        (select u.usertext from sy_user u where u.usercode = a.SEUSERCODE) seUserText,
        (CASE WHEN p.isSingleVehicle = '0' THEN '否' WHEN p.isSingleVehicle = '1' THEN '是' ELSE '' END ) isSingleVehicle,
        o.id,o.otscode,a.projectid,j.PROJECTNAME,a.apqpCode,ap.subapqpcode,p.contractPartName,p.PARTNO,p.PARTNAME,
        ap.PLANFINISHDATE,p.vehiclenames,ap.FINISHDATE
        from
        SQM_APQP_OTS o
        left join SQM_OTS_CONCLUSION_ISSUED c on c.otscode = o.otscode
        left join SQM_APQP_INFO a on a.id = o.apqpid
        left join SQM_APQP_ASSOCIATE_PARTS ap on ap.apqpcode = a.APQPCODE
        left join SQM_APQP_PARTS p on p.id = ap.partid
        left join SQM_APQP_PROJECT j on j.id = a.projectid

3个回答

带子查询 和 left join都可以

left join比子查询效率高,最好是使用left join

个人觉得此类问题基本从两个角度考虑,1)运行效率,2)代码可读性和可维护性
对于枚举值,我个人的做法是先用小查询把枚举值查出来,然后再在查询里使用,这样关联表少,查询速度也快,可读性也高。
当然还是要具体问题具体分析,如果你需要全部枚举值参与的,那自然我的做法就不能使用。但退一步来说,如果你总是要把这么多表join起来,是不是和通常我们反对的SELECT * 一样,是不是该重新考虑下设计呢?^-^

weixin_39584851
weixin_39584851 回复一杯星空一个世界: 没看懂,子查询不都是在Join的时候用么
大约一个月之前 回复
weixin_39584851
weixin_39584851 没看懂,子查询不都是在Join的时候用么。
大约一个月之前 回复
liyaowen505
一杯星空一个世界 谢谢^^。另外,在select中用子查询 和 在where中用子查询 效率什么的有区别吗
11 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
asp读取mssql返回的字段,使用自定义截取字符串方法爆类型不匹配
asp程序使用的mssql数据库,从数据库读取字段后,使用自定义截取字符串方法是报错如下: Microsoft VBScript 运行时错误 错误 '800a000d' 调用方法名称cutstr: owen1="新闻公告" Set rs02=Server.CreateObject("ADODB.RecordSet") sql="select top 7 news_id,news_Title,check_link,web_link,Creat_Date,hot from news_zx where (BigClassName='"&owen1&"' or BigClassName='询价采购') and (check_tj=1 and check_open=1) order by Creat_Date desc" rs02.Open sql,conn,1,1 if rs02.eof and rs02.bof then response.Write("暂时没有记录") else k=1 Do While Not rs02.Eof and k<7 'response.Write("<li><span class='date'>"&rs02("Creat_Date")&"</span>") response.Write(TypeName(rs02("news_Title"))) response.write(cutstr(rs02("news_Title"),5)) response.write(cutstr(Cstr(rs02("news_Title")),5)) response.Write("</li>") rs02.MoveNext k=k+1 Loop end if rs02.close set rs02=nothing cutstr方法如下: function cutstr(tempstr,lef)' for le=1 to len(tempstr) if asc(mid(tempstr,le,1))<0 then lef=lef-2 else lef=lef-1 end if if lef<=0 then exit for next if len(tempstr)>le then cutstr=left(tempstr,le)&"..." else cutstr=tempstr end if end function 补充: response.write(cutstr(rs02("news_Title"))) rs02("news_Title")数据库字段类型是nvarchar,使用TypeName(rs02("news_Title"))输出Field。 但是仍然报错Microsoft VBScript 运行时错误 错误 '800a000d',cutstr类型不匹配 试了N多方法不管用,跪求大神指点
Java画板代码 请问这个flag变量具体是什么作用?
``` import java.awt.*; import java.awt.event.*; import javax.swing.*; public class DrawPanel extends JPanel { private JPanel right,left;//建立2个面板 private JRadioButton op2; private int f=2; private int sx, sy, x,y; **private boolean flag=false;**//【这个flag】 private Color c; private Point point1=null,point2=null; public DrawPanel()//DrawPanel无参构造器 { c =Color.black; right = new JPanel(); left = new JPanel(); ButtonGroup g = new ButtonGroup();//new一个按钮组 op2 = new JRadioButton("直线",false); g.add(op2); left.setLayout(new BoxLayout(lef__t,BoxLayo_ut_.Y_AXI_S)); left.add(op2); op2.addActionListener(new listen2()); right.setBackground(Color.white); // right.addMouseListener(new listen1()); right.addMouseMotionListener(new listen1()); setLayout(new BorderLayout());//边界布局 add(right,"Center"); add(left,"West"); setBackground(Color.white); setPreferredSize(new Dimension(500,450)); _ } private class listen1 implements MouseListener,MouseMotionListener { public void mousePressed(MouseEvent event)//按下鼠标时: { **flag=false;** point1=event.getPoint();//记录按下鼠标时的点坐标 sx=point1.x; sy=point1.y ; } public void mouseReleased(MouseEvent event)//释放鼠标时: { Graphics g=right.getGraphics();// switch(f){ case 2://画直线按钮被选中时: point2=event.getPoint();//获取释放鼠标的坐标点 x=point2.x; y=point2.y ; g.setColor(c); g.drawLine(sx,sy,x,y);//画一条从单击点到释放点的直线 break; } } public void mouseEntered(MouseEvent event){} public void mouseExited(MouseEvent event){} public void mouseClicked(MouseEvent event){ } public void mouseMoved(MouseEvent event){} public void mouseDragged(MouseEvent event) //具体化MouseMotionListener中的拖拽方法,使在拖拽鼠标时产生预览效果 { Graphics g=right.getGraphics(); switch(f){ case 2:////画直线按钮被选中时: ** if(! flag){** point2=event.getPoint(); x=point2.x; y=point2.y ; g.drawLine(sx,sy,x,y); flag=true; } else { g.setXORMode(Color.red);//设置异或画图模式 g.drawLine(sx,sy,x,y); //清除上次移动时画出的线 point2=event.getPoint(); x=point2.x; y=point2.y ; g.drawLine(sx,sy,x,y); } break;} } } private class listen2 implements ActionListener { public void actionPerformed(ActionEvent event) { Object source=event.getSource();//获得事件源 if(source==op2)f=2;//直线 } } } ```
关于rotate和translate的两个问题
![图片说明](https://img-ask.csdn.net/upload/201704/07/1491542290_183448.png) 问题1.一个正方形 让它向右旋转90度,以下面这种代码方式再让它向右转90度 mybox.style.transform=mybox.style.transform+"rotate(90deg)"; 为什么第二次反向转到目标位置 比如上面的程序执行两次右转 问题2.rotate和translate同时执行的时候 rotate应该是影响了translate的坐标轴的 rotate的坐标轴基点在中心。可以设置transform-origin设置 我下在想让正方形相对浏览器水平移动100px 同时旋转60deg transform:rotate(60deg) transform(100px,0) 这种实现是有问题的 rotate影响了translate的坐标轴 我能不能设置translate的坐标轴为浏览器(固定不变的参考系)?我没有查到相关资料。 如果不行的话 我怎么实现 正方形相对浏览器水平移动100px 同时旋转60deg(怎么让rotate不影响tranlate ) 上面程序就是rotate后影响了go的方向 源码: ``` <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>task3-3</title> <style type="text/css"> .box { position: relative; width: 500px; height: 500px; margin: 100px auto 20px auto; border: 2px solid black; } .container { width: 100%; height: 100%; font-size: 0; } .container div { box-sizing: border-box; width: 10%; height: 10%; display: inline-block; border-right: 1px solid #ccc; border-bottom: 1px solid #ccc; } .cont_row{ position: absolute; margin-top: -50px; width: 100%; height: 10%; } .cont_row div,.cont_col div{ height: 50px; width: 50px; float: left; display: inline-block; text-align: center; line-height: 50px; } .cont_col{ position: absolute; margin-top: -500px; margin-left: -50px; width: 10%; height: 100%; } form{margin-top: 30px;} #myBox{ position: absolute; top: 350px; left: 250px; box-sizing: border-box; width: 50px; height: 50px; background-color: #ec3325; border: none; transition: all 1s linear; } #myHead{ position: absolute; box-sizing: border-box; width: 50px; height: 15px; background-color:#001df5 ; border: none; } </style> </head> <body> <div class="box"> <div class="cont_row"> <div>1</div> <div>2</div> <div>3</div> <div>4</div> <div>5</div> <div>6</div> <div>7</div> <div>8</div> <div>9</div> <div>10</div> </div> <div class="container"> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div id="myBox"><div id="myHead"></div></div> </div> <div class="cont_col"> <div>1</div> <div>2</div> <div>3</div> <div>4</div> <div>5</div> <div>6</div> <div>7</div> <div>8</div> <div>9</div> <div>10</div> </div> <form action="#"> <input style="width:200px; height: 25px; " type="text" id="order"> <input type="button" value="执行" id="action"> </form> <p>指令有:GO:向蓝色边所面向的方向前进一格<br> TUN LEF:向左转(逆时针旋转90度)<br> TUN RIG:向右转(顺时针旋转90度)<br> TUN BAC:向右转(旋转180度)</p> </div> <script> //规定方向 1:上, 2:右 ,3:下, 4:左。di属性储存方向值,方向控制go命令的走法 //旋转 注意累计角度值即可 var act = document.getElementById("action"); var order = document.getElementById("order"); var mybox = document.getElementById("myBox"); var angle=0;//角度计数 var count=1;//计步 mybox.di=1; function takeOrder() { if(order.value=="TUN LEF"){ //为了不出现负方向先进行判断 if(mybox.di==1){mybox.di=4;} else {mybox.di=(mybox.di-1)%4;} console.log(mybox.di); mybox.style.transform=mybox.style.transform+"rotate(-90deg)"; } if(order.value=="TUN RIG"){ if(mybox.di==3){mybox.di=4} else{mybox.di=(mybox.di+1)%4;} mybox.style.transform=mybox.style.transform+"rotate(90deg)"; console.log(mybox.di); } if(order.value=="TUN BAC"){ if(mybox.di==2){mybox.di=4} else{mybox.di=(mybox.di+2)%4;} mybox.style.transform=mybox.style.transform+"rotate(180deg)"; console.log(mybox.di); } if(order.value=="GO"){ console.log(mybox.di); if(mybox.di==1){mybox.style.transform=mybox.style.transform+"translate(0,-50px)";} if(mybox.di==2){mybox.style.transform=mybox.style.transform+"translate(50px,0)";} if(mybox.di==3){mybox.style.transform=mybox.style.transform+"translate(0,50px)";} if(mybox.di==4){mybox.style.transform=mybox.style.transform+"translate(-50px,0)";} } } window.onload=function () { act.onclick=takeOrder; } </script> </body> </html> ```
大家看我的这个自定义属性为什么不能储存值
![图片说明](https://img-ask.csdn.net/upload/201704/07/1491531049_74424.png) 第221行赋值为1 然后不同状态改变它的值 240行进行判断 我在控制台检测它的值 为什么是空 源码: ``` <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>task3-3</title> <style type="text/css"> .box { position: relative; width: 500px; height: 500px; margin: 100px auto 20px auto; border: 2px solid black; } .container { width: 100%; height: 100%; font-size: 0; } .container div { box-sizing: border-box; width: 10%; height: 10%; display: inline-block; border-right: 1px solid #ccc; border-bottom: 1px solid #ccc; } .cont_row{ position: absolute; margin-top: -50px; width: 100%; height: 10%; } .cont_row div,.cont_col div{ height: 50px; width: 50px; float: left; display: inline-block; text-align: center; line-height: 50px; } .cont_col{ position: absolute; margin-top: -500px; margin-left: -50px; width: 10%; height: 100%; } form{margin-top: 30px;} #myBox{ position: absolute; top: 350px; left: 250px; box-sizing: border-box; width: 50px; height: 50px; background-color: #ec3325; border: none; transition: all 1s linear; } #myHead{ position: absolute; box-sizing: border-box; width: 50px; height: 15px; background-color:#001df5 ; border: none; } </style> </head> <body> <div class="box"> <div class="cont_row"> <div>1</div> <div>2</div> <div>3</div> <div>4</div> <div>5</div> <div>6</div> <div>7</div> <div>8</div> <div>9</div> <div>10</div> </div> <div class="container"> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div id="myBox"><div id="myHead"></div></div> </div> <div class="cont_col"> <div>1</div> <div>2</div> <div>3</div> <div>4</div> <div>5</div> <div>6</div> <div>7</div> <div>8</div> <div>9</div> <div>10</div> </div> <form action="#"> <input style="width:200px; height: 25px; " type="text" id="order"> <input type="button" value="执行" id="action"> </form> <p>指令有:GO:向蓝色边所面向的方向前进一格<br> TUN LEF:向左转(逆时针旋转90度)<br> TUN RIG:向右转(顺时针旋转90度)<br> TUN BAC:向右转(旋转180度)</p> </div> <script> //规定方向 1:上, 2:右 ,3:下, 4:左。dir属性储存方向值,方向控制go命令的走法 //旋转 注意累计角度值即可 var act = document.getElementById("action"); var order = document.getElementById("order"); var mybox = document.getElementById("myBox"); var angle=0;//角度计数 mybox.dir=1; function takeOrder() { if(order.value=="TUN LEF"){ //为了不出现负方向先进行判断 if(mybox.dir==1){mybox.dir=5;} mybox.dir=(mybox.dir-1)%4; mybox.style.transform="rotate("+(angle-90)+"deg)"; angle=-90+angle; } if(order.value=="TUN RIG"){ mybox.dir=(mybox.dir+1)%4; mybox.style.transform="rotate("+(angle+90)+"deg)"; angle=90+angle; } if(order.value=="TUN BAC"){ mybox.dir=(mybox.dir+1)%4; mybox.style.transform="rotate("+(angle+180)+"deg)"; angle=180+angle; } if(order.value=="GO"){ mybox.dir=1; if(mybox.dir==1){mybox.style.transform="translate(0,50px)";} if(mybox.dir==2){mybox.style.transform="translate(50px,0)";} if(mybox.dir==3){mybox.style.transform="translate(0,-50px)";} if(mybox.dir==4){mybox.style.transform="translate(-50px,0)";} } } window.onload=function () { act.onclick=takeOrder; } </script> </body> </html> ```
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、PDF搜索网站推荐 对于大部
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
Vue + Spring Boot 项目实战(十四):用户认证方案与完善的访问拦截
本篇文章主要讲解 token、session 等用户认证方案的区别并分析常见误区,以及如何通过前后端的配合实现完善的访问拦截,为下一步权限控制的实现打下基础。
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入  假设现有4个人
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
写在前面: 我是 扬帆向海,这个昵称来源于我的名字以及女朋友的名字。我热爱技术、热爱开源、热爱编程。技术是开源的、知识是共享的。 这博客是对自己学习的一点点总结及记录,如果您对 Java、算法 感兴趣,可以关注我的动态,我们一起学习。 用知识改变命运,让我们的家人过上更好的生活。 目录一、杨辉三角的介绍二、杨辉三角的算法思想三、代码实现1.第一种写法2.第二种写法 一、杨辉三角的介绍 百度
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
SQL-小白最佳入门sql查询一
一 说明 如果是初学者,建议去网上寻找安装Mysql的文章安装,以及使用navicat连接数据库,以后的示例基本是使用mysql数据库管理系统; 二 准备前提 需要建立一张学生表,列分别是id,名称,年龄,学生信息;本示例中文章篇幅原因SQL注释略; 建表语句: CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // dosho
漫话:什么是平衡(AVL)树?这应该是把AVL树讲的最好的文章了
这篇文章通过对话的形式,由浅入深带你读懂 AVL 树,看完让你保证理解 AVL 树的各种操作,如果觉得不错,别吝啬你的赞哦。 1、若它的左子树不为空,则左子树上所有的节点值都小于它的根节点值。 2、若它的右子树不为空,则右子树上所有的节点值均大于它的根节点值。 3、它的左右子树也分别可以充当为二叉查找树。 例如: 例如,我现在想要查找数值为14的节点。由于二叉查找树的特性,我们可...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,
程序员:我终于知道post和get的区别
IT界知名的程序员曾说:对于那些月薪三万以下,自称IT工程师的码农们,其实我们从来没有把他们归为我们IT工程师的队伍。他们虽然总是以IT工程师自居,但只是他们一厢情愿罢了。 此话一出,不知激起了多少(码农)程序员的愤怒,却又无可奈何,于是码农问程序员。 码农:你知道get和post请求到底有什么区别? 程序员:你看这篇就知道了。 码农:你月薪三万了? 程序员:嗯。 码农:你是怎么做到的? 程序员:
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU
开源并不是你认为的那些事
点击上方蓝字 关注我们开源之道导读所以 ————想要理清开源是什么?先要厘清开源不是什么,名正言顺是句中国的古代成语,概念本身的理解非常之重要。大部分生物多样性的起源,...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
      11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI 算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下
《C++ Primer》学习笔记(六):C++模块设计——函数
专栏C++学习笔记 《C++ Primer》学习笔记/习题答案 总目录 https://blog.csdn.net/TeFuirnever/article/details/100700212 —————————————————————————————————————————————————————— 《C++ Primer》习题参考答案:第6章 - C++模块设计——函数 文章目录专栏C+...
8年经验面试官详解 Java 面试秘诀
    作者 | 胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。   Java程序员准备和投递简历的实
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车? 某胡同口的煎饼摊一年能卖出多少个煎饼? 深圳有多少个产品经理? 一辆公交车里能装下多少个乒乓球? 一
so easy! 10行代码写个"狗屁不通"文章生成器
前几天,GitHub 有个开源项目特别火,只要输入标题就可以生成一篇长长的文章。背后实现代码一定很复杂吧,里面一定有很多高深莫测的机器学习等复杂算法不过,当我看了源代码之后这程序不到50
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
MySQL数据库总结
文章目录一、数据库简介二、MySQL数据类型(5.5版本)三、Sql语句(1)Sql语句简介(2)数据定义语言DDLcreate,alter,drop(3)数据操纵语言DMLupdate,insert,delete(4)数据控制语言DCLgrant,revoke(5)数据查询语言DQLselect(6)分组查询与分页查询group by,limit四、完整性约束(单表)五、多表查询六、MySQL数
20行Python代码爬取王者荣耀全英雄皮肤
引言 王者荣耀大家都玩过吧,没玩过的也应该听说过,作为时下最火的手机MOBA游戏,咳咳,好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤,而且仅仅使用20行Python代码即可完成。 准备工作 爬取皮肤本身并不难,难点在于分析,我们首先得得到皮肤图片的url地址,话不多说,我们马上来到王者荣耀的官网: 我们点击英雄资料,然后随意地选择一位英雄,接着F12打开调试台,找到英雄原皮肤的图片
中年危机,35 岁定律,见鬼去吧!
中年危机,35 岁定律,相信你都听说过,每次触及还会让你感到丝丝焦虑,毕竟时间这把杀猪刀不会放过任何一个人。中年危机或 35 岁定律是客观存在的,你迟早都会遭遇的,那你是否有信心战胜它呢? 中年危机之所以让人害怕,一则是你没有把握打赢这场遭遇战,再则中年是一个输不起的阶段。古人云:知己知彼,百战不殆。恐惧,主要源自对敌人和自己的不了解,不知道敌人的优劣势,也不清楚自己的长短板,常常以己之所短攻彼...
程序设计的5个底层逻辑,决定你能走多快
阿里妹导读:肉眼看计算机是由CPU、内存、显示器这些硬件设备组成,但大部分人从事的是软件开发工作。计算机底层原理就是连通硬件和软件的桥梁,理解计算机底层原理才能在程序设计这条路上越走越快,越走越轻松。从操作系统层面去理解高级编程语言的执行过程,会发现好多软件设计都是同一种套路,很多语言特性都依赖于底层机制,今天董鹏为你一一揭秘。 结合 CPU 理解一行 Java 代码是怎么执行的 根据冯·诺...
张小龙-年薪近3亿的微信之父,他是如何做到的?
张小龙生于湖南邵东魏家桥镇, 家庭主要特点:穷。 不仅自己穷,亲戚也都很穷,可以说穷以类聚。爷爷做过铜匠,总的来说,标准的劳动阶级出身。 家有兄弟两人, 一个小龙,一个小虎。 小虎好动,与邻里打成一片, 小龙好静,喜好读书。 “文静的像个妹子。”张小龙的表哥如是说。 穷文富武,做个读书郎是个不错的选择。 87年至94年, 华中科技大学本硕连读。 本科就读电信系, 不喜欢上课
阿里靠什么武功秘籍渡过“双十一“的天量冲击
双十一大概会产生多大的数据量呢,可能大家没概念,举个例子央视拍了这么多年电视新闻节目,几十年下来他存了大概80P的数据。而今年双11一天,阿里要处理970P的数据,做为一个IT人,笔者认为今年”双十一“阿里最大的技术看点有有以下两个: 阿里的数据库,也就是刚刚拿下TPC冠军的OcceanBase,处理峰值也达到了骇人听闻的6100万次/秒, 阿里核心系统百分百上云了。 如果把信息系统比做一个武
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
iOS Bug 太多,苹果终于坐不住了!
开源的 Android 和闭源的 iOS,作为用户的你,更偏向哪一个呢? 整理 | 屠敏 出品 | CSDN(ID:CSDNnews) 毋庸置疑,当前移动设备操作系统市场中,Android 和 iOS 作为两大阵营,在相互竞争的同时不断演进。不过一直以来,开源的 Android 吸引了无数的手机厂商涌入其中,为其生态带来了百花齐放的盛景,但和神秘且闭源的 iOS 系统相比,不少网友...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
Zookeeper的基本命令大全
1、列出节点 ls path ls -s path //包含该节点的详细信息,如子节点总数等 2、查看节点状态 stat path cZxid = 0x14f //创建节点的ID ctime = Thu Nov 07 01:02:53 CST 2019 //节点的创建时间 mZxid = 0x14f //修改节点ID mtime = Thu Nov 07 01:02:53 CST 2019 ...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
(经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
今年正式步入了大四,离毕业也只剩半年多的时间,回想一下大学四年,感觉自己走了不少弯路,今天就来分享一下自己大学的学习经历,也希望其他人能不要走我走错的路。 (一)初进校园 刚进入大学的时候自己完全就相信了高中老师的话:“进入大学你们就轻松了”。因此在大一的时候自己学习的激情早就被抛地一干二净,每天不是在寝室里玩游戏就是出门游玩,不过好在自己大学时买的第一台笔记本性能并不是很好,也没让我彻底沉...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
听说了吗?阿里双11作战室竟1根网线都没有
双11不光是购物狂欢节,更是对技术的一次“大考”,对于阿里巴巴企业内部运营的基础保障技术而言,亦是如此。 回溯双11历史,这背后也经历过“小米加步枪”的阶段:作战室从随处是网线,交换机放地上的“一地狼藉”;到如今媲美5G的wifi网速,到现场却看不到一根网线;从当年使用商用AP(无线路由器),让光明顶双11当天断网一分钟,到全部使用阿里自研AP……阿里巴巴企业智能事业部工程师们提供的基础保障...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
Mybatis学习(2)史上最全的 自定义mybatis
这篇博客介绍了一下手写 mybatis 的全部过程,并且有完整的代码实现。
相关热词 c# clr dll c# 如何orm c# 固定大小的字符数组 c#框架设计 c# 删除数据库 c# 中文文字 图片转 c# 成员属性 接口 c#如何将程序封装 16进制负数转换 c# c#练手项目
立即提问