【spring】spring JDBC开发 、 将创建表生成sql语句的方法

将navicate中已存在表的创建转化成sql语句的方法

1、右击表,选择对象信息

2、点击DDL

jar包引入

1、spring-starter-jdbc

代码实现:

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

 

2、驱动

代码实现:

<dependency>
	<groupId>mysql</groupId>
	<artifactId>mysql-connector-java</artifactId>
</dependency>

 

3、连接池

代码实现:

<dependency>
	<groupId>com.alibaba</groupId>
	<artifactId>druid</artifactId>
	<version>1.1.21</version>
</dependency>

 

properties文件配置

代码实现:

mysql_driver=com.mysql.cj.jdbc.Driver
mysql_url=jdbc:mysql://localhost:3306/final_hotel_system?serverTimezone=UTC
mysql_username=root
mysql_passwd=root

注:

(1)连接池、数据库连接信息是专项配置信息

(2)使用新版的jdbc驱动(cj.jdbc)必须添加时间戳(?serverTimezone=UTC)

否则报错:

The server time zone value '�й���׼ʱ��' is unrecogni

 

xml文件配置

1、引入专项配置文件

代码实现:

        <context:property-placeholder location="DB.properties"></context:property-placeholder>

 

2、创建dataSource的bean

代码实现:

<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
        <property name="driverClassName" value="${mysql_driver}"></property>
        <property name="url" value="${mysql_url}"></property>
        <property name="userName" value="${mysql_username}"></property>
        <property name="password" value="${mysql_passwd}"></property>
 </bean>

注:

该引用方式使用的是类似于el表达式的方法(不是el表达式也不是spel表达式)

 

3、创建jdbcTemplate 的bean

代码实现:

<bean id="jdbcTemplete" class="org.springframework.jdbc.core.JdbcTemplate">
       <property name="dataSource" value="#{dataSource}"></property>
</bean>

注:

(1)查找类的快捷方法:ctrl + shift + t(在包中) ctrl + shift + r(在src里面的)

 

4、添加自动扫描

        <context:component-scan base-package="com.zzxtit.aop.jdbc"></context:component-scan>

包内文件配置

1、创建接口

代码实现:

package com.zzxtit.aop.jdbc;

public interface UserDao {
	public void insertUserInfor(UserInfor us);
	
	public UserInfor getUserInforById(int userId);

	public void deleteUserInforById(int i);
	
	public void updatePasswordById(int userId, String newPassword); 
}

 

2、在包内添加信息类

代码实现:

package com.zzxtit.aop.jdbc;

public class UserInfor {
	private int userId;
	private String password;
	public int getUserId() {
		return userId;
	}
	public void setUserId(int userId) {
		this.userId = userId;
	}
	public String getPassword() {
		return password;
	}
	
	public void setPassword(String password) {
		this.password = password;
	}
	
	@Override
	public String toString() {
		return "UserInfor [userId=" + userId + ", password=" + password + "]";
	}
	
	public UserInfor() {
		super();
	}
	public UserInfor(int userId, String password) {
		super();
		this.userId = userId;
		this.password = password;
	}
}

3、添加实现类:

代码实现:

package com.zzxtit.aop.jdbc;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;

@Repository
public class UserDaoImol implements UserDao{

	@Autowired
	private JdbcTemplate jdbcTemplate;
	
	public void insertUserInfor(UserInfor us) {
		String sql="insert into user_infor(user_id,password) "
				+ "values(?,?)";	
		jdbcTemplate.update(sql, us.getUserId(), us.getPassword());
	}

	public UserInfor getUserInforById(int userId) {
		String sql = "select * from user_infor where user_id = ?";
		List<UserInfor> ui = jdbcTemplate.query(sql, new BeanPropertyRowMapper<UserInfor>(UserInfor.class), userId);
		
		if(ui != null && ui.size() > 0) {
			return ui.get(0);
		}else {
			return null;
		}
		
	}
	
	public void deleteUserInforById(int userId) {
		String sql = "delete from user_infor where user_id = ?";
		jdbcTemplate.update(sql,userId);
	}
	

	public void updatePasswordById(int userId, String newPassword) {
		String sql = "update user_infor set password = ? where user_id = ?";
		jdbcTemplate.update(sql, newPassword,userId );
		
	}


}

注:

(1)自动扫描时应将dao层注释为repository(持久层)

  (2)创建bean时默认使用无参的构造方法,如果写了有参的构造方法需要手动添加一个无参的构造方法

否则报错

Failed to instantiate [ClassName]: No default constructor found;

(3)getUserInforById中使用的query方法返回的是一个list

(4)添加一个新的方法时不仅要在实现类添加而且要在接口添加,在main中无法使用(spring面向接口)

(5)使用jdbcTemplate删除数据时使用的也是update方法

运行:

代码实现:

package com.zzxtit.aop.jdbc;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

/*
 * 需要记录的操作
 * 1、navicate 将操作转化为sql语句的方法[GIT]
 * 2、报错记录 (1)使用cj.jdbc必须添加 时间戳  [git](2) 创建bean时默认使用无参构造方法[git]
 * 3、添加数据类型的bean还是需要使用new的方法创建的
 * 4、添加新方法时需要在接口添加以及实现类添加
 * 5、使用jdbctemplate删除数据
 */
public class Main {

	public static void main(String[] args) {
		ApplicationContext ioc = new ClassPathXmlApplicationContext("applicationContest-jdbc.xml");
		
		UserDao ud = ioc.getBean(UserDao.class);
		
		UserInfor ui = ud.getUserInforById(123);
		System.out.println(ui);
		
		UserInfor ui1 = new UserInfor(1234,"1234");
		ud.insertUserInfor(ui1);
		
		ud.deleteUserInforById(1234);
		
		ud.updatePasswordById(123, "321");
	} 

}

注:

(1)像UserInfor这种用来添加数据的类是不用spring代理的,直接使用new创建

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值