SpringBoot-(8)-配置MySQL数据库链接,配置数据坚挺拦截,创建默认数据表
一,链接mysql数据库
# 数据源基本配置 spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://127.0.0.1:3306/account_system spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
配置MySQL数据库账户密码
配置jdbc驱动
指定链接数据库名称“account_system”
指定datasouce类型,Druid,便于监控
二,配置连接池等信息
spring.datasource.initialSize: 5 spring.datasource.minIdle: 5 spring.datasource.maxActive: 20 spring.datasource.maxWait: 60000 spring.datasource.timeBetweenEvictionRunsMillis: 60000 spring.datasource.minEvictableIdleTimeMillis: 300000 spring.datasource.validationQuery: SELECT 1 FROM DUAL spring.datasource.testWhileIdle: true spring.datasource.testOnBorrow: false spring.datasource.testOnReturn: false spring.datasource.poolPreparedStatements: true
-
spring.dao.exceptiontranslation.enabled是否开启PersistenceExceptionTranslationPostProcessor,默认为true
-
spring.datasource.abandon-when-percentage-full设定超时被废弃的连接占到多少比例时要被关闭或上报
-
spring.datasource.allow-pool-suspension使用Hikari pool时,是否允许连接池暂停,默认为: false
-
spring.datasource.alternate-username-allowed是否允许替代的用户名.
-
spring.datasource.auto-commit指定updates是否自动提交.
-
spring.datasource.catalog指定默认的catalog.
-
spring.datasource.commit-on-return设置当连接被归还时,是否要提交所有还未完成的事务
-
spring.datasource.connection-init-sql指定连接被创建,再被添加到连接池之前执行的sql.
-
spring.datasource.connection-init-sqls使用DBCP connection pool时,指定初始化时要执行的sql
-
spring.datasource.connection-properties.[key]在使用DBCP connection pool时指定要配置的属性
-
spring.datasource.connection-test-query指定校验连接合法性执行的sql语句
-
spring.datasource.connection-timeout指定连接的超时时间,毫秒单位.
-
spring.datasource.continue-on-error在初始化数据库时,遇到错误是否继续,默认false
-
spring.datasource.data指定Data (DML)脚本
-
spring.datasource.data-source-class-name指定数据源的全限定名.
-
spring.datasource.data-source-jndi指定jndi的地址
-
spring.datasource.data-source-properties.[key]使用Hikari connection pool时,指定要设置的属性
-
spring.datasource.db-properties使用Tomcat connection pool,指定要设置的属性
-
spring.datasource.default-auto-commit是否自动提交.
-
spring.datasource.default-catalog指定连接默认的catalog.
-
spring.datasource.default-read-only是否设置默认连接只读.
-
spring.datasource.default-transaction-isolation指定连接的事务的默认隔离级别.
-
spring.datasource.driver-class-name指定driver的类名,默认从jdbc url中自动探测.
-
spring.datasource.fair-queue是否采用FIFO返回连接.
-
spring.datasource.health-check-properties.[key]使用Hikari connection pool时,在心跳检查时传递的属性
-
spring.datasource.idle-timeout指定连接多久没被使用时,被设置为空闲,默认为10ms
-
spring.datasource.ignore-exception-on-pre-load当初始化连接池时,是否忽略异常.
-
spring.datasource.init-sql当连接创建时,执行的sql
-
spring.datasource.initial-size指定启动连接池时,初始建立的连接数量
-
spring.datasource.initialization-fail-fast当创建连接池时,没法创建指定最小连接数量是否抛异常
-
spring.datasource.initialize指定初始化数据源,是否用data.sql来初始化,默认: true
-
spring.datasource.isolate-internal-queries指定内部查询是否要被隔离,默认为false
-
spring.datasource.jdbc-interceptors使用Tomcat connection pool时,指定jdbc拦截器,分号分隔
-
spring.datasource.jdbc-url指定JDBC URL.
-
spring.datasource.jmx-enabled是否开启JMX,默认为: false
-
spring.datasource.jndi-name指定jndi的名称.
-
spring.datasource.leak-detection-threshold使用Hikari connection pool时,多少毫秒检测一次连接泄露.
-
spring.datasource.log-abandoned使用DBCP connection pool,是否追踪废弃statement或连接,默认为: false
-
spring.datasource.log-validation-errors当使用Tomcat connection pool是否打印校验错误.
-
spring.datasource.login-timeout指定连接数据库的超时时间.
-
spring.datasource.max-active指定连接池中最大的活跃连接数.
-
spring.datasource.max-age指定连接池中连接的最大年龄
-
spring.datasource.max-idle指定连接池最大的空闲连接数量.
-
spring.datasource.max-lifetime指定连接池中连接的最大生存时间,毫秒单位.
-
spring.datasource.max-open-prepared-statements指定最大的打开的prepared statements数量.
-
spring.datasource.max-wait指定连接池等待连接返回的最大等待时间,毫秒单位.
-
spring.datasource.maximum-pool-size指定连接池最大的连接数,包括使用中的和空闲的连接.
-
spring.datasource.min-evictable-idle-time-millis指定一个空闲连接最少空闲多久后可被清除.
-
spring.datasource.min-idle指定必须保持连接的最小值(For DBCP and Tomcat connection pools)
-
spring.datasource.minimum-idle指定连接维护的最小空闲连接数,当使用HikariCP时指定.
-
spring.datasource.name指定数据源名.
-
spring.datasource.num-tests-per-eviction-run指定运行每个idle object evictor线程时的对象数量
-
spring.datasource.password指定数据库密码.
-
spring.datasource.platform指定schema要使用的Platform(schema-${platform}.sql),默认为: all
-
spring.datasource.pool-name指定连接池名字.
-
spring.datasource.pool-prepared-statements指定是否池化statements.
-
spring.datasource.propagate-interrupt-state在等待连接时,如果线程被中断,是否传播中断状态.
-
spring.datasource.read-only当使用Hikari connection pool时,是否标记数据源只读
-
spring.datasource.register-mbeans指定Hikari connection pool是否注册JMX MBeans.
-
spring.datasource.remove-abandoned指定当连接超过废弃超时时间时,是否立刻删除该连接.
-
spring.datasource.remove-abandoned-timeout指定连接应该被废弃的时间.
-
spring.datasource.rollback-on-return在归还连接时,是否回滚等待中的事务.
-
spring.datasource.schema指定Schema (DDL)脚本.
-
spring.datasource.separator指定初始化脚本的语句分隔符,默认: ;
-
spring.datasource.sql-script-encoding指定SQL scripts编码.
-
spring.datasource.suspect-timeout指定打印废弃连接前的超时时间.
-
spring.datasource.test-on-borrow当从连接池借用连接时,是否测试该连接.
-
spring.datasource.test-on-connect创建时,是否测试连接
-
spring.datasource.test-on-return在连接归还到连接池时是否测试该连接.
-
spring.datasource.test-while-idle当连接空闲时,是否执行连接测试.
-
spring.datasource.time-between-eviction-runs-millis指定空闲连接检查、废弃连接清理、空闲连接池大小调整之间的操作时间间隔
-
spring.datasource.transaction-isolation指定事务隔离级别,使用Hikari connection pool时指定
-
spring.datasource.url指定JDBC URL.
-
spring.datasource.use-disposable-connection-facade是否对连接进行包装,防止连接关闭之后被使用.
-
spring.datasource.use-equals比较方法名时是否使用String.equals()替换==.
-
spring.datasource.use-lock是否对连接操作加锁
-
spring.datasource.username指定数据库名.
-
spring.datasource.validation-interval指定多少ms执行一次连接校验.
-
spring.datasource.validation-query指定获取连接时连接校验的sql查询语句.
-
spring.datasource.validation-query-timeout指定连接校验查询的超时时间.
-
spring.datasource.validation-timeout设定连接校验的超时时间,当使用Hikari connection pool时指定
-
spring.datasource.validator-class-name用来测试查询的validator全限定名.
-
spring.datasource.xa.data-source-class-name指定数据源的全限定名.
-
spring.datasource.xa.properties指定传递给XA data source的属性
三,配置创建数据表sql文件路径
spring.datasource.initialization-mode=always spring.datasource.schema[0]=classpath:sql/accounts.sql
account.sql
SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- Table structure for accounts -- ---------------------------- DROP TABLE IF EXISTS `accounts`; CREATE TABLE `accounts` ( `id` int(11) NOT NULL AUTO_INCREMENT, `nickName` varchar(80) DEFAULT NULL, `lastName` varchar(60) DEFAULT NULL, `password` varchar(40) DEFAULT NULL, `email` varchar(100) DEFAULT NULL, `mobilePhone` varchar(30) DEFAULT NULL, `address` varchar(255) DEFAULT NULL, `photo` varchar(40) DEFAULT NULL, `authority` INT DEFAULT 0x001, `gender` int(2) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
四,运行项目,查看数据库是否自动生成表
运行项目之前,先在数据库中创建好对应的数据库
运行项目以后,查看是否有对应的数据表在数据库中