mysql分表操作--简单设计

本文介绍了一种基于类型的不同进行数据库分表的方法,并通过具体实例展示了如何实现数据的插入操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

这里做个例子进行分表,设计很简单,根据类型不同进行分表,比如有三种类型,三张表结构一模一样,建立一个表名索引表,然后根据类型在这张索引表里查询要插入的表名,然后再进行插入操作。
 
索引表:
CREATE TABLE tableindex (
  id int(11) NOT NULL AUTO_INCREMENT,
  tablename varchar(10) DEFAULT NULL,
  type varchar(10) DEFAULT NULL,
  PRIMARY KEY (id)
 
业务表:
CREATE TABLE `e` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `password` varchar(20) DEFAULT NULL,
  `name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8 
三张表e,e0,e1表结构一样
 
package com.msg.domain;

public class User implements java.io.Serializable {
	private static final long serialVersionUID = 1L;
	private String name;
	private String password;
	private String type;
	public User() {
		
	}
	
	public User(String name, String password) {
		this.name = name;
		this.password = password;
	}
	
	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}

	public String getType() {
		return type;
	}

	public void setType(String type) {
		this.type = type;
	}
	
}

 

 

 

public void insertMessage() {
		JdbcUtils jdbc = new JdbcUtils();//JDBC操作类
		try {
			List<User> userList = new ArrayList<User>();
			User user0 = new User(); 
			user0.setName("张三");
			user0.setPassword("123");
			user0.setType("1");
			userList.add(user0);
			User user1 = new User(); 
			user1.setName("李四");
			user1.setPassword("123456");
			user1.setType("2");
			userList.add(user1);
			User user2 = new User(); 
			user2.setName("王五");
			user2.setPassword("890");
			user2.setType("3");
			userList.add(user2);
			for (User user:userList){
				StringBuffer sb = new StringBuffer();
				//查询业务表名
				String tableName = 
					jdbc.query("select * from tableindex where type='"+user.getType()+"'");
				sb.append("insert into "+tableName+"(name,password) values('"+user.getName()+"','"+
						user.getPassword()+"')");
				//执行插入操作
				jdbc.insert(sb.toString());
			}
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值