목차
DAO由两部分组成:" >DAO由两部分组成:
DAO包下面分4个包:" >DAO包下面分4个包:
代码实现:" >代码实现:

JDBCDAO优化

Jun 07, 2016 pm 02:50 PM
access dao data obj 최적화

DAO(Data Access Object)数据访问对象是一个数据访问接口,处理业务逻辑与数据库资源之间的关系。 DAO由两部分组成: 1.Data Access:数据访问,实现数据访问与业务逻辑的分离。 2.Action Domain Object:领域对象,业务数据对象的封装。 DAO模式的实现: 1.DA



DAO(Data Access Object)数据访问对象是一个数据访问接口,处理业务逻辑与数据库资源之间的关系。


DAO由两部分组成:

1.Data Access:数据访问,实现数据访问与业务逻辑的分离。

2.Action Domain Object:领域对象,业务数据对象的封装。


DAO模式的实现:

1.DAO的工厂类:构造DAO的实例对象。

2.DAO的接口:提供接口抽象方法,引导子类实现。

3.DAO的实现子类:实现接口方法。

4.数据对象:封装数据。


DAO包下面分4个包:

1.dao包:存放抽象接口的方法。

2.dao.impl包:存放实现子类的方法。

3.pojo包:存放封装的数据信息。

4.util包:存放工厂类。


代码实现:


父类接口:

public interface TeacherDao {//父类接口
	public boolean insert(Teacherpojo tea) throws Exception;
	public boolean delete(int id) throws Exception;
	public boolean update(Teacherpojo tea) throws Exception;
	public List<teacherpojo> query() throws Exception;
	public Teacherpojo queryById(int id) throws Exception;
}</teacherpojo>
로그인 후 복사


具体实现语句预制的方法:

public static int update(String sql,Object...objects) throws Exception {
		Connection con = SQLUtil.getConnection();//获取连接
		PreparedStatement ps = con.prepareStatement(sql);//获取预制对象
		for (int i=0;i<objects.length ps.setobject objects return ps.executeupdate><br>
<br>

<br>
子类实现(添加一条数据):
<p><span style="font-size:24px"></span></p>
<pre name="code" class="java">public boolean insert(Teacherpojo tea) throws Exception {
		String sql = "insert into teacher (id,name,gender,age,job,creatDate) "
				+ "values(?,?,?,?,?,?)";
		int result = SQLTemplete.update(sql, tea.getId(),tea.getName(),
				tea.getGender(),tea.getAge(),tea.getJob(),tea.getCreatdate());
		System.out.println("执行完成...");
		if(result > 0){
			return true;
		}
		return false;
	}
로그인 후 복사

结果图示:



删除一条数据:

public boolean delete(int id) throws Exception {
		String sql = "delete from teacher where id=?";
		int result = SQLTemplete.update(sql, id);
		System.out.println("执行完成...");
		if( result > 0 ){
			return true;
		}
		return false;
	}
로그인 후 복사

删除结果图示:





修改一条数据:

public boolean update(Teacherpojo tea) throws Exception {
		String sql = "update teacher set "
				+ "id=?,name=?,gender=?,age=?,job=?,creatDate=? where id=?";
		int result = SQLTemplete.update(sql, tea.getId(),tea.getName(),tea.getGender(),
				tea.getAge(),tea.getJob(),tea.getCreatdate(),tea.getId());
		System.out.println("执行完成...");
		if( result > 0 ){
			return true;
		}
		return false;
	}
로그인 후 복사

添加结果图示:




查找所有的数据,返回一个数据队列:

public ArrayList<teacherpojo> query() throws SQLException {
		Connection con = SQLUtil.getConnection();
		Statement state = con.createStatement();
		String sql = "select * from teacher";
		ResultSet rs = state.executeQuery(sql);
		ArrayList<teacherpojo> list = new ArrayList<teacherpojo>();
		Teacherpojo tp ;
		while(rs.next()){
			tp = new Teacherpojo();
			tp.setId(rs.getInt("id"));
			tp.setName(rs.getString("name"));
			tp.setAge(rs.getInt("age"));
			tp.setGender(rs.getString("gender"));
			tp.setJob(rs.getString("job"));
			tp.setCreatdate(rs.getString("creatDate"));
			list.add(tp);
		}
		System.out.println("执行完成...");
		return list;
	}</teacherpojo></teacherpojo></teacherpojo>
로그인 후 복사

结果图示:



很多时候并不是要查询所有的结果,要的是部分条件查询结果,所有可以写一个预制查找的方法,代码如下:


public static ResultSet query(String sql,Object...objects) throws Exception{
		Connection con = SQLUtil.getConnection();
		PreparedStatement ps = con.prepareStatement(sql);
		for (int i = 0; i <br>
结果图示,我只搜索关于gender为man的数据:
<p><span style="font-size:24px"><img src="/static/imghw/default1.png" data-src="http://img.blog.csdn.net/20160506200506812?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" class="lazy" alt=""><br>
</span></p>
<p><span style="font-size:24px"><br>
</span></p>
<p><span style="font-size:24px"><br>
</span></p>
<p><span style="font-size:24px"><br>
</span></p>
<p><span style="font-size:24px"><br>
</span></p>
   








로그인 후 복사
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

DeepSeek PDF를 변환하는 방법 DeepSeek PDF를 변환하는 방법 Feb 19, 2025 pm 05:24 PM

DeepSeek은 파일을 PDF로 직접 변환 할 수 없습니다. 파일 유형에 따라 공통 문서 (Word, Excel, PowerPoint) : Microsoft Office, LibreOffice 및 기타 소프트웨어를 사용하여 PDF로 내보내십시오. 이미지 : 이미지 뷰어 또는 이미지 처리 소프트웨어를 사용하여 PDF로 저장하십시오. 웹 페이지 : 브라우저의 "PDF로 인쇄"기능 또는 전용 웹 페이지에서 PDF 도구를 사용하십시오. 드문 형식 : 오른쪽 변환기를 찾아 PDF로 변환하십시오. 올바른 도구를 선택하고 실제 상황에 따라 계획을 개발하는 것이 중요합니다.

C++ 프로그램 최적화: 시간 복잡도 감소 기술 C++ 프로그램 최적화: 시간 복잡도 감소 기술 Jun 01, 2024 am 11:19 AM

시간 복잡도는 입력 크기를 기준으로 알고리즘의 실행 시간을 측정합니다. C++ 프로그램의 시간 복잡성을 줄이는 팁에는 데이터 저장 및 관리를 최적화하기 위한 적절한 컨테이너(예: 벡터, 목록) 선택이 포함됩니다. Quick Sort와 같은 효율적인 알고리즘을 활용하여 계산 시간을 단축합니다. 여러 작업을 제거하여 이중 계산을 줄입니다. 불필요한 계산을 피하려면 조건부 분기를 사용하세요. 이진 검색과 같은 더 빠른 알고리즘을 사용하여 선형 검색을 최적화합니다.

'검은 신화: 오공' Xbox 버전이 '메모리 누수'로 인해 지연되었으며, PS5 버전 최적화 진행 중 '검은 신화: 오공' Xbox 버전이 '메모리 누수'로 인해 지연되었으며, PS5 버전 최적화 진행 중 Aug 27, 2024 pm 03:38 PM

최근 'Black Myth: 오공'은 각 플랫폼의 동시 접속자 수가 새로운 최고치를 기록하며 전 세계적으로 큰 주목을 받고 있습니다. 이 게임은 여러 플랫폼에서 큰 상업적 성공을 거두었습니다. 'Black Myth: Wukong'의 Xbox 버전 출시가 연기되었습니다. 'Black Myth: Wukong'은 PC와 PS5 플랫폼으로 출시되었지만 Xbox 버전에 대한 확실한 소식은 없습니다. 관계자는 '검은 신화:오공'이 엑스박스 플랫폼으로 출시될 것임을 확인한 것으로 알려졌다. 하지만 아직 구체적인 출시 날짜는 발표되지 않았습니다. 최근 Xbox 버전의 출시가 기술적인 문제로 인해 지연된 것으로 알려졌습니다. 관련 블로거에 따르면, 그는 Gamescom에서 개발자 및 "Xbox 내부자"와의 커뮤니케이션을 통해 "Black Myth: Wukong"의 Xbox 버전이 존재한다는 사실을 알게 되었습니다.

Node.js 환경에서 403을 반환하는 타사 인터페이스 문제를 해결하는 방법은 무엇입니까? Node.js 환경에서 403을 반환하는 타사 인터페이스 문제를 해결하는 방법은 무엇입니까? Mar 31, 2025 pm 11:27 PM

Node.js 환경에서 403을 반환하는 타사 인터페이스의 문제를 해결하십시오. Node.js를 사용하여 타사 인터페이스를 호출 할 때 때때로 403을 반환하는 인터페이스에서 403의 오류가 발생합니다 ...

Laravel Redis Connection 공유 : 선택 메소드가 다른 연결에 영향을 미치는 이유는 무엇입니까? Laravel Redis Connection 공유 : 선택 메소드가 다른 연결에 영향을 미치는 이유는 무엇입니까? Apr 01, 2025 am 07:45 AM

Laravel 프레임 워크 및 Laravel 프레임 워크 및 Redis를 사용할 때 Redis 연결을 공유하는 데 영향을 줄 수 있습니다. 개발자는 문제가 발생할 수 있습니다. 구성을 통해 ...

처리량 향상을 위해 C++ 서버 아키텍처 최적화 처리량 향상을 위해 C++ 서버 아키텍처 최적화 Jun 01, 2024 pm 01:14 PM

C++ 서버 처리량 최적화 전략: 스레드 풀: 요청에 빠르게 응답하기 위해 미리 스레드 풀을 만듭니다. 비차단 I/O: 처리량 향상을 위해 I/O를 기다리는 동안 다른 작업을 수행합니다. HTTP/2: 바이너리 프로토콜을 사용하고 멀티플렉싱 및 콘텐츠 압축을 지원하며 성능을 향상시킵니다.

C#에서 멀티 스레딩의 이점은 무엇입니까? C#에서 멀티 스레딩의 이점은 무엇입니까? Apr 03, 2025 pm 02:51 PM

멀티 스레딩의 장점은 특히 많은 양의 데이터를 처리하거나 시간이 많이 걸리는 작업을 수행하기 위해 성능 및 리소스 활용도를 향상시킬 수 있다는 것입니다. 이를 통해 여러 작업을 동시에 수행하여 효율성을 향상시킬 수 있습니다. 그러나 너무 많은 스레드가 성능 저하로 이어질 수 있으므로 CPU 코어 수와 작업 특성에 따라 스레드 수를 신중하게 선택해야합니다. 또한 다중 스레드 프로그래밍에는 교착 상태 및 레이스 조건과 같은 과제가 포함되며 동기화 메커니즘을 사용하여 해결해야하며 동시 프로그래밍에 대한 확실한 지식, 장단점을 측정하고주의해서 사용해야합니다.

노드 환경에서 403 오류를 반환하는 타사 인터페이스를 피하는 방법은 무엇입니까? 노드 환경에서 403 오류를 반환하는 타사 인터페이스를 피하는 방법은 무엇입니까? Apr 01, 2025 pm 02:03 PM

노드 환경에서 403 오류를 반환하는 타사 인터페이스를 피하는 방법. node.js를 사용하여 타사 웹 사이트 인터페이스를 호출 할 때 때때로 403 오류를 반환하는 문제가 발생합니다. � ...

See all articles