1. 1 不可撤销
  2. 2 小年兽 程嘉敏
  3. 3 手放开 李圣杰
  4. 4 迷人的危险3(翻自 dance flow) FAFA
  5. 5 山楂树之恋 程佳佳
  6. 6 summertime cinnamons / evening cinema
  7. 7 不谓侠(Cover 萧忆情Alex) CRITTY
  8. 8 神武醉相思(翻自 优我女团) 双笙
  9. 9 空山新雨后 音阙诗听 / 锦零
  10. 10 Wonderful U (Demo Version) AGA
  11. 11 广寒宫 丸子呦
  12. 12 陪我看日出 回音哥
  13. 13 春夏秋冬的你 王宇良
  14. 14 世界が终わるまでは… WANDS
  15. 15 多想在平庸的生活拥抱你 隔壁老樊
  16. 16 千禧 徐秉龙
  17. 17 我的一个道姑朋友 双笙
  18. 18 大鱼  (Cover 周深) 双笙
  19. 19 霜雪千年(Cover 洛天依 / 乐正绫) 双笙 / 封茗囧菌
  20. 20 云烟成雨(翻自 房东的猫) 周玥
  21. 21 情深深雨濛濛 杨胖雨
  22. 22 Five Hundred Miles Justin Timberlake / Carey Mulligan / Stark Sands
  23. 23 斑马斑马 房东的猫
  24. 24 See You Again Wiz Khalifa / Charlie Puth
  25. 25 Faded Alan Walker / Iselin Solheim
  26. 26 Natural J.Fla
  27. 27 New Soul Vox Angeli
  28. 28 ハレハレヤ(朗朗晴天)(翻自 v flower) 猫瑾
  29. 29 像鱼 王贰浪
  30. 30 Bye Bye Bye Lovestoned
  31. 31 Blame You 眠 / Lopu$
  32. 32 Believer J.Fla
  33. 33 书信 戴羽彤
  34. 34 柴 鱼 の c a l l i n g【已售】 幸子小姐拜托了
  35. 35 夜空中最亮的星(翻自 逃跑计划) 戴羽彤
  36. 36 慢慢喜欢你 LIve版(翻自 莫文蔚) 戴羽彤
  37. 37 病变(翻自 cubi) 戴羽彤
  38. 38 那女孩对我说 (完整版) Uu
  39. 39 绿色 陈雪凝
  40. 40 月牙湾 LIve版(翻自 F.I.R.) 戴羽彤
夜空中最亮的星(翻自 逃跑计划) - 戴羽彤
00:00 / 04:10

夜空中最亮的星 能否听清

那仰望的人 心底的孤独和叹息

夜空中最亮的星 能否记起

那曾与我同行 消失在风里的身影

我祈祷拥有一颗透明的心灵

和会流泪的眼睛

给我再去相信的勇气

越过谎言去拥抱你

每当我找不到存在的意义

每当我迷失在黑夜里

噢喔喔 夜空中最亮的星

请指引我靠近你

夜空中最亮的星 是否知道

那曾与我同行的身影 如今在哪里

夜空中最亮的星 是否在意

是等太阳先升起 还是意外先来临

我宁愿所有痛苦都留在心底

也不愿忘记你的眼睛

哦 给我再去相信的勇气

哦 越过谎言去拥抱你

每当我找不到存在的意义

每当我迷失在黑夜里

噢喔喔 夜空中最亮的星

请照亮我向前行 哒~

我祈祷拥有一颗透明的心灵

和会流泪的眼睛 哦

给我再去相信的勇气

哦 越过谎言去拥抱你

每当我找不到存在的意义

每当我迷失在黑夜里

噢喔喔 夜空中最亮的星

请照亮我向前行

反射实现增删改查(DAO层)——插入数据

先贴出代码,后续补充自己的思路、配置文件、使用方式:
/**
	 *  插入数据
	 */
	@Override
	public void addObject(Object object, String tableName) {
		StringBuilder sql = new StringBuilder("INSERT " + tableName
				+ " VALUES(");
		Connection connection = null;
		PreparedStatement preparedStatement = null;
		// 用于存放传入的对象的参数,默认将id值(主键)的key设为0,方便条件设置
		Map<Integer, Object> fieldsValues = new HashMap<Integer, Object>();
		try {
			for (int i = 0; i < fields.length; i++) {
				fields[i].setAccessible(true);
				fieldsValues.put(i, fields[i].get(object));
				sql.append("?");
				if (i < (fields.length - 1))
					sql.append(", ");

			}
			sql.append(")");
			connection = DBConnection.getConnection();

			preparedStatement = connection.prepareStatement(sql.toString());
			Class<?> fieldClass = null;
			for (int i = 1; i <= fieldsValues.size(); i++) {
				/**
				 * 获取存入map中对象的参数的类类型,根据类类型选择preparedStatement的set方法
				 */
				if (fieldsValues.get(i - 1) != null) {
					fieldClass = fieldsValues.get(i - 1).getClass();
					// 如果类类型为String.class,则执行setString
					if (fieldClass.equals(String.class)) {
						preparedStatement.setString(i,
								(String) fieldsValues.get(i - 1));
					}
					// 如果类类型为Float.class,则执行setString
					if (fieldClass.equals(Float.class)) {
						preparedStatement.setFloat(i,
								(Float) fieldsValues.get(i - 1));
					}
					// 如果类类型为Integer.class,则执行setString
					if (fieldClass.equals(Integer.class)) {
						preparedStatement.setInt(i,
								(Integer) fieldsValues.get(i - 1));
					}
					// 如果类类型为Timestamp.class,则执行setString
					if (fieldClass.equals(Timestamp.class)) {
						preparedStatement.setTimestamp(i, new Timestamp(
								((Date) fieldsValues.get(i - 1)).getTime()));
					}

				} else {
					preparedStatement.setObject(i, null);
				}

			}
			// 执行sql语句,返回更新参数
			int columnsCount = preparedStatement.executeUpdate();
			System.out.println("有" + columnsCount + "条数据被更新!");

		} catch (SQLException e) {
			e.printStackTrace();
		} catch (SecurityException e) {
			e.printStackTrace();
		} catch (NumberFormatException e) {
			e.printStackTrace();
		} catch (IllegalArgumentException e) {
			e.printStackTrace();
		} catch (IllegalAccessException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} finally {
			DBConnection.close(connection, preparedStatement, null);
		}

	}

基本流程:(这张表结合源码备注理解应该问题不大)如果看不清楚,复制图片地址在新窗口中查看

posted @ 2018-05-19 22:34  云中志  阅读(1030)  评论(0编辑  收藏  举报