将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创建