sql单表语句查询怎么搞??/

需求:
lcjd是环节 gdh是工单 clr是处理人
每个环节每个人的统计
每个人处理工单数的统计

2个回答

第一个,按环节和人两个字段分组后后统计:select lcjd ,clr ,count(*) as total from xxx group by lcjd ,clr
第二个,按工单和人两个字段分组后后统计:select gdh ,clr ,count(*) as total from xxx group by gdh ,clr

qq_42445502
qq_42445502 感谢。
8 个月之前 回复
dabocaiqq
请多多姿瓷阿木小镇 这个可以说,非常正确。
8 个月之前 回复

#每个环节每个人的统计
select count(clr),lcjd from test GROUP BY lcjd

#每个人处理工单数的统计
select count(gdh) 工单数,clr from test GROUP BY clr;

qq_42445502
qq_42445502 感谢。
8 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
sql语句 多条件查询求解答
看了半天子条件查询感觉搞不定 现在有一张学生表,里面有字段 学生编号,学生名字,成绩,试卷 请问如何能够查询到 所有试卷不重复,每张试卷成绩最好学生的信息
SQL语句:A表中的字段值既不存在B表中又不存在C表中
SELECT * FROM A WHERE NOT EXISTS ( SELECT * FROM B WHERE dialnumber = A.用户号码 ); 这是原来两张表的,现在就是三张表,这个SQL语句怎么写,搞些各位大神
求一条sql语句 sqlserver数据库
刷卡表,有ID,刷卡时间、时间等并和用户表形成多对一关系,使用的是sqlserver。 我要取得是“昨天,每个用户的最大刷卡时间和最小刷卡时间的刷卡数据”。 我的SQL不是很好,昨天、最大刷卡时间和最小都能搞出来,但是加个每个用户就乱了; 因为每个用户都可能会有多条刷卡数据. 。。。求解
复杂sql,请大神解析,没办法理解以下这条sql语句。
sql在以下网址第六题: http://www.cnblogs.com/netserver/p/4518995.html (里面有建表语句) select a.* from tb a where 2 > (select count(*) from tb where name = a.name and val > a.val ) order by a.name,a.val ; 想了半天,我始终无法理解这条语句是怎么做到筛选出最大的2条val值的,并且如果做到了分组了的呢?都没见到有group by这条语句。这条嵌套查询究竟做了什么?有大神能详细解释下吗,感谢。一有这种和查询的表直接嵌套的我都有点懵 ,目前还没用过。。。常用的都是外连接,内连接,自连接,多表连接这些都能理解。因为理解这些只需要搞清楚执行顺序,还有一些基础知识就差不多了。像上面这种真的不知道在干啥啊?
关于sql语句的问题
<p>有下面两个表A B</p> <p>问题:写一句sql语句,把表B的同一个Id的Score求和并填充到表A相应Id中的totalScore。</p> <p>表A:                               </p> <table style="width: 111px; height: 104px;" border="1"><tbody> <tr> <td>id</td> <td>totalScore</td> </tr> <tr> <td>1</td> <td> </td> </tr> <tr> <td>2</td> <td> </td> </tr> <tr> <td>3</td> <td> </td> </tr> <tr> <td>4</td> <td> </td> </tr> </tbody></table> <p>  </p> <table style="width: 104px; height: 95px;" border="1" align="left"><tbody> <tr> <td>id</td> <td>score</td> </tr> <tr> <td>1</td> <td>10</td> </tr> <tr> <td>1</td> <td>12</td> </tr> <tr> <td>2</td> <td>23</td> </tr> <tr> <td>2</td> <td>43</td> </tr> <tr> <td>3</td> <td>24</td> </tr> <tr> <td>3</td> <td>43</td> </tr> <tr> <td>3</td> <td>45</td> </tr> <tr> <td>4</td> <td>56</td> </tr> </tbody></table> <p>表B:</p><br /><strong>问题补充:</strong><br />首先谢谢你的帮助,但是有一个细节,表A已经存在,并且id已经被填充,你写的sql语句,是表a中id和totalScore都没有数据时可以成立。听有的人说好像要用update来更新。但我怎么都搞不出来。 <br />
sql语句根据datetime类型排序优化
select id,date_release,productname,linkman from requires where validate='1' and bigclass=20 order by date_release desc limit 0,15 sql语句如上,因为用datetime数据类型(date_release字段)排序导致查询变慢,有木有大神指教下怎么搞?
MFC中 SQL语句格式的的问题
(1)下面是程序中的SQL语句: mSqlStr = "INSERT INTO BORROW (READER_ID, BOOK_ID, BORROW_DATE, B_CLERK_ID) VALUES('"; // mSqlStr = "INSERT INTO BORROW (READER_ID, BOOK_ID, B_CLERK_ID) VALUES('"; mSqlStr = mSqlStr + m_strReaderID; mSqlStr = mSqlStr + "','"; mSqlStr = mSqlStr + m_strBookID; mSqlStr = mSqlStr + "','"; mSqlStr = mSqlStr + "', m_BORROW_DATE,'"; //获取系统时间SYSDATE mSqlStr = mSqlStr + "','"; mSqlStr = mSqlStr + m_strUserID; mSqlStr = mSqlStr + "')"; ![图片说明](https://img-ask.csdn.net/upload/201507/04/1435977807_753071.png) (2)下面是数据库中对应表的结构: ![图片说明](https://img-ask.csdn.net/upload/201507/04/1435977854_659016.png) (3)下面是程序运行时编译器的错误提示: ![图片说明](https://img-ask.csdn.net/upload/201507/04/1435978126_183775.png) (4)谢谢大家了,帮帮忙吧,我是初学者,MFC里面SQL语句搞复杂了就看不懂,简单的还是懂,一复杂看起来就眼睛花了
java 日志打印sql语句
用的mybatis.xml和log4j.properties配置日志,控制台能打印sql语句我想在日志文件打印出来,做了半天搞不定求大神帮忙
使用springjdbc提示无效的sql语句
t-sql语句拼接的方式也用了,预处理的方式也用了,但是还是抛出如下异常(在Oracle数据端能查到插入的信息): 在控制台打印的sql语句如下: insert into jzxx(dw_id, jz_type, jz_person, jz_money, jz_date, jz_remark) values (2,'个人','张三',88886,sysdate,'私人') 错误信息如下: HTTP Status 500 - StatementCallback; bad SQL grammar [insert into jzxx(dw_id, jz_type, jz_person, jz_money, jz_date, jz_remark) values (2,'个人','张三',88886,sysdate,'私人')]; nested exception is java.sql.SQLException: ORA-00900: 无效 SQL 语句 type Exception report message StatementCallback; bad SQL grammar [insert into jzxx(dw_id, jz_type, jz_person, jz_money, jz_date, jz_remark) values (2,'个人','张三',88886,sysdate,'私人')]; nested exception is java.sql.SQLException: ORA-00900: 无效 SQL 语句 description The server encountered an internal error that prevented it from fulfilling this request. exception org.springframework.jdbc.BadSqlGrammarException: StatementCallback; bad SQL grammar [insert into jzxx(dw_id, jz_type, jz_person, jz_money, jz_date, jz_remark) values (2,'个人','张三',88886,sysdate,'私人')]; nested exception is java.sql.SQLException: ORA-00900: 无效 SQL 语句 java 代码如下: public class IJzxxDaoImpl implements IJzxxDao { JdbcTemplate temp = new JdbcTemplate(DBUtil.getDs()); @Override public int insertJzxx(Jzxx jz) { Integer dw_id = jz.getDw_id(); String jz_type = jz.getJz_type(); String jz_person = jz.getJz_person(); Integer jz_money = jz.getJz_money(); String jz_remark = jz.getJz_remark(); //String sql = "insert into jzxx(dw_id, jz_type, jz_person, jz_money, jz_date, jz_remark) values(?,?,?,?,sysdate,?)"; String sql = "insert into jzxx(dw_id, jz_type, jz_person, jz_money, jz_date, jz_remark) values ("+dw_id+",'"+jz_type+"','"+jz_person+"',"+jz_money+",sysdate,'"+jz_remark+"')"; System.out.println(sql); return temp.queryForInt(sql); } 各种方法试过了还是搞不定,请大家帮帮忙,谢谢!
Oracle数据库中怎样创建数据库和数据表,还有搞半天了我没找到sql语句在哪里写?
就是类似于sql server中的数据表,然后可以增删改查,我下载的Oracle打开就是一个网页,里面一大堆东西,我也不知道是干嘛用的,只想知道,怎样创建表格,在百度上搜了一些资料,说是创建表空间,可是我创建表空间后什么都没有呀,很晕
从500万条数据中查询,求优化一条SQL语句
表结构如下,里面有500W数据。我没有权限修改这个表,所以请大家给我优化下SQL查询 [code="sql"]CREATE TABLE IF NOT EXISTS `jdp_tb_trade` ( `tid` bigint(20) NOT NULL, `status` varchar(64) DEFAULT NULL, `type` varchar(64) DEFAULT NULL, `seller_nick` varchar(32) DEFAULT NULL, `buyer_nick` varchar(32) DEFAULT NULL, `created` datetime DEFAULT NULL, `modified` datetime DEFAULT NULL, `jdp_hashcode` varchar(128) DEFAULT NULL, `jdp_response` mediumtext, `jdp_created` datetime DEFAULT NULL, `jdp_modified` datetime DEFAULT NULL, PRIMARY KEY (`tid`), KEY `ind_jdp_tb_trade_seller_nick_jdp_modified` (`seller_nick`,`jdp_modified`), KEY `ind_jdp_tb_trade_jdp_modified` (`jdp_modified`), KEY `ind_jdp_tb_trade_seller_nick_modified` (`seller_nick`,`modified`), KEY `ind_jdp_tb_trade_modified` (`modified`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;[/code] 符合以下条件的有3W条数据 [code="sql"]SELECT COUNT(*) AS tp_count FROM `jdp_tb_trade` WHERE ( `seller_nick` IN ('李心','zhixian50','陈鹏','雪儿','稀饭','婷婷','七七') ) AND ( (`jdp_modified` > '2007-11-30 09:52:39') AND (`jdp_modified` <= '2014-04-21 22:31:13') ) LIMIT 1[/code] 我要分页查询出这3W条数据,由于MYSQL分页越往后查询越慢,所以我用了关联查询。该查询在前面2页需要3到4分钟才能返回结果。后面的每页4秒左右就返回了。实在搞不明白为什么。麻烦大家帮忙优化下。每页必须要在10秒内完成。 [code="sql"]SELECT t1.jdp_modified,t1.jdp_response FROM jdp_tb_trade t1, ( SELECT `tid` FROM `jdp_tb_trade` WHERE ( `seller_nick` IN ('李心','zhixian50','陈鹏','雪儿','稀饭','婷婷','七七') ) AND ( (`jdp_modified` > '2007-11-30 09:52:39') AND (`jdp_modified` <= '2014-04-21 22:31:13') ) ORDER BY jdp_modified desc LIMIT 0,200 ) t2 WHERE t1.tid=t2.tid[/code]
oracle 获取上一条insert语句的id 插入到当前insert语句中
[size=large]当我执行以下一条sql语句 insert into TEST_INFO (ID, NAME, PARENTID) values (SEQ_TEST_INFO.NEXTVAL, '老爸', 1001); 获取该语句的id时,,假设为1002,那么以下三条sql语句的父节点都为1002,即 insert into TEST_INFO (ID, NAME, PARENTID) values (SEQ_TEST_INFO.NEXTVAL, '儿子1', 1002); insert into TEST_INFO (ID, NAME, PARENTID) values (SEQ_TEST_INFO.NEXTVAL, '儿子2', 1002); insert into TEST_INFO (ID, NAME, PARENTID) values (SEQ_TEST_INFO.NEXTVAL, '儿子3', 1002); --------------------------------------------------------------------------------------------- 现在我想用sql语句直接来写上面那三条insert语句,而不是先获得1002后 再执行 请问 怎么搞啊 。。。。。。。。。。。。。。 谢谢![/size]
SQL SERVER 2017 字体和颜色设置无效
问题描述:SQL 2017 所有查询分析器页面上的语句字体与颜色无法设置 环境说明: 1>:windows 10 64位 企业版 2>:安装版本为Developer 3>:第一次是从MSDN(我告诉你)下载的光盘镜像(cn_sql_server_2017_developer_x64_dvd_11296175)1.64 GB 4>:第二次是从同事拷贝的在线安装包,在线下载安装(SQLServer2017-SSEI-Eval)4.48MB 曾尝试过处理对策: 1>:重装SQL SERVER 4次 2>:重装SSMS工具2次 3>:第一次用本地镜像安装,第二次用在线安装包安装(我同事用在线安装包安装没问题) 特别说明: 工具→选项→显示其设置(我电脑只有区区几项)而我同事所安装有很长一串。 每天看着密密麻麻的小蚂蚁字体,本来不是近视的我,两个月后估计也成近视,看存储过程不仅搞成近视估计快整成精神病!求大神指导如何处理,谢谢! ![工具-选项](https://img-ask.csdn.net/upload/201806/23/1529736009_992320.png) ![显示其设置](https://img-ask.csdn.net/upload/201806/23/1529736052_708121.png) ![字体设置24号,字体依旧小如蚂蚁](https://img-ask.csdn.net/upload/201806/23/1529736187_933429.png)
MS SQL如何在执行过程中知道有多少用户变量.
在一些语句对SQL的表进行增删改操作时,我想通过触发器把系统和用户操作的变量名称搞个清单列出来.新手求助,谢谢!
基于servlet jsp页面查询条件回显及分页
在公司之前的老项目上完善新功能,纯servlet jsp页面, 做条件查询时不能回显查询条件,我在后台把前台数据接收后存在session中,然后从jsp页面直接取,但是结果每次回显的是我上一次的查询,也就是我查询"2"的时候,回显的是"1",大神给看看是 另外就是目前条件查询后点击下一页,又把所有的数据查出来了.![图片说明](https://img-ask.csdn.net/upload/201905/11/1557566762_480988.png) action 是执行当前页面,页面中有个方法查询数据库![图片说明](https://img-ask.csdn.net/upload/201905/11/1557566978_215553.png) ![图片说明](https://img-ask.csdn.net/upload/201905/11/1557567021_9586.png)![图片说明](https://img-ask.csdn.net/upload/201905/11/1557567095_290470.png) 最后一张图是后台代码.搞了一下午,我感觉条件查询后分页就办法实现,不知道大佬们有什么解决思路 后台没有按照dao service action分开写,所有的业务都写在一个class里,包括sql语句
在Dao层拼接语句报错,但是在数据库运行没有问题
在Dao层拼接语句报错——数据库:sqlserver2008R2,whth pro as(select...很长就不写了), 这个跑断点测试一切正常,复制到数据库可以运行,但是在Dao层用父类封装的方法就会报错, 报错抛出的异常显示的语句被改变了,也搞不懂什么情况
PreparedStatement 预编译原理
<p><strong><span>preparedStatement 有三大优点:</span></strong></p> <p><span><span>一.代码的可读性和可维护性. </span></span></p> <p><span><span>二.PreparedStatement尽最大可能提高性能. </span></span></p> <p><span><span>三.最重要的一点是极大地提高了安全性. </span></span></p> <p> </p> <p><span><span>其中一和三的确很易理解。 关于性能的提高也是最有价值的这点, 我对其原理还有些质疑。 </span></span></p> <p> </p> <p> </p> <div class="quote_title">网上一:</div> <div class="quote_div">SQL 语句被预编译并且存储在 PreparedStatement 对象中,其后可以使用该对象高效地多次执行该语句。 <br> </div> <p><span style="color: #ff0000;">问题:</span>预编译在JDBC中完成的?还是数据库中?即便存在preparedStatement中,如果这个preparedStatement 对象不被缓存起来,其后又如何重复使用,多次执行? (一些webserver会缓存preparedStatement)</p> <p>我想关于其性能的提高主要得需要数据库的支持。 </p> <div class="quote_title">oracle 性能优化 写道</div> <div class="quote_div">共享SQL语句 <br>  为了不重复解析相同的SQL语句,在第一次解析之后, ORACLE将SQL语句存放在内存中。 <br>可惜的是ORACLE只对简单的表提供高速缓冲(cache buffering) ,这个功能并不适用于多表连接查询。 <br> </div> <p><span><span><span><span><span><span style="font-size: x-small;"><span style="color: #008000;">个人理解:</span>预编译是利用数据库的SQL共享来实现的,因为当使用preparedStatement 的时候,尽管参数不同,但是在语句中用?来替代。 因此很多语句就完全相同。(这个道理和J2EE的server缓存preparedStatement 的道理应该是一样的)</span></span></span></span></span></span></p> <p> </p> <p><span><span><span><span><span><span><span style="font-size: x-small;"><span style="color: #ff0000;">问题:</span>但是如果是这样的话,那么oracle的多表查询岂不是并无预编译效果?</span></span></span></span></span></span></span></p> <p> </p> <p><span><span><span><span><span><span style="font-size: x-small;"><span><span><span><span><span><span><span style="color: #ff0000;">问题:</span></span></span></span></span></span></span>关于缓存:是否根据创建preparedStatement的语句来做为Key来map的?例如以下:是否检查匹配insert into tb_name (col1,col2,col2,col4) values (?,?,?,?)来确定是否用已经有的执行路径来执行? </span></span></span></span></span></span></p> <p><span><span><span><span style="font-size: x-small;"><span>perstmt = con.prepareStatement("insert into tb_name (col1,col2,col2,col4) values (?,?,?,?)"); </span></span></span></span></span></p> <p><span> </span></p> <p><span><strong>以下几篇从网络上搜索到的三篇文章:</strong></span></p> <p><span> </span></p> <div class="quote_title"><span>CSDN 写道</span></div> <div class="quote_div"><span>一.代码的可读性和可维护性. <br>虽然用PreparedStatement来代替Statement会使代码多出几行,但这样的代码无论从可读性还是可维护性上来说.都比直接用Statement的代码高很多档次: <br><br>stmt.executeUpdate("insert into tb_name (col1,col2,col2,col4) values ('"+var1+"','"+var2+"',"+var3+",'"+var4+"')"); <br><br>perstmt = con.prepareStatement("insert into tb_name (col1,col2,col2,col4) values (?,?,?,?)"); <br>perstmt.setString(1,var1); <br>perstmt.setString(2,var2); <br>perstmt.setString(3,var3); <br>perstmt.setString(4,var4); <br>perstmt.executeUpdate(); <br><br>不用我多说,对于第一种方法.别说其他人去读你的代码,就是你自己过一段时间再去读,都会觉得伤心. <br><br>二.PreparedStatement尽最大可能提高性能. <br>每一种数据库都会尽最大努力对预编译语句提供最大的性能优化.因为预编译语句有可能被重复调用.所以语句在被DB的编译器编译后的执行代码被缓存下来,那么下次调用时只要是相同的预编译语句就不需要编译,只要将参数直接传入编译过的语句执行代码中(相当于一个涵数)就会得到执行.这并不是说只有一个Connection中多次执行的预编译语句被缓存,而是<span style="color: #0000ff;">对于整个DB中,只要预编译的语句语法和缓存中匹配.那么在任何时候就可以不需要再次编译而可以直接执行.而statement的语句中,即使是相同一操作,而由于每次操作的数据不同所以使整个语句相匹配的机会极小,几乎不太可能匹配.</span>比如: <br>insert into tb_name (col1,col2) values ('11','22'); <br>insert into tb_name (col1,col2) values ('11','23'); <br>即使是相同操作但因为数据内容不一样,所以整个个语句本身不能匹配,没有缓存语句的意义.事实是没有数据库会对普通语句编译后的执行代码缓存.这样每执行一次都要对传入的语句编译一次. <br><br>当然并不是所以预编译语句都一定会被缓存,数据库本身会用一种策略,比如使用频度等因素来决定什么时候不再缓存已有的预编译结果.以保存有更多的空间存储新的预编译语句. <br><br>三.最重要的一点是极大地提高了安全性. <br><br>即使到目前为止,仍有一些人连基本的恶义SQL语法都不知道. <br>String sql = "select * from tb_name where name= '"+varname+"' and passwd='"+varpasswd+"'"; <br>如果我们把[' or '1' = '1]作为varpasswd传入进来.用户名随意,看看会成为什么? <br><br>select * from tb_name = '随意' and passwd = '' or '1' = '1'; <br>因为'1'='1'肯定成立,所以可以任何通过验证.更有甚者: <br>把[';drop table tb_name;]作为varpasswd传入进来,则: <br>select * from tb_name = '随意' and passwd = '';drop table tb_name;有些数据库是不会让你成功的,但也有很多数据库就可以使这些语句得到执行. <br><br>而如果你使用预编译语句.你传入的任何内容就不会和原来的语句发生任何匹配的关系.(前提是数据库本身支持预编译,但上前可能没有什么服务端数据库不支持编译了,只有少数的桌面数据库,就是直接文件访问的那些)只要全使用预编译语句,你就用不着对传入的数据做任何过虑.而如果使用普通的statement,有可能要对drop,;等做费尽心机的判断和过虑. </span></div> <p><span> </span></p> <p> </p> <div class="quote_title"><span>论坛 写道</span></div> <div class="quote_div"> <span><span style="font-size: x-small;">1,执行效率:Statement 采取直接编译 SQL 语句的方式,扔给数据库去执行,而 </span></span><span><span><span style="font-size: x-small;"><span style="color: #0000ff;">PreparedStatement 则先将 SQL 语句预编译</span>一遍,再填充参数,这样效率会高一些。JDK 文档说:SQL 语句被预编译并且存储在 PreparedStatement 对象中,其后可以使用该对象高效地多次执行该语句。 <br><br>2,代码可读性:Statement 中 SQL 语句中需要 Java 中的变量,加就得进行字符串的运算,还需要考虑一些引号、单引号的问题,参数变量越多,代码就越难看,而且会被单引号、双引号搞疯掉;而 PreparedStatement,则不需要这样,参数可以采用“?”占位符代替,接下来再进行参数的填充,这样利于代码的可读性,并且符合面向对象的思想。 <br><br>3,安全性:Statement 由于可能需要采取字符串与变量的拼接,很容易进行 SQL 注入攻击,而 PreparedStatement 由于是预 <br>编译,再填充参数的,不存在 SQL 注入问题。 <br></span></span></span> </div> <p><span> </span></p> <div class="quote_title"><span>Oracle 优化 写道</span></div> <div class="quote_div"><span>3. 共享SQL语句 <br>  为了不重复解析相同的SQL语句,在第一次解析之后, ORACLE将SQL语句存放在内存中。这块位于系统全局区域SGA(system global area)的共享池(shared buffer pool)中的内存可以被所有的数据库用户共享。 因此,当你执行一个SQL语句(有时被称为一个游标)时,如果它和之前的执行过的语句完全相同, ORACLE就能很快获得已经被解析的语句以及最好的执行路径。 ORACLE的这个功能大大地提高了SQL的执行性能并节省了内存的使用。 <br><br>  可惜的是ORACLE只对简单的表提供高速缓冲(cache buffering) ,这个功能并不适用于多表连接查询。 </span></div><br /><strong>问题补充:</strong><br />感谢geeksun的回答,我的理解是: <br />问题1, PreparedStatement是jdbc 驱动包里的一个类,并不是说存储在jdbc中。 <br />问题2, 我认为多表查询不支持预编这是不可能的。 <br />问题3, 我想这样提问可能更好一些。 <br />java 方法如下: <br />protected boolean updateSalary(Connection conn,BigDecimal x,String ID) throws SQLException{ <br /> PreparedStatement pstmt = null; <br /> try { <br /> pstmt = conn.prepareStatement("UPDATE EMPLOYEES SET SALARY = ? WHERE ID = ?"); <br /> pstmt.setBigDecimal(1, x); <br /> pstmt.setString(2, ID); <br /> return true; <br /> } finally{ <br /> if (pstmt!=null){ <br /> pstmt.close(); <br /> } <br /> } <br /> <br /> } <br /> <br /> <br />第一次调用以后,是否会缓存PreparedStatement, 这个在用weblogic这种server的时候是可以肯定的。因为从数据源的来connection是一个包装类,不是jdbc驱动的connection,而用connection来创建的PreparedStatement也是封装类。因此尽管pstmt.close().但是实际被封装的PreparedStatement并未关闭。 <br />但是是第二次调用这个方法,会重新conn.prepareStatement, 这个时候我想应该是根据语句来作为key来寻找缓存的preparedStatement,但是尽管取到缓存。 如果没有Database的配合,效率也很难提高多少。 <br /><strong>问题补充:</strong><br />谢谢geeksun的帮忙,Sql的共享我想肯定是支持多表的。 至于高速缓存应该讲的是结果的缓存。 <br />但是你对PreparedStatement的观点我认为是不对的。 因为这个对象肯定是在WebServer端的, 不可能跑到数据库那端。K-V对应的K值应该就是创建这个对象的那条语句,只是需要一个精通人士的肯定。
postgresql求比率问题
我有一个比较大的数据库,7个表,每个表里面有(100个字段,700W条数据)左右,但不全部都是有效数据。现在的任务是计算每一列的填充率(数据非空),我现在会的方法只有一个,就是把非空的个数统计出来,让后除总个数,再计算百分比。但是这样SQL语句的量特别大,而且没有一点技巧性。我的想法是先用SQL语句把不合格的字段名统计出来,再在统计后的字段上面计算,然后用简洁的SQL语句把填充率直接显示到查询结果。但是我现在第一步(统计不合格字段名)都还知道怎么搞,求大神支招,感激不尽!
有大佬会做这个题目吗,顺便带一下思路,我今天笔试做这个感觉搞得很迷
题1.1、删除表的重复记录 如果记录完全相同才算重复记录,请书写此种情况下的SQL语句; 如果有id主键(数字,自增1模式),请书写此种情况下的SQL语句。
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
程序员,职场上请远离这种人!
对有些职场人来讲,甩锅就是一种生存手段。01.从大学打篮球说起上大学的时候喜欢打篮球,然后我又特别喜欢抢篮板,经常是跳起来的时候没事,落下来的时候偶尔会踩到别人的脚上,于...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch, ...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
一个读研让我损失了一百万的真实故事
关注我!只要10分钟,包你学会数据分析 毕业后,应该就业还是考研? 我刚出国留学那会儿,就惊讶的发现,外国local95%都不会选择读研 他们说,硕士学费很贵,时间宝贵,老板不认,所以很费 当几乎所有人都是本科学历时,硕士学历反而像个异类 在老板眼里,三年硕士远远不如3年的工作经验实用 他们甚至专门为拒绝高学历者发明了一个词,叫overoccupie...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给袈...
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
压测学习总结(1)——高并发性能指标:QPS、TPS、RT、吞吐量详解
一、QPS,每秒查询 QPS:Queries Per Second意思是“每秒查询率”,是一台服务器每秒能够相应的查询次数,是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准。互联网中,作为域名系统服务器的机器的性能经常用每秒查询率来衡量。 二、TPS,每秒事务 TPS:是TransactionsPerSecond的缩写,也就是事务数/秒。它是软件测试结果的测量单位。一个事务是指一...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
【图解算法面试】记一次面试:说说游戏中的敏感词过滤是如何实现的?
版权声明:本文为苦逼的码农原创。未经同意禁止任何形式转载,特别是那些复制粘贴到别的平台的,否则,必定追究。欢迎大家多多转发,谢谢。 小秋今天去面试了,面试官问了一个与敏感词过滤算法相关的问题,然而小秋对敏感词过滤算法一点也没听说过。于是,有了下下事情的发生… 面试官开怼 面试官:玩过王者荣耀吧?了解过敏感词过滤吗?,例如在游戏里,如果我们发送“你在干嘛?麻痹演员啊你?”,由于“麻痹”是一个敏感词,...
GitHub 标星 1.6w+,我发现了一个宝藏项目,作为编程新手有福了!
大家好,我是 Rocky0429,一个最近老在 GitHub 上闲逛的蒟蒻… 特别惭愧的是,虽然我很早就知道 GitHub,但是学会逛 GitHub 的时间特别晚。当时一方面是因为菜,看着这种全是英文的东西难受,不知道该怎么去玩,另一方面是一直在搞 ACM,没有做一些工程类的项目,所以想当然的以为和 GitHub 也没什么关系(当然这种想法是错误的)。 后来自己花了一个星期看完了 Pyt...
杭漂程序员2019的心路历程,还不起助学贷款,交不起房租,披荆斩棘终雨过天晴
一个杭漂2019的心酸历程,一路披荆斩棘终于还是雨过天晴。
我采访了同事,让他掏出了每天都会浏览的干货网站
前言只有光头才能变强。文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y在周六的晚上,我日常去到公司写文章。想写...
相关热词 c#判断数字不得为负数 c#帧和帧协议 c#算偏移值 c# 在枚举中 c#6 字符串 插值 c#程序中的占位符标签 c#监听数组变化 c# vlc c#索引实现 c# 局域网广播通信
立即提问