• 技术文章 >数据库 >mysql教程

    JDBC链接mysql插入数据后显示问号的原因及解决办法_MySQL

    PHP中文网PHP中文网2018-05-18 10:51:25原创1788
    1.在cmd中进入mysql查看默认的编码格式:

    mysql> show variables like "%char%";

    若不是utf8(因为我用的是utf8),关掉mysql服务,在my.ini中添加

    [client]
    default-character-set=utf8
    [mysqld]
    default-storage-engine=INNODB
    character-set-server=utf8
    collation-server=utf8_general_ci
    [mysql]
    default-character-set=utf8

    2.eclipse中的编码格式是否为utf8

    3.如果还是不可以,检查mysql客户端表格的编码方式

    show create table tablename

    如果不是utf-8.删掉重新建立一张表(之前我在原表上改动没有成功,可能是我自己操作的原因)

    分享一个经典的JDBC连接MySQL的程序

    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    public class MySQLConnection {
    public static void main(String[] args) {
    Connection conn = null;
    Statement stmt = null;
    ResultSet rs = null;
    String url = null;
    String user = null;
    String password = null;
    String sql = null;
    try {
    Class.forName("com.mysql.jdbc.Driver"); //加载mysq驱动
    } catch (ClassNotFoundException e) {
    System.out.println("驱动加载错误");
    e.printStackTrace();//打印出错详细信息
    }
    try {
    url = 
    "jdbc:mysql://localhost/test?user=root&password=yqs2602555
    &useUnicode=true&&
    characterEncoding=gb2312&autoReconnect = true";
    //简单写法:url = "jdbc:myqsl://localhost/test(数据库名)? user=root(用户)&password=yqs2602555(密码)";
    user = "root";
    password = "yqs2602555";
    conn = DriverManager.getConnection(url,user,password);
    } catch (SQLException e) {
    System.out.println("数据库链接错误");
    e.printStackTrace();
    }
    try {
    stmt = conn.createStatement();
    sql = "select * from dept";//dept这张表有deptno,deptname和age这三个字段
    rs = stmt.executeQuery(sql);//执行sql语句
    while(rs.next()) {
    System.out.print(rs.getInt("deptno") + " ");
    System.out.print(rs.getString("deptname") + " ");
    System.out.println(rs.getInt("age") + " ");
    }
    } catch (SQLException e) {
    System.out.println("数据操作错误");
    e.printStackTrace();
    }
    //关闭数据库
    try {
    if(rs != null) {
    rs.close();
    rs = null;
    }
    if(stmt != null) {
    stmt.close();
    stmt = null;
    }
    if(conn != null) {
    conn.close();
    conn = null;
    }
    } catch(Exception e) {
    System.out.println("数据库关闭错误");
    e.printStackTrace();
    }
    }
    }

    运行结果如下:

    1 yqs 0 
    2 hello 0 
    3 yqsshr 0 
    4 world 0 
    5 hryspa 0 
    1 yqs 0 
    2 hello 0 
    3 yqsshr 0 
    4 world 0 
    5 hryspa 0 
    1 yqs11 21 
    1 yqs21 31 
    1 yqs31 41 
    1 yqs41 51

    以上就是JDBC链接mysql插入数据后显示问号的原因及解决办法_MySQL的内容,更多相关内容请关注PHP中文网(m.sbmmt.com)!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:MySQL 5.5/5.6/5.7及以上版本安装包安装时如何选择安装路径_MySQL 下一篇:Mysql数据库介绍及mysql显示命令_MySQL
    Web大前端开发直播班

    相关文章推荐

    • jquery mobile是什么意思• mysql怎么增加行• mysql怎么增加权限• mysql怎么删除unique约束• mysql视图与表的区别是什么

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网