JdbcTemplate 对mysql数据库操作

package Dao;

import java.util.List;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.sql.DriverManager;  
import java.sql.Connection;  
import java.sql.Statement;  

import org.apache.coyote.http11.filters.VoidInputFilter;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowCallbackHandler;
import org.springframework.jdbc.datasource.DriverManagerDataSource;

import bsh.This;

//import Domain.model;

public class Mysqltest {

	
	   private static JdbcTemplate temp = new JdbcTemplate();
	   private static int temp2;
	   public static String URL;
       public static String uesrName;
	   public static String passWord;
	   public static int ID = 1;

	   public static void main(String[] args) throws Exception {
		   
		   connectToDatabase();
		   //creattable();
		   //useradd();
		   User temp = Search();
		   System.out.println(temp.getName());
		   System.out.println(temp.getCompany());
		   System.out.println(temp.getEmailUrl());
		   System.out.println(temp.getId());
	   }
	   
	   //connect to the mysql
	   public static void connectToDatabase() {
		   
			DriverManagerDataSource ds = new DriverManagerDataSource();
			ds.setDriverClassName("com.mysql.jdbc.Driver");
			
			ds.setUrl("jdbc:mysql://localhost:3306/user?useUnicode=true&characterEncoding=UTF-8");		
			ds.setUsername("root");
			ds.setPassword("2323");
			temp.setDataSource(ds);
		}	
	  //creat the table
	   public static void creattable() {
		   String sql="CREATE TABLE user_in (ID INT(60) primary key, EmailUrl VARCHAR(100),"
				   + " name VARCHAR(60), password VARCHAR(100), Company VARCHAR(20));";		
		   temp.execute(sql);
	   }
	   
	   //insert the information
	   public static void useradd() {
		   String sqlStr = "INSERT INTO " + "user_in" + "(ID,EmailUrl,name,password,Company) " + " VALUES(?,?,?,?,?) ";
			Object args[] = new Object[] {"1", "weizhinie@tju.edu.cn","weizhi","2323","天津大学"};

			temp.update(sqlStr, args);
	   }
	   
	   
	   public static void useradd2(String name, String password, String email, String company) {
		   String sqlStr = "INSERT INTO " + "user_in" + "(ID,EmailUrl,name,password,Company) " + " VALUES(?,?,?,?,?) ";
		   ID++;
		   Object args[] = new Object[] {String.valueOf(ID), email,name,password,company};

			temp.update(sqlStr, args);
	   }
	   
	   //search the information
	   public static User Search() {
		   User model = new User();
		   ArrayList<User> result = new ArrayList<>();			
			String sqlStr = String.format("SELECT * FROM %s where name like ? ", "user_in");						   
			temp.query(sqlStr, new Object[]{"%weizhi%"}, new RowCallbackHandler() {			
				@Override
				public void processRow(ResultSet arg0) throws SQLException {
					
					System.out.println(arg0);
					model.setCompany(arg0.getString("Company"));
					model.setPassword(arg0.getString("password"));
					//model.setImgWebURL(arg0.getString("imgWebURL"));	
					model.setName(arg0.getString("name"));
					model.setEmailUrl(arg0.getString("EmailUrl"));
					
										
					result.add(model);
				}
			});
 
			return model;
	   }
	   //search the number of the result. 
	   public static int Search2(String name, String password) throws Exception {
		   //User model = new User();
		    
		    temp2 = 1;
		   //ArrayList<User> result = new ArrayList<>();	
		    String query = "SELECT * FROM user_in where name like \"%"+name+"%\"";
		    System.out.println(query);
		    List rows = temp.queryForList(query);
			
					
					if(rows.size()==0) {
						System.out.println("meiyou");
						temp2 = 0;
					}
					else {
					//System.out.println(arg0);
						System.out.println("you");
						temp2 = 1;						
					}
            return temp2;
	   }
}
Spring JdbcTemplate是Spring框架提供的一个对JDBC进行封装的工具类,它可以简化JDBC编程的复杂性,提供了一种更简便的方式来访问数据库JdbcTemplate的原理是将JDBC的访问进行封装,提供了一些常用的操作方法,例如查询、更新、批量操作等。它通过DataSource来获取JDBC的连接,并通过Connection对象进行JDBC的操作,最后释放连接资源。 使用JdbcTemplate进行数据库操作的步骤如下: 1. 配置数据源,配置JdbcTemplate。 2. 在代码中通过JdbcTemplate对象进行数据库操作。 下面是一个简单的例子: 配置数据源和JdbcTemplate: ```xml <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/test"/> <property name="username" value="root"/> <property name="password" value="root"/> </bean> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"> <property name="dataSource" ref="dataSource"/> </bean> ``` 在代码中通过JdbcTemplate对象进行数据库操作: ```java @Autowired private JdbcTemplate jdbcTemplate; public void insertUser(User user) { String sql = "INSERT INTO user(name, age) VALUES(?, ?)"; jdbcTemplate.update(sql, user.getName(), user.getAge()); } public List<User> getUsers() { String sql = "SELECT * FROM user"; List<User> users = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class)); return users; } ``` 在上面的代码中,我们通过@Autowired注解注入了JdbcTemplate对象,并使用它来执行插入和查询操作。 通过JdbcTemplate,我们可以使用占位符来传递参数,也可以使用BeanPropertyRowMapper将查询结果映射为Java对象。 总的来说,Spring JdbcTemplate的原理是封装了JDBC的访问,提供了一种更便捷的方式来操作数据库
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值