zoukankan      html  css  js  c++  java
  • Java反射_JDBC操作数据

    </pre><p>使用反射 来操作  这里是练习反射的使用</p><p>链接数据库工具类</p><p><pre name="code" class="java">private static final String DRIVER = "com.mysql.jdbc.Driver";
    	private static final String USER = "root";
    	private static final String PW = "1234";
    	private static final String URL="jdbc:mysql://localhost:3306/reflction";
    	/**
    	 * 链接数据库
    	 * @return
    	 */
    	public static Connection getConnection(){
    		try {
    			Class.forName(DRIVER);
    			Connection con = DriverManager.getConnection(URL, USER, PW);
    			System.out.println("Connection OK .....");
    			return con;
    		} catch (Exception e) {
    			System.out.println("Connection error...");
    			e.printStackTrace();
    		}
    		return null;
    	}

    核心类

    public Object getById(Class clazz, Integer id) throws Exception{
    		Object obj = clazz.newInstance();//实列一个
    		//创建链接
    		Connection con = JdbcUtils.getConnection();
    		//获取实体的名字 须要拼接 从最后一个点開始		
    		String tablename = clazz.getName().substring(clazz.getName().lastIndexOf("."));
    		//拼接sql 语句
    		String sql = "select * from "+tablename+" where id=?";
    		
    		try {
    			PreparedStatement psmt = con.prepareStatement(sql);
    			psmt.setInt(1, id);
    			//查到结果集
    			ResultSet rs = psmt.executeQuery();
    			//遍历结果
    			while(rs.next()){
    				//得到全部属性
    				Field[] fields = clazz.getDeclaredFields();
    				for (Field field : fields) {//遍历属性
    					//获取属性名  
    					String fname = field.getName();
    					//获取属性类型 int
    					Class type = field.getType();
    					//
    					Method rsGetMethod = ResultSet.class.getMethod("getObject", String.class);
    					Object value = rsGetMethod.invoke(rs, fname);
    					//更改修饰符权限
    					field.setAccessible(true);
    					field.set(obj, value);
    				}
    			


  • 相关阅读:
    Python自动化运维之1、Python入门
    Github使用教程
    Windows 托盘区域显示图标
    VS 2013 打包程序教程
    UML类图简单介绍
    crontab定时任务
    软硬链接的区别和重点
    linux运维之NFS服务器配置
    怎么样让Win10可以ping通?
    VM虚拟机Linux克隆后网卡的相关操作!
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/5275725.html
Copyright © 2011-2022 走看看