zoukankan      html  css  js  c++  java
  • JDBC编程JAVA

    学习资料《疯狂java讲义》

    环境:MYSQL

            Java 1.7

    java用JDBC操作数据库是java编程的基础之一。而掌握SQL是JDBC编程的基础。JDBC是sun公司制定的接口API,各个数据库产商根据接口API提供实现类(驱动程序),这是面向接口编程的典型应用。

    可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL)。

    SQL (结构化查询语言)是用于执行查询的语法。但是 SQL 语言也包含用于更新、插入和删除记录的语法。

    查询和更新指令构成了 SQL 的 DML 部分:

    • SELECT - 从数据库表中获取数据
    • UPDATE - 更新数据库表中的数据
    • DELETE - 从数据库表中删除数据
    • INSERT INTO - 向数据库表中插入数据

    SQL 的数据定义语言 (DDL) 部分使我们有能力创建或删除表格。我们也可以定义索引(键),规定表之间的链接,以及施加表间的约束。

    SQL 中最重要的 DDL 语句:

    • CREATE DATABASE - 创建新数据库
    • ALTER DATABASE - 修改数据库
    • CREATE TABLE - 创建新表
    • ALTER TABLE - 变更(改变)数据库表
    • DROP TABLE - 删除表
    • CREATE INDEX - 创建索引(搜索键)
    • DROP INDEX - 删除索引

    MYSQL语法:

    show databases;

    use 数据库名;

    show tables;

    desc 表名--查看数据表的结构

    bin mysql -p 密码 -u 用户名 -h主机名 --default-character-set=utf8  连接远程主机的mysql服务

    alter table tablename modify; 只能一次修改一个列

    alter table tablename rename to newname;

    alter table tablename change 列名 to 新列名 type;

    (constraint 约束名)约束定义;---多列约束

    primary key( 列名) ----多列主键约束,不能自定义约束名称

    列名 type auto_increment primary key---自增长主键

    alter table tablename drop index 约束名;

    建立外键约束时,MYSQL会为该列建立索引;

    列名 类型 references 表名(主键名);

    外键参照自身表的主键----自关联

    on detete cascade / on delete set null--主键记录删除,从键也删除

    create index index_name on table_name (column1, column2...);

    create or replace view view_name as subquery  with check option;不允许修改视图数据

    DML:

    insert into ; update; delete from;

    concat("xxx","xxx")字符串连接

    distinct、in、like、is null

     PS:不建议在JAVA程序中使用特定数据库的函数,因为会导致程序代码与特定数据库耦合;如果移植要重新打开源程序修改SQL语句。

    where 与having的区别

    where用于过滤行,having用于过滤组

    where子句中不能使用组函数(avg(), count(), max(),min(),sum()),having可以

    cross join, natural join, join using, join on

    left join, right join ,full join

    子查询

    集合运算select union/minus/

    JDBC常用类和接口:在java.sql包下重要的几个类或对象

    DriverManager

    Connection

    Statement

    ResultSet

    例子:记得添加mysql -connector-java 的jar包

    public class JDBCTest {
        public static void main(String[] args) throws ClassNotFoundException, SQLException, InterruptedException {
            // 加载驱动
            Class.forName("com.mysql.jdbc.Driver");
    
            try {
    
                Connection conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/sakila", "root", "password");
                Statement stmt = conn.createStatement();
                ResultSet rs = stmt.executeQuery("select * from city LIMIT 5");
                while (rs.next()) {
                    System.out.println(
                            rs.getInt(1) + "	" + rs.getString(2) + "	" + rs.getInt(3) + "	" + rs.getTimestamp(4));
                    Thread.sleep(3000);
                }
            } finally {
    
            }
    
        }
    
    }
    
    输出:
    1    A Corua (La Corua)    87    2006-02-15 04:45:25.0
    2    Abha    82    2006-02-15 04:45:25.0
    3    Abu Dhabi    101    2006-02-15 04:45:25.0
    4    Acua    60    2006-02-15 04:45:25.0
    5    Adana    97    2006-02-15 04:45:25.0
    //执行SQL,PreparedStatement与Statement对比
    
    public class PreparedStatementTest {
        private String driver;
        private String url;
        private String user;
        private String pass;
    
        public void initParam(String paramFile) throws Exception {
            Properties props = new Properties();
            props.load(new FileInputStream(paramFile));
            driver = props.getProperty("driver");
            url = props.getProperty("url");
            user = props.getProperty("user");
            pass = props.getProperty("pass");
    
        }
        public void insertUseStatement() throws Exception
        {
            Class.forName(driver);
            long start = System.currentTimeMillis();
            try(
                    Connection conn = (Connection) DriverManager.getConnection(url,user,pass);
                    Statement stmt = conn.createStatement())
            {
                for(int i=0;i<100;i++)
                {
                    stmt.executeUpdate("insert into student_table values("+"null,'姓名"+i+"', 1)");
                }
                System.out.println("using statement:"+(System.currentTimeMillis()-start));
            }
        }
        //PreparedStatement能防止SQL注入,?代表占位符
        public void insertUsePrepare() throws Exception
        {
            Class.forName(driver);
            long start=System.currentTimeMillis();
            try(
                    Connection conn = DriverManager.getConnection(url,user,pass);
                    PreparedStatement pstmt=conn.prepareStatement("insert into student_table values(null,?,1)"))
            {
                for(int i =0;i<100;i++)
                {
                    pstmt.setString(1,"姓名"+i);
                    pstmt.executeUpdate();
                }
                System.out.println(" using PreparedStatement:"+(System.currentTimeMillis()-start));
            }
        }
        
    
        public static void main(String[] args) throws Exception {
            // TODO Auto-generated method stub
            PreparedStatementTest pt = new PreparedStatementTest();
            pt.initParam("E:\workspace\learning\mysql.ini");
            pt.insertUseStatement();
            pt.insertUsePrepare();
    
        }
    
    }
    
    输出:
    using statement:3423
     using PreparedStatement:3176
    View Code
  • 相关阅读:
    软件技术发展的几个阶段
    MOOONscheduler核心设计图(初稿)
    Write Read Writeln Readln console
    Win32Check对Windows操作 注销 重新启动 关闭计算机_Win32Check
    WM_nclButtonDblClk响应标题栏事件_message
    使用 “+”号实现多个字符串的连接
    TRichEdit_控制TRichEdit组件滚动
    取得字符串中指定的字符str[]
    undo RichEdit1
    使Memo 原有的右键功能失效 _OnContextPopup
  • 原文地址:https://www.cnblogs.com/flyingbee6/p/5149772.html
Copyright © 2011-2022 走看看