连接mysql数据库执行写入语句
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 | package insert; import java.sql.DriverManager; import java.sql.SQLException; import com.mysql.jdbc.Connection; public class DButil { /* * 打开数据库 */ private static String driver; //连接数据库的驱动 private static String url; private static String username; private static String password; static { driver= "com.mysql.jdbc.Driver" ; //需要的数据库驱动 url= "jdbc:mysql://localhost:3306/test?serverTimezone=GMT%2B8&useSSL=false" ;//数据库名路径 username= "root" ; password= "xxxx" ; } public static Connection open() { try { Class.forName(driver); return (Connection) DriverManager.getConnection(url,username, password); } catch (Exception e) { System.out.println( "数据库连接失败!" ); // TODO Auto-generated catch block e.printStackTrace(); } //加载驱动 return null ; } /* * 关闭数据库 */ public static void close(Connection conn) { if (conn!= null ) { try { conn.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } } |
需要引入 mysql-connector-java-5.1.45-bin.jar
执行类
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | package insert; import java.sql.SQLException; import com.mysql.jdbc.Connection; import com.mysql.jdbc.PreparedStatement; public class jdbcconnection { public static void main(String[] args) { // TODO Auto-generated method stub insert( "yangxu" , 1 , "beijing" , "15022009896" , false ); } static void insert(String name, int age,String address,String phone, boolean flag) { String sql= "insert into student(name,age,address,phone,flag) value(?,?,?,?,?)" ; Connection conn=DButil.open(); try { PreparedStatement pstmt=(PreparedStatement) conn.prepareStatement(sql); pstmt.setString( 1 ,name); pstmt.setInt( 2 ,age); pstmt.setString( 3 ,address); pstmt.setString( 4 ,phone); pstmt.setBoolean( 5 , flag); pstmt.executeUpdate(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { DButil.close(conn); } } } |
//实体类
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 | package insert; public class Customer { String name; int age; String address; String phone; boolean flag; 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 getAddress() { return address; } public void setAddress(String address) { this .address = address; } public String getPhone() { return phone; } public void setPhone(String phone) { this .phone = phone; } public boolean isFlag() { return flag; } public void setFlag( boolean flag) { this .flag = flag; } @Override public String toString() { return "Customer [name=" + name + ", age=" + age + ", address=" + address + ", phone=" + phone + ", flag=" + flag + "]" ; } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构