MYSQL数据库存储城市代码实现 在这篇http://blog.csdn.net/huoer_12/article/details/17399211文章中,说的是城市代码的MYSQL数据库方式的存储实现,这篇具体讲述实现方法。 实现类CityDB.java /** * @2013-12-18 * @author eabour * @file CityDB.java * Al
MYSQL数据库存储城市代码实现
在这篇http://blog.csdn.net/huoer_12/article/details/17399211文章中,说的是城市代码的MYSQL数据库方式的存储实现,这篇具体讲述实现方法。
实现类CityDB.java
/** * @2013-12-18 * @author eabour * @file CityDB.java * All Rights Reserved! */ package com.eabour.weather; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.ArrayList; import java.util.List; import java.util.Map; import com.eabour.jdbc.ConnectionPool; import com.eabour.tool.LogUtil; /** * @author eabour * @create 2013-12-18 下午2:44:59 */ public class CityDB { private ConnectionPool pool; private final String PROV_TABLE="province"; private final String CITY_TABLE="city"; private final String DIST_TABLE="distract"; public CityDB(){ this.pool=ConnectionPool.getInstance(); } /** * * @author eabour * @throws SQLException * @create 2013-12-18 下午2:50:15 * * @function: */ public void getCitCode() throws SQLException{ Connection con=pool.getConnection(); try{ Statement stmt=con.createStatement(); /* * DROP TABLE IF EXISTS `province`; * DROP TABLE IF EXISTS `city`; * DROP TABLE IF EXISTS `distract`; * */ /* ResultSet tables=stmt.executeQuery("show tables"); boolean hasProv = false,hasCity = false,hasDist = false; while(tables.next()){ String table=tables.getString(1); if(PROV_TABLE.equals(table)) hasProv=true; if(CITY_TABLE.equals(table)) hasCity=true; if(DIST_TABLE.equals(table)) hasDist=true; } */ con.setAutoCommit(false); stmt.addBatch("DROP TABLE IF EXISTS " + DIST_TABLE); stmt.addBatch("DROP TABLE IF EXISTS " + CITY_TABLE); stmt.addBatch("DROP TABLE IF EXISTS " + PROV_TABLE); stmt.executeBatch(); //con.setAutoCommit(true); stmt.addBatch("CREATE TABLE " + PROV_TABLE + " " + "(id varchar(10),name varchar(20),primary key(id)) ENGINE=InnoDB DEFAULT CHARSET=utf8"); stmt.addBatch("CREATE TABLE " + CITY_TABLE + " " + "(id varchar(10),name varchar(20),pro_id varchar(10),primary key(id)," + "foreign key(pro_id) references " + PROV_TABLE + "(id)) ENGINE=InnoDB DEFAULT CHARSET=utf8"); stmt.addBatch("CREATE TABLE " + DIST_TABLE + " " + "(id varchar(10),name varchar(20),code varchar(15),city_id varchar(10)," + "primary key(id),foreign key(city_id) references " + CITY_TABLE + "(id)) ENGINE=InnoDB DEFAULT CHARSET=utf8"); stmt.executeBatch(); con.commit(); CityCode cityutil=new CityCode(); //get Province list Map<string> pro=cityutil.getProvinceList(); for(String key : pro.keySet()){ System.out.println(key + " : " + pro.get(key)); stmt.addBatch("INSERT INTO "+ PROV_TABLE + "(id,name) values(\'"+ key + "\',\'" + pro.get(key) + "\')"); } stmt.executeBatch(); con.commit(); for(String key : pro.keySet()){ System.out.println(pro.get(key)); //get city list Map<string> city=cityutil.getCityZone(key); for(String city_key : city.keySet()){ System.out.println(" " + city.get(city_key)); stmt.addBatch("INSERT INTO "+ CITY_TABLE + " values(\'"+ city_key + "\',\'" + city.get(city_key) + "\',\'" + key + "\')"); //get distract list Map<string> distract=cityutil.getCityZone(city_key); for(String dis_key : distract.keySet()){ System.out.println(" " + distract.get(dis_key)); //get concrete information Map<string> concrete=cityutil.getCityZone(dis_key); stmt.addBatch("INSERT INTO "+ DIST_TABLE + " values(\'"+ dis_key + "\',\'" + distract.get(dis_key) + "\',\'" + concrete.get(dis_key) + "\',\'" + city_key + "\')"); } } stmt.executeBatch(); con.commit(); } }finally{ con.setAutoCommit(true); pool.release(con); } } /** * @param city * @return * @author eabour * @create 2013-12-18 下午5:31:16 * @charset UTF-8 * * @function: 根据参数city来查询该城市的代码 */ public String getCode(String city){ Connection con=pool.getConnection(); try{ if(city == null || !city.matches("[\\u4E00-\\u9FA5]+")) return "不合法"; con.setAutoCommit(true); PreparedStatement ps=con.prepareStatement("select code from "+DIST_TABLE+" where name = ?"); ps.setString(1, city); ResultSet rs=ps.executeQuery(); if(rs.next()){ return rs.getString(1); } ps=con.prepareStatement("select id from "+ PROV_TABLE +" where name = ?"); ps.setString(1, city); ResultSet rs1=ps.executeQuery(); List<string> list=new ArrayList<string>(); if(rs1.next()){ String id=rs1.getString(1); ps=con.prepareStatement("select name from "+ CITY_TABLE +" where pro_id = ?"); ps.setString(1, id); ResultSet rs2=ps.executeQuery(); while(rs2.next()){ list.add(rs2.getString(1)); } return list.toString(); } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); LogUtil.logWarn(this.getClass(), "getCity", e.toString()); }finally{ pool.release(con); } return "Unable to search the city's name of " + city; } } </string></string></string></string></string></string>
这就是主要实现类。
测试类:
public static void main(String[] args) throws SQLException { // TODO Auto-generated method stub ConnectionPool pool=ConnectionPool.getInstance(); pool.localInit(); System.out.println(new CityDB().getCode("西安")); }
这个是测试的主方法,ConnectionPool是个数据库连接池,pool.localinit()是对数据库的本地初始化,重要作用是初始化本地数据库的连接等,并建立池,好让用到数据库连接的语句使用,也可以自己创建Connection连接,都可以。
今天在编写该类时,遇见了一些异常,主要还是对Mysql数据库的不了解造成的,就是出现了在插入汉字的时候,出现异常为 ‘海南’ not in feild list ,当时不知道原因,以为是字段问题,但是改完字段名称后还是这样的。左后就直接在数据库中操作,而不是在java程序里,结果还是同样的错误。然后我就重新用navicat for mysql进行建表,相同的字段,结果还是不能存汉字,但是原先的一个表能存汉字,现在的错误为
“incorrect string value”,进过查阅资料得知,是Mysql字符编码的问题,要修改为utf8,最后在新建表时添加如下语句:ENGINE=InnoDB DEFAULT CHARSET=utf8
。
还有就是mysql中的 `(是在TAB键上面和1键前面的那个有波浪的键),就是加在表名和字段上面的,字符串的是'(单引号,不是 ` )。鉴于对MYSQL的研究不多,就不在讲述。
如有不当之处,还请指正!

mysqloffersvariousStorageEngines, 각각의 everitedforentUsecases : 1) innodbisidealforapplicationsneedingAcidCoInceandHighConcurrency, 지원 트랜잭션 및 foreignKeys.2) myIsAmisbestforread-heverworkloads, memoryengineis

MySQL의 일반적인 보안 취약점에는 SQL 주입, 약한 암호, 부적절한 권한 구성 및 업데이트되지 않은 소프트웨어가 포함됩니다. 1. 전처리 명령문을 사용하여 SQL 주입을 방지 할 수 있습니다. 2. 강력한 비밀번호 전략을 사용하여 약한 암호는 피할 수 있습니다. 3. 정기적 인 검토 및 사용자 권한 조정을 통해 부적절한 권한 구성을 해결할 수 있습니다. 4. Unupdated 소프트웨어는 MySQL 버전을 정기적으로 확인하고 업데이트하여 패치 할 수 있습니다.

느린 쿼리 로그를 활성화하고 임계 값을 설정하여 MySQL에서 느린 쿼리를 식별 할 수 있습니다. 1. 느린 쿼리 로그를 활성화하고 임계 값을 설정하십시오. 2. 느린 쿼리 로그 파일을보고 분석하고 심층 분석을 위해 MySQLDumpSlow 또는 PT-Query 소수성과 같은 도구를 사용하십시오. 3. 인덱스 최적화, 쿼리 재 작성 및 select*의 사용을 피함으로써 느린 쿼리 최적화를 달성 할 수 있습니다.

MySQL 서버의 건강 및 성능을 모니터링하려면 시스템 건강, 성능 지표 및 쿼리 실행에주의를 기울여야합니다. 1) 시스템 건강 모니터링 : CPU, 메모리, 디스크 I/O 및 네트워크 활동을 볼 수 있도록 상단, HTOP 또는 ShowGlobalStatus 명령을 사용하십시오. 2) 성능 표시기 추적 : 초당 쿼리 번호, 평균 쿼리 시간 및 캐시 적중률과 같은 주요 표시기를 모니터링합니다. 3) 쿼리 실행 최적화 확인 : 실행 시간이 설정 임계 값을 초과하는 쿼리를 느린 쿼리 로그를 활성화하고 기록 및 최적화하십시오.

MySQL과 Mariadb의 주요 차이점은 성능, 기능 및 라이센스입니다. 1. MySQL은 Oracle에 의해 개발되었으며 Mariadb는 포크입니다. 2. MariaDB는 높은 하중 환경에서 더 나은 성능을 발휘할 수 있습니다. 3. Mariadb는 더 많은 스토리지 엔진과 기능을 제공합니다. 4.MySQL은 듀얼 라이센스를 채택하고 MariaDB는 완전히 오픈 소스입니다. 선택할 때 기존 인프라, 성능 요구 사항, 기능 요구 사항 및 라이센스 비용을 고려해야합니다.

MySQL은 GPL 라이센스를 사용합니다. 1) GPL 라이센스는 MySQL의 무료 사용, 수정 및 분포를 허용하지만 수정 된 분포는 GPL을 준수해야합니다. 2) 상업용 라이센스는 공개 수정을 피할 수 있으며 기밀이 필요한 상업용 응용 프로그램에 적합합니다.

MyISAM 대신 InnoDB를 선택할 때의 상황에는 다음이 포함됩니다. 1) 거래 지원, 2) 높은 동시성 환경, 3) 높은 데이터 일관성; 반대로, MyISAM을 선택할 때의 상황에는 다음이 포함됩니다. 1) 주로 읽기 작업, 2) 거래 지원이 필요하지 않습니다. InnoDB는 전자 상거래 플랫폼과 같은 높은 데이터 일관성 및 트랜잭션 처리가 필요한 응용 프로그램에 적합하지만 MyISAM은 블로그 시스템과 같은 읽기 집약적 및 트랜잭션이없는 애플리케이션에 적합합니다.

MySQL에서 외국 키의 기능은 테이블 간의 관계를 설정하고 데이터의 일관성과 무결성을 보장하는 것입니다. 외국 키는 참조 무결성 검사 및 계단식 작업을 통해 데이터의 효과를 유지합니다. 성능 최적화에주의를 기울이고 사용할 때 일반적인 오류를 피하십시오.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는
