专业实习第二天 MySql5.0安装+SQLyog+数据库基本语句操作+java实现数据库连接

本文主要是介绍专业实习第二天 MySql5.0安装+SQLyog+数据库基本语句操作+java实现数据库连接,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基本语句—增删改查
##选中要执行的语句,F8执行
#删除数据库 
#第一句写这个可以重复执行
DROP DATABASE IF EXISTS School;#创建数据库
CREATE DATABASE School;#使用数据库
USE School;#创建表
CREATE TABLE Student
(id INT PRIMARY KEY AUTO_INCREMENT,NAME VARCHAR(20) NOT NULL,age INT NOT NULL,hobby VARCHAR(20) NOT NULL
);INSERT INTO Student VALUES(NULL,'老大',8,'蜂蜜');
INSERT INTO Student VALUES(NULL,'老二',7,'光头强');
INSERT INTO Student VALUES(NULL,'老三',20,'蓝球');
INSERT INTO Student VALUES(NULL,'老师',21,'污');
INSERT INTO Student VALUES(NULL,'老五',99,'足球');#查询
SELECT * FROM Student;##############################我是分割线#####################################添加数据
INSERT INTO Student VALUES(NULL,'走石飞沙',21,'学习');#删除
DELETE FROM student; #数据全部删除,自增列不受影响DELETE FROM Student WHERE NAME = '老师'; #删除某条记录,自增列不受影响TRUNCATE TABLE Student; #删除全部数据,重置表,自增列恢复原值#修改
UPDATE Student SET hobby = '段子',age = 45 WHERE id = 4 #修改多个列用逗号分隔##################################我是分割线##################################查询数据SELECT * FROM Student; #查询全部列SELECT id ,NAME,age,hobby FROM Student#条件查询SELECT * FROM Student WHERE NAME = '老师'; #多个条件查询使用AND(并且)或者OR(或者)查询#排序查询     ORDER BY    升序:ASC或不写,降序:DESCSELECT * FROM Student ORDER BY age DESC;
外键+多表查询
DROP DATABASE IF EXISTS BookDB;
CREATE DATABASE BookDB;
USE BookDB;
CREATE TABLE TYPE(tid INT PRIMARY KEY AUTO_INCREMENT,tname VARCHAR(20) NOT NULL
);CREATE TABLE Book(bid INT PRIMARY KEY AUTO_INCREMENT,bname VARCHAR(20) NOT NULL,bprice INT NOT NULL,bdesc VARCHAR(20) NOT NULL,tid INT NOT NULL,#外键FOREIGN KEY(tid) REFERENCES TYPE(tid)
);
#另外一种外键
#alter table Book add CONStraint fk_tid FOREIGN key (tid) REFERENCES type(tid);INSERT INTO TYPE VALUE(NULL,'chinese');
INSERT INTO TYPE VALUE(NULL,'english');INSERT INTO Book VALUE(NULL,'book1',10,'desc1',1);
INSERT INTO Book VALUE(NULL,'book2',20,'desc2',1);
INSERT INTO Book VALUE(NULL,'book3',20,'desc3',1);
INSERT INTO Book VALUE(NULL,'book4',50,'desc4',2);
INSERT INTO Book VALUE(NULL,'book5',30,'desc5',2);SELECT * FROM TYPE;
SELECT * FROM Book;#多表查询
#select..whereSELECT b.bid,b.bname,b.bprice,b.bdesc,t.tname
FROM TYPE t,Book b
WHERE t.tid = b.tid;# inner..join
SELECT b.bid,b.bname,b.bprice,b.bdesc,t.tname
FROM TYPE t INNER JOIN Book b
ON t.tid = b.bid;
连接数据库小实现—–上面第一个School数据库连接测试使用

1.创建学生类

public class Student {private int id;private String name;private int age;private String hobby;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public String getHobby() {return hobby;}public void setHobby(String hobby) {this.hobby = hobby;}public Student(int id, String name, int age, String hobby) {super();this.id = id;this.name = name;this.age = age;this.hobby = hobby;}public Student() {super();}}

2.数据库基本工具类

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;public class BaseDao {private String driver = "com.mysql.jdbc.Driver";private String url = "jdbc:mysql://localhost:3306/School";private String name = "root";private String pwd = "123456";public Connection getCon(){Connection con = null;try {Class.forName(driver);con = DriverManager.getConnection(url,name,pwd);} catch (ClassNotFoundException e) {// TODO Auto-generated catch blocke.printStackTrace();} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}return con;}public void closeAll(Connection con,PreparedStatement ps,ResultSet rs){try {if(rs != null){rs.close();}if(ps != null){ps.close();}if(con != null){con.close();}} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}}Connection con = null;PreparedStatement ps = null;//万能正删改方法public int execute(String sql,Object ... param){int result = 0;try {con = this.getCon();ps = con.prepareStatement(sql);int i = 1;for(Object obj : param) {ps.setObject(i, obj);i++;}result = ps.executeUpdate();} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();} finally {this.closeAll(con, ps, null);}return result;}
}

3.学生工具类

public class StudentDao extends BaseDao {public int add(Student stu){String sql = "insert into Student values(null,?,?,?)";return this.execute(sql,stu.getName(),stu.getAge(),stu.getHobby());}public int update(Student stu){String sql = "update Student set name = ?,age = ?,hobby = ? where id = ?";return this.execute(sql,stu.getName(),stu.getAge(),stu.getHobby(),stu.getId());}public int delete(int id){String sql = "delete from Student where id = ?";return this.execute(sql, id);}
}

4.测试

public class Test {public static void main(String[] args) {StudentDao sd = new StudentDao();//int result = sd.add(new Student(0,"老八",10,"游戏"));//int result = sd.update(new Student(8,"老八",55,"game"));int result = sd.delete(8);if(result == 1){System.out.println("success");}else {System.out.println("error");}}
}
小知识 & 快捷键
  1. 导入mysql jar包 —>>>项目名右键然后3 3 2,左边第三个,中间第三个,右边第二个
  2. 异常快捷键 alt+shift+z 松开摁y
  3. gets and sets alt+shift+s 选择最大快的第二个
  4. 构造方法 alt+shift+s 最大块倒数第二个 全选为含参构造 全不选为无参构造
  5. 导包 ctrl+shift+O
  6. 整理代码 ctrl+shift+F
  7. 快捷提示 lat+/
  8. 删除一行 ctrl+D

这篇关于专业实习第二天 MySql5.0安装+SQLyog+数据库基本语句操作+java实现数据库连接的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/441367

相关文章

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方