當前位置:首頁 » 編程語言 » javasql面試題

javasql面試題

發布時間: 2023-10-31 18:12:26

java面試題求助

第一個問題:select a.姓名,a.薪水,b.薪水級別,count(b.Salclass) from (select * from 員工表 where empid=1) a left join 薪水級別表 b on a.EmpSal = b.MaxSal
樓主可以試一下。我提供點思路。平均工資我沒想明白。一個人的平均工資怎麼求。。。

第二題就是一個設計模式只要滿足它的要求就行比如:
public class Singleton {
private Singleton(){}
//在自己內部定義自己一個實例,是不是很奇怪?
//注意這是private 只供內部調用
private static Singleton instance = new Singleton();
//這里提供了一個供外部訪問本class的靜態方法,可以直接訪問
public static Singleton getInstance() {
return instance;
}
}

❷ java,oracle面試題,如下,sql怎麼寫

如題我先進行分析:

  1. 第一句話中按月找出平均 填寫時間大於3天的人員信息 :

    那麼可用理解為 根據月份查找 員工平均延遲填寫日期大於3天的 人員信息。

  2. 第二句話一個人員的日誌填寫日期有多條則取最早的一條,如果有一天未填寫,則取系統當前時間,不含小時。

    以上這句話需要注意兩點 第一點,取最早的一條此處需要用到ROW_NUMBER() OVER() 以及未填寫 則取系統當前時間 不含小時 那麼取值格式應為yyyy-mm-dd此處需要處理格式。

根據以上分析提供如下SQL: 註:(以下SQL已ORACLE為例)

--創建臨時表存儲數據
withemp_logas(
select1asempno,'張一'asempname,'工作內容1'asworkcontent,date'2017-03-20'asbegdate,date'2017-03-23'asentrydate,1asnumfromal
unionall
select1asempno,'張一'asempname,'工作內容2'asworkcontent,date'2017-03-20'asbegdate,date'2017-03-23'asentrydate,2asnumfromal
unionall
select1asempno,'張一'asempname,'工作內容3'asworkcontent,date'2017-03-20'asbegdate,date'2017-03-24'asentrydate,5asnumfromal
unionall
select1asempno,'張一'asempname,'工作內容1'asworkcontent,date'2017-03-24'asbegdate,date'2017-03-30'asentrydate,8asnumfromal
unionall
select2asempno,'張二'asempname,'工作內容21'asworkcontent,date'2017-03-20'asbegdate,date'2017-03-30'asentrydate,8asnumfromal
unionall
select2asempno,'張二'asempname,'工作內容22'asworkcontent,date'2017-03-25'asbegdate,date'2017-03-28'asentrydate,8asnumfromal
unionall
select3asempno,'張三'asempname,'工作內容31'asworkcontent,date'2017-03-20'asbegdate,nullasentrydate,nullasnumfromal
unionall
select3asempno,'張三'asempname,'工作內容32'asworkcontent,date'2017-03-20'asbegdate,nullasentrydate,nullasnumfromal
unionall
select4asempno,'張四'asempname,'工作內容42'asworkcontent,date'2017-03-25'asbegdate,date'2017-03-28'asentrydate,8asnumfromal
)
select*from(
selectempno,empname,sum(num)num,sum(yanci)/count(empno)pingjunyanci--獲取人員當月總延遲數除去當月人員每日的打開數計算出當月每天的平均延遲天數
from(selectROW_NUMBER()OVER(PARTITIONBYe.empno,e.begdateORDERBYe.empno,e.begdate)ASRN,--排序獲取當天有多條記錄並在後面條件中獲取第一條
e.empno,e.empname,
e.workcontent,e.begdate,
e.entrydate,
e.num,
(nvl(e.entrydate,to_date(to_char(sysdate,'yyyy-mm-dd'),'yyyy-mm-dd'))-begdate)asyanci--判斷如果沒有填寫結束日期那麼以系統當前日期進行運算延遲日期
fromemp_loge)e1
wheree1.rn=1--獲取第一條
andto_char(begdate,'yyyy-mm')='2017-03'--可用的月份條件
groupbyempno,empname,numorderbyempno--根據人員工號、人員姓名分組匯總
)e2wheree2.pingjunyanci>3;

--分析不易忘認真閱讀後採納,有其他問題請追問我。

❸ java 面試題

1,C
只有C選項中的三個類全是用final關鍵字修飾
final修飾類,表示類不能被繼承,修飾方法表示方法不可覆蓋(重寫),修飾屬性表示不可改變(常量)

2,A
此類完全由在 collection 上進行操作或返回 collection 的靜態方法組成

3,看不到類

4,B
A應該改為INSERT INTO TABLE_USER(UserID,Name) VALUES('001','xxx');
C應該改為SELECT * FROM TABLE_USER WHERE UserID = '001';

❹ 上海久雅Java面試題

久雅科技面試題 【JAVA軟體工程師】
1、基本集合類有哪些,各自的特點?
集合類型主要有3種:set(集)、list(列表)和map(映射)。
List 關心的是索引,與其他集合相比,List特有的就是和索引相關的一些方法:get(int index) 、 add(int index,Object o) 、 indexOf(Object o) 。
Set關心唯一性,它不允許重復。
Map關心的是唯一的標識符。他將唯一的鍵映射到某個元素。當然鍵和值都是對象。
2、下面代碼的運行結果:(A)
public class Foo {
public static void main(String[] args) {
String s;
String.out.println("s="+s);
}
}
A.由於String s沒有初始化,代碼不能編譯通過 B.代碼得到編譯,輸出結果為"s="
C.代碼得到編譯,並輸出"s=null" D.代碼得到編譯,但捕獲到NullPointException異常
3、請說明equal和==的區別。
int i=1;int j=1;
在一個判斷條件中使用i==j是否為true?
如果i和j是integer呢?
==操作比較的是兩個變數的值是否相等,對於引用型變數表示的是兩個變數在堆中存儲的地址是否相同,即棧中的內容是否相同。
equals操作表示的兩個變數是否是對同一個對象的引用,即堆中的內容是否相同。
==比較的是2個對象的地址,而equals比較的是2個對象的內容。
4、編寫一個方法用於奇偶數判定。
int num=0;
System.out.println("請輸入一個整數:");
Scanner inputScanner=new Scanner(System.in);
num=inputScanner.nextInt();
if(num%2==0){
System.out.println(num+"為偶數");
}else{
System.out.println(num+"為奇數");
}
5、以下這段代碼是否正確:
String[] name={"tom","dick","harry"};
for(i=0;i<=name.length;i++){
System.out.print(name[i]+'\n');
}
這段代碼錯誤,會觸發「」異常,這是代碼在嘗試訪問不在數組的索引取值范圍內的元素時會顯示的運行時錯誤消息。
6、以下兩個列印,分別輸出什麼結果:
double amount1=2.0;
double amount2=1.1;
double amount3=0.9;
System.out.println(amount1-amount2==amount3);

BigDecimal damount1=newBigDecimal("2.0");
BigDecimal damount2=newBigDecimal("1.1");
BigDecimal damount3=newBigDecimal("0.9");
System.out.println(damount1.subtract(damount2).equals(damount3));
7、jsp和servlet有何區別?
jsp在本質上就是servlet但是兩者的創建方式不一樣。
servlet完全是Java程序代碼構成擅長於流程式控制制和事務處理,而通過jsp來生成動態網頁;jsp由HTML代碼和JSP標簽構成,可以方便地編寫動態網頁。
因此在實際應用中採用servlet來控制業務流程,而採用JSP來生成動態網頁。在struts框架中,jsp位於MVC設計模式的視圖層,而servlet位於控制層。
8、以下說法錯誤的是?(A)
A.session存在伺服器,cookie存在硬碟
B.session機制採用的是伺服器端保持狀態,但是在應用過程中藉助於cookie機制來達到保存標識的目的,從而實現用戶登錄
C.cookie只與你的主機(域)有關,與select和jsp頁面無關
D.cookie中不能直接存取java對象,session中可以存對象
9、下面關於forward和redirect的描述,不正確的是?(D)
A.執行forward時,瀏覽器不知道伺服器發送的內容從何而來,地址欄還是原來的地址
B.執行forward時,伺服器端告訴瀏覽器重新去請求地址
C.forward是內部重定向,redirect是外部重定向
D.forward是伺服器將控制權轉交給另一個內部伺服器對象,由新的對象來全權負責響應用戶的請求
10、http請求中,get和post的區別?
(1)get是從伺服器上獲取數據,post是向伺服器傳送數據。 在客戶端,Get方式在通過URL提交數據,數據在URL中可以看到;POST方式,數據放置在HTML HEADER內提交。
(2)對於get方式,伺服器端用Request.QueryString獲取變數的值,對於post方式,伺服器端用Request.Form獲取提交的數據。
(3) GET方式提交的數據最多隻能有1024位元組,而POST則沒有此限制。
(4)安全性問題。正如在(1)中提到,使用 Get 的時候,參數會顯示在地址欄上,而 Post 不會。所以,如果這些數據是中文數據而且是非敏感數據,那麼使用 get;如果用戶輸入的數據不是中文字元而且包含敏感數據,那麼還是使用 post為好。
11、Spring和Hibernate整合過程中各對象(BO為業務模型)注入的順序是?(C)
A.DateSource->SessionFactory->Biz->DAO B.SessionFactory->DateSource->DAO->BO
C.DateSource->SessionFactory->DAO->BO D.SessionFactory->DateSource->Biz->DAO
12、所有通過英語六級考試的學生都參加了學校的英語俱樂部,王進參加了英語俱樂部,所以他一定通過了英語六級考試。以下哪項最好的指出了上述論證的邏輯錯誤?(C)
A.部分通過英語六級考試的學生沒有參加英語俱樂部
B.王進參加英語俱樂部是因為他符合加入俱樂部的基本條件
C.有些參加英語俱樂部的學生還沒有通過英語六級考試
D.王進曾經獲得過年級英語演講比賽第一名
13、Spring實現ioc是基於何種底層java技術?
基於java的反射機制 , 在spring初始化的時候 , 初始化所有bean , 然後在應用程序需要的時候 , 通過反射機制來獲取。
14、為什麼有時需要連接池?列出一個連接池的實例,舉例說明使用連接池的好處。
使用連接池是為了提升操作資料庫的效率,使用連接池就好比一些東西已經造好等著你來用就行了,不使用連接池就像是你在用他們之前還要先造好然後再拿去用,這比不用連接池要耗費更多的時間。
package test;
import java.sql.*;
import java.util.*;
public class DBConnpool
{
private int inUse = 0;
private Vector<Connection> connections = new Vector<Connection>();
private String poolname = "dbconnpool";
private String dbid = "jdbc:mysql://localhost:3306/teasystem";
private String drivername = "com.mysql.jdbc.Driver";
private String username = "root";
private String password = "123";
private int maxconn = 5000;
public DBConnpool(){ }
public void setdbid(String dbid)
{ this.dbid = dbid; }
public void setusername(String username)
{ this.username = username; }
public void setpassword(String password)
{ this.password = password; }
public void setmaxconn(int maxconn)
{ this.maxconn = maxconn; }
public String getdbid()
{ return dbid; }
public String getusername()
{ return username; }
public String getpassword()
{ return password; }
public int getmaxconn()
{ return maxconn; }
//將連接返還給連接池
public synchronized void reConnection(Connection conn)
{ Connection con = conn;
connections.addElement(con);
inUse--;
}
//從連接池獲取一個連接
public synchronized Connection getConnection()
{
Connection con = null;
if(connections.size()>0)
{
con = (Connection)connections.elementAt(0);
connections.removeElementAt(0);
try{
if(con.isClosed())
{ con = getConnection(); }
}catch(Exception e){
e.printStackTrace();
}
}else if(maxconn == 0||inUse<maxconn)
{ con = newConnection(); }
if(con != null)
{ inUse++; }
return con;
}
private Connection newConnection()
{
Connection con = null;
try{
Class.forName(drivername);
con = DriverManager.getConnection(dbid,username,password);
}catch(Exception e){
e.printStackTrace();
return null;
}
return con;
}
public synchronized void closeConn()
{
Enumeration allConnections = connections.elements();
while(allConnections.hasMoreElements())
{
Connection con = (Connection)allConnections.nextElement();
try{
con.close();
}catch(SQLException e){
e.printStackTrace();
} } } }
使用連接池,把暫時不使用的鏈接放入連接池,到需要使用的時候,從連接池中取出鏈接使用。
15、以下給定的數組,如何最簡單的把每個值都列印出來?
String[] arry=new String[]{"john","Marry","Bob"};
System.out.println(Array.toString(arry));
16、java項目中引入了一個第三方庫,運行到某段代碼過程中拋出NoClassDefFoundError或NoSuchMethodError,這個問題如何產生的,你如何解決這個問題?
17、有一個字元串需要判斷,條件如下:必須有至少1位數字,有1位字母,10位以上。你用何種技術實現這種判斷?
if(/^\d+$/.test(str)) { 全為數字,執行... }當然你也可以用isNaN來判斷if(isNaN(str)){ str是個數字,執行...}
18、Chrome瀏覽器用於調試的快捷鍵是什麼?
F12
19、Chrome瀏覽器調試面板中,Elemets,Network,Resources分別是什麼用途?
Elements 是頁面html元素,
Network 是頁面載入的時候網路資源載入情況
Resource 是網站的網頁資源文件,包括css、js等
20、Eclipse中,讓一個java程序看起來更易讀的快捷鍵是什麼?
Ctrl+Shift+F
21、簡單說說什麼是stack trace。
stack trace叫做堆棧軌跡:如果你需要列印出某個時間的調用堆棧狀態,你將產生一個堆棧軌跡。
stack trace 中包括三部分,分別為:.bss .text .data
bss: 表示程序中未初始化的全局變數的一塊內存區域
text: 表示程序中已初始化的全局變數的一塊內存區域
data:表示存放程序執行代碼的一塊內存區域

❺ java 。資料庫,面試題,如下圖,求SQL

select 姓名, sum(成績) as 總成績
from ...
group by 姓名
order by 總成績

❻ JAVA面試題求大神幫忙,給滿分100分

1: D | javac 命令編譯指定類和該類依賴的類。編譯後的文件為二進制文件class
2:C
3:B
4:C | IOException,runtimeException 編譯時不要求強行處理,只在運行期發生。IOException編譯時強行要求處理,繼承自Exception
5:B | Set無序隊列,用get(index)游標無法獲取
6:C
7:A | 不使用關鍵字相當於default
8:D | 二進制演算法 11為 111 | 10 = 111(只要有一個是1就是1) 也就是11
9: C | ''表示位元組char。"/u0020" 是Unico的空格編碼
10:B

1、publicstaticObject[]arraySubtract(Object[]array1,Object[]array2){
ArrayList<Object>list=newArrayList<Object>();
//選出屬於數組1但不屬於數組2的元素
for(inti=0;i<array1.length;++i){
booleanbContained=false;
for(intj=0;j<array2.length;++j){
if(array1[i].equals(array2[j])){
bContained=true;
break;
}
}
if(!bContained){
list.add(array1[i]);
}
}

Objectres[]=newObject[list.size()];
for(inti=0;i<list.size();++i)
res[i]=list.get(i);
returnres;
}

2、
intcount(intn)
{
intresult=0;
for(inti=1;i<n;i++)
{
result+=i;
}
returnresult;
}
3、select*fromAwherenamein((name)>1)
熱點內容
壓縮內存軟體 發布:2025-01-31 16:51:39 瀏覽:145
腳本lcd 發布:2025-01-31 16:41:02 瀏覽:515
安卓selinux干什麼用的 發布:2025-01-31 16:32:04 瀏覽:531
俠盜獵車手加錢密碼是多少 發布:2025-01-31 15:44:28 瀏覽:662
沒密碼怎麼登微信 發布:2025-01-31 15:33:51 瀏覽:737
c語言死機程序 發布:2025-01-31 15:07:52 瀏覽:18
編程教育裝修 發布:2025-01-31 15:04:38 瀏覽:402
函數和存儲過程的區別 發布:2025-01-31 14:39:12 瀏覽:610
地下室柱子箍筋的加密 發布:2025-01-31 14:36:11 瀏覽:935
手機拍攝視頻在哪個文件夾 發布:2025-01-31 14:34:28 瀏覽:761