Day27 数据库复习二 JDBC一

多表查询

笛卡尔集
子表的外键做约束,子表的外键值要和主表的主键相同
内连接查询:n个表连接条件n-1个连接条件,把满足条件的数据查出来

select e.id,e.ename,salary,d.dname from employee e inner join dept d on e.did=d.id;
外链接查询:左外链接查询、右外链接查询,全外连接,把满足条件的数据查出来,还要把不满足条件的数据查出来

左外链接
    SELECT * 
    FROM emp LEFT OUTER JOIN dept
    ON emp.deptno = dept.deptno
右外链接
 SELECT * 
    FROM emp RIGHT OUTER JOIN dept
    ON emp.deptno = dept.deptno

子查询

把子查询的结果用在外出查询中
select * from employee where salary>(select salary from employee where ename=‘李四’);

分页查询limit

select * from employee limit 0,2;
limit的第一个值表示从哪一条开始,第二个值表示查询多少个记录
实际应用,已知条件第几页

导入导出(备份)cmd

导出 mysqldump -uroot -p 数据库名 > 保存路径,后缀名.sql
导入:
第一种方式: 先建库 mysql -uroot -p 数据库名 < 路径
第二种方式:use 库 mysql客户端:source 路径:

存储过程和函数触发器(pl/sql)

定义分隔符: delimiter //(结束之后记得修改过来)
定义存储过程:

create procedure pro_exam(pid int,out pname varchar(40)) begin select name into pname from exam where id = pid; end //

begin --------end//
函数的定义

delimiter//
create function fun(pid int) returns varchar(40)
begin
declare vname varchar(40);
select ename into vname from emp where id = pid;
return vname;
end //

delimiter;
函数的调用 select fun

JDBC

1.jdbc

java数据库连接技术 API

2.JDBC步骤

注册驱动:确定数据库
获取连接对象
获取发送sql语句载体:Statement、 PreparedStatement、 CallableStatement
根据sql的不同,不返回结果集:insert、update、delete    返回1/0
						  返回结果集:select
结果集处理:ResultSet
public class Testjdbc1 {
	public static void update() throws Exception{
		//1.注册驱动
		/*DriverManager.registerDriver(new Driver());*/
		Class.forName("com.mysql.jdbc.Driver");
		//2.获取连接
		String url="jdbc:mysql://localhost:3306/b";
		String user="root";
		String password="root";
		Connection conn=DriverManager.getConnection(url,user,password);
		//3.载体(传输对象)
		Statement stmt=conn.createStatement();
		//检查语句合法性,执行
		//执行效率低
		stmt.executeUpdate("update exam set name='aaa' where id=9");
		
	}
	public static void add() throws Exception{
		//1.注册驱动
		/*DriverManager.registerDriver(new Driver());*/
		Class.forName("com.mysql.jdbc.Driver");
		//2.获取连接
		String url="jdbc:mysql://localhost:3306/b";
		String user="root";
		String password="root";
		Connection conn=DriverManager.getConnection(url,user,password);
		//3.载体(传输对象)
		Statement stmt=conn.createStatement();
		int id=10;
		String name="aa";
		int chinese=2;
		int math=2;
		int english=2;
		String sql="insert into exam values(id,name,chinese,math,english)";
		//String sql="insert into exam values (9,'admin',1,1,1)";
		int n=stmt.executeUpdate(sql);
		System.out.println(n);
	}
	public static void query() throws Exception{
		//1.注册驱动
		/*DriverManager.registerDriver(new Driver());*/
		Class.forName("com.mysql.jdbc.Driver");
		//2.获取连接
		String url="jdbc:mysql://localhost:3306/b";
		String user="root";
		String password="root";
		Connection conn=DriverManager.getConnection(url,user,password);
		//3.载体(传输对象)
		Statement stmt=conn.createStatement();
		//4.处理结果集
		ResultSet rs=stmt.executeQuery("select * from exam");
		//next方法,指针下移,判断是否有数据
		while(rs.next()){
			System.out.println(rs.getInt(1));
			System.out.println(rs.getString("name"));
		}
	}
	public static void main(String[] args) throws Exception {
		add();
	}
}

3.Statement存在的问题

sql赋值容易出错
相同框架的语句执行,效率低
sql是拼接形式存在的,容易sql注入
封装工具类

public class DBUtil {
	public static Connection getConn() throws Exception{
		//1.注册驱动
		/*DriverManager.registerDriver(new Driver());*/
		Class.forName("com.mysql.jdbc.Driver");
		//2.获取连接
		String url="jdbc:mysql://localhost:3306/b";
		String user="root";
		String password="root";
		Connection conn=DriverManager.getConnection(url,user,password);
		return conn;
	}
public static void add(int id,String name,int chinese,int math,int english) throws Exception{
	/*	//1.注册驱动
		Class.forName("com.mysql.jdbc.Driver");
		//2.获取连接
		String url="jdbc:mysql://localhost:3306/b";
		String user="root";
		String password="root";*/
		Connection conn=DBUtil.getConn();
		//定义预置语句
		String sql="insert into exam values(?,?,?,?,?)";
		PreparedStatement pstmt=conn.prepareStatement(sql);
		//给占位符赋值
		pstmt.setInt(1,id);
		pstmt.setString(2,name);
		pstmt.setInt(3,chinese);
		pstmt.setInt(4,math);
		pstmt.setInt(5,english);
		//执行
		int n=pstmt.executeUpdate();
		System.out.println(n);
		DBUtil.close(pstmt, conn);
	}

4.PreparedStatement 预置语句

有占位符 " ?"

5.批处理

可以提高效率
//添加到批处理
pstmt.addBatch();
//执行批处理
pstmt.executeBatch();

6.事务

一起成功,一起失败

public class TestJdbc4 {
	public static void test() throws Exception{
		Connection conn=DBUtil.getConn();
		//开启事务
		conn.setAutoCommit(false);
		PreparedStatement pstmt=null;
		try{
			String sql="insert into exam (id,name) values(?,?)";
			pstmt=conn.prepareStatement(sql);
			pstmt.setInt(1, 13);
			pstmt.setString(2, "xiaoxiao");
			pstmt.executeUpdate();
			pstmt.setInt(1, 14);
			pstmt.setString(2, "xiao");
			pstmt.executeUpdate();
			//提交事务
			conn.commit();
		}catch(Exception e){
			//回滚事务
			conn.rollback();
		}
	}
	public static void main(String[] args) throws Exception {
		test();
	}
}
OFDM(正交频分复用)是种高效的多载波通信技术,它将高速数据流拆分为多个低速子流,并通过多个并行的低带宽子载波传输。这种技术具有高频谱效率、强抗多径衰落能力和灵活的带宽分配优势。 OFDM系统利用大量正交子载波传输数据,子载波间的正交性可有效避免码间干扰(ISI)。其数学表达为多个离散子载波信号的线性组合,调制和解调过程通过FFT(快速傅立叶变换)和IFFT(逆快速傅立叶变换)实现。其关键流程包括:数据符号映射到子载波、IFFT转换为时域信号、添加循环前缀以减少ISI、信道传输、接收端FFT恢复子载波数据和解调原始数据。 Matlab是种广泛应用于科研、工程和数据分析的高级编程语言和交互式环境。在OFDM系统设计中,首先需掌握Matlab基础,包括编程语法、函数库和工具箱。接着,根据OFDM原理构建系统模型,实现IFFT/FFT变换、循环前缀处理和信道建模等关键算法,并通过改变参数(如信噪比、调制方式)评估系统性能。最后,利用Matlab的绘图功能展示仿真结果,如误码率(BER)曲线等。 无线通信中主要考虑加性高斯白噪声(AWGN),其在频带上均匀分布且统计独立。通过仿真OFDM系统,可在不同信噪比下测量并绘制BER曲线。分析重点包括:不同调制方式(如BPSK、QPSK)对BER的影响、循环前缀长度选择对性能的影响以及信道估计误差对BER的影响。 OFDM技术广泛应用于多个领域,如数字音频广播(DAB)、地面数字电视广播(DVB-T)、无线局域网(WLAN)以及4G/LTE和5G移动通信,是这些通信标准中的核心技术之。 深入研究基于Matlab的OFDM系统设计与仿真,有助于加深对OFDM技术的理解,并提升解决实际通信问题的能力。仿真得到的关键性能指标(如BER曲线)对评估系统可靠性至关重要。未来可进步探索复杂信道条件下的OFDM性能及系统优化,以适应不同应用场景
51单片机是电子工程领域常用的入门级微控制器,广泛应用于小型电子设备,例如电子时钟。本项目将介绍如何利用51单片机设计款简单的电子时钟,并通过Keil软件进行程序开发,同时借助Proteus仿真工具进行电路模拟,帮助初学者掌握51单片机的基础应用。 51单片机基于Intel 8051内核,集成了CPU、RAM、ROM、定时器/计数器和I/O端口等功能模块,具有易于编程和性价比高的优势。在电子时钟项目中,主要利用其定时器实现时间的精确计算。Keil μVision是51单片机的常用开发环境,支持C语言和汇编语言编程。开发时,需编写代码以控制单片机显示和更新时间,包括初始化时钟硬件、设置定时器中断、编写中断服务程序以及与LCD显示屏交互等步骤。关键环节如下:是初始化,配置时钟源(如外部晶振)设定工作频率;是定时器设置,选择合适模式(如模式1或模式2),设置计数初值以获得所需时间分辨率;三是中断服务,编写定时器中断服务程序,定时器溢出时更新时间并触发中断;四是显示控制,通过I/O端口驱动LCD显示屏显示当前时间。 Proteus是款虚拟原型设计软件,可用于模拟硬件电路,帮助开发者在编程前验证电路设计。在Proteus中,可搭建51单片机、LCD模块、晶振及电阻、电容等元件,形成电子时钟电路模型。运行仿真后,可观察程序在实际电路中的运行情况,及时发现并解决问题。 实际项目中,51单片机电子时钟还涉及以下知识点:是时钟信号产生,定时器通过计数外部时钟脉冲实现时间累计,可通过调整晶振频率和定时器初始值设置不同时间间隔;是LCD接口,需理解LCD的命令和数据传输协议,以及如何控制背光、显示模式、行列地址等;三是中断系统,了解中断概念、中断向量及程序中中断的启用和禁用方法;四是数码管显示,若使用数码管而非LCD,需了解其显示原理及段选、位选的驱动方式。 本项目融合了单片机基础、
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值